On Mon, Apr 23, 2012 at 7:30 PM, Jiang Liu <jiang.liu@xxxxxxxxxx> wrote: >> If you are going to hotplug the entire IOH, then you are probably ok >> with network links going down, so could you just down the links and >> remove the driver with the existing code? > > I feel it's a little risky to shut down/restart all network interfaces > for hot-removal of IOH, that may disturb the applications. I guess I'm confused... wouldn't the removal of an entire domain of pci devices disturb userspace applications? > And there > are also other kinds of clients, such as ASYNC_TX, seems we can't > adopt this method to reclaim DMA channels from ASYNC_TX subsystem. I say handle this like block device hotplug. I.e. the driver stays loaded but the channel is put into an 'offline' state. So the driver hides the fact that the hardware went away. Similar to how you can remove a disk but /dev/sda sticks around until the last reference is gone (and the driver 'sd' sticks around until all block devices are gone). I expect the work will be in making sure existing clients are prepared to handle NULL returns from ->device_prep_dma_*. In some cases the channel is treated more like a cpu, so a NULL return from ->device_prep_dma_memcpy() has been interpreted as "device is temporarily busy, it is safe to try again". We would need to change that to a permanent indication that the device is gone and not attempt retry. -- Dan -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html