> From: Russell King [mailto:[EMAIL PROTECTED]] > > Linus Torvalds writes: > > - me: UHCI drivers really need to enable bus mastering. > > But it'll already be turned on if pci_assign_unassigned_resources() is > called. This calls pdev_enable_device for every single device, which > turns on the bus master bit in the PCI command register. > > Is it intentional that pci_assign_unassigned_resources should: > 1. enable all devices? > 2. enable bus master on all devices? Russell beat me to this question (must have something to do with that .uk location). I think that Linus's patch is correct and that pci/setup_res.c::pdev_enable_device() shouldn't be doing this: /* ??? Always turn on bus mastering. If the device doesn't support it, the bit will go into the bucket. */ cmd |= PCI_COMMAND_MASTER; First, the ??? makes it iffy. Second, if the device doesn't support it, OK, but if the device does support bus mastering and the device has been programmed from a previous kernel/driver bootup (i.e., the device isn't reset by a soft boot), then the device still knows some memory addresses to DMA into, but it shouldn't be using those. This is addressed in a Word .doc file at www.pcisig.com/developers/docs/ : "Warm Boot on PCI Machines". The short summary is that soft reset should disable bus mastering and not re-enable it. This doc says that device drivers (or expansion ROM code) are responsible for setting the bus master bit. Third, removing this will help find drivers that don't do pci_set_master() when they should (like UHCI HCDs). :( ~Randy -- _______________________________________________ |randy.dunlap_at_intel.com 503-677-5408| |NOTE: Any views presented here are mine alone| |& may not represent the views of my employer.| -----------------------------------------------
> From: Russell King [mailto:[EMAIL PROTECTED]] > > Linus Torvalds writes: > > - me: UHCI drivers really need to enable bus mastering. > > But it'll already be turned on if pci_assign_unassigned_resources() is > called. This calls pdev_enable_device for every single device, which > turns on the bus master bit in the PCI command register. > > Is it intentional that pci_assign_unassigned_resources should: > 1. enable all devices? > 2. enable bus master on all devices? Russell beat me to this question (must have something to do with that .uk location). I think that Linus's patch is correct and that pci/setup_res.c::pdev_enable_device() shouldn't be doing this: