On Tue, Nov 22, 2011 at 06:05:48PM +0100, Marc Vertes wrote: > Wolfram Sang <w.sang@xxxxxxxxxxxxxx> wrote: > > > On Tue, Nov 22, 2011 at 12:17:13PM +0100, Marc Vertes wrote: > > > Add a new driver for the hardware watchdog timer on VIA chipsets. > > > Tested on a Artigo A1100, VX855 chipset. > > > > > > Signed-off-by: Marc Vertes <marc.vertes@xxxxxxxxxx> > > > > New watchdog drivers should use the framework. Have a look at > > Documentation/watchdog/convert_drivers_to_kernel_api.txt for a guide. It > > is mainly removing code, though. > > > Here it is: Great, thanks. > +static int wdt_start(struct watchdog_device *wdev) > +{ > + /* Nothing to do. The watchdog can only be started by the BIOS. */ > + return 0; > +} > + > +static int wdt_stop(struct watchdog_device *wdev) > +{ > + /* Nothing to do. The watchdog can not be stopped. */ > + return 0; > +} Hmm, I'll leave this to Wim if it can stay like this (or if he wants a timer to serve the non-stoppable watchdog or so). > +static int __devinit wdt_probe(struct pci_dev *pdev, > + const struct pci_device_id *ent) > +{ > + unsigned int mmio = 0; > + void __iomem *wdt_mem; > + int ret; > + > + if (pci_enable_device(pdev)) { > + dev_err(&pdev->dev, "cannot enable PCI device\n"); > + return -ENODEV; > + } > + pci_read_config_dword(pdev, VIA_WDT_MB_OFFSET, &mmio); > + dev_info(&pdev->dev, "VIA Chipset watchdog MMIO: %x\n", mmio); > + if (mmio == 0) { > + dev_err(&pdev->dev, "watchdog timer is not enabled in BIOS\n"); > + return -ENODEV; > + } What about if (mmio != 0) { dev_info("VIA Chipset...") } else { dev_err() return -ENODEV; } to only have the needed printouts. > + wdt_mem = ioremap(mmio, 8); > + if (wdt_mem == NULL) { > + dev_err(&pdev->dev, "cannot remap VIA wdt mmio registers\n"); > + return -ENODEV; > + } > + ret = watchdog_register_device(&wdt_dev); > + if (ret) > + return ret; You need to iounmap in the error-case. > + watchdog_set_drvdata(&wdt_dev, wdt_mem); > + if (readl(wdt_mem) & VIA_WDT_FIRED) { > + wdt_dev.bootstatus |= WDIOF_CARDRESET; > + dev_notice(&pdev->dev, "restarted by expired watchdog\n"); Skip the printout. This can be detected using CARDRESET. > +/* > + * The driver has not been tested yet on CX700 and VX800. > + */ Then, I'd rather skip this comment and the IDs. Or if you are sure enough it works, leave them in ;) Best option would be testers showing up. Regards, Wolfram -- Pengutronix e.K. | Wolfram Sang | Industrial Linux Solutions | http://www.pengutronix.de/ |
Attachment:
signature.asc
Description: Digital signature