On Tue, 2005-03-01 at 18:19 +0100, Andi Kleen wrote: > Hidetoshi Seto <[EMAIL PROTECTED]> writes: > > > > > int sample_read_with_iochk(struct pci_dev *dev, u32 *buf, int words) > > { > > unsigned long ofs = pci_resource_start(dev, 0) + DATA_OFFSET; > > int i; > > > > /* Create magical cookie on the stack */ > > iocookie cookie; > > > > /* Critical section start */ > > iochk_clear(&dev, &cookie); > > { > > /* Get the whole packet of data */ > > for (i = 0; i < words; i++) > > *buf++ = ioread32(dev, ofs); > > } > > /* Critical section end. Did we have any trouble? */ > > if ( iochk_read(&cookie) ) return -1; > > Looks good for handling PCI-Express errors. > > But what would the default handling be? It would be nice if there > was a simple way for a driver to say "just shut me down on an error" > without adding iochk_* to each function. Ideally this would be just > a standard callback that knows how to clean up the driver.
I think that would be the lack of a callback, see other messages. > > +void iochk_clear(iocookie *cookie, struct pci_dev *dev) > > +{ > > + local_irq_save(*cookie); > > +} > > + > > +int iochk_read(iocookie *cookie) > > +{ > > + local_irq_restore(*cookie); > > + return 0; > > +} > > These should be inlined. > > > +EXPORT_SYMBOL(iochk_init); > > This doesn't need to be exported. > > -Andi -- Benjamin Herrenschmidt <[EMAIL PROTECTED]> - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/