[PATCH] PCI: move pci core to use add_hotplug_env_var()
This fixes a bug in the environment variables for all PCI device hotplug calls. Thanks to Kay Sievers for pointing out the problem. Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
Родитель
2fd9d74b35
Коммит
7bcf5c0e7f
|
@ -20,46 +20,35 @@ int pci_hotplug (struct device *dev, char **envp, int num_envp,
|
||||||
|
|
||||||
scratch = buffer;
|
scratch = buffer;
|
||||||
|
|
||||||
/* stuff we want to pass to /sbin/hotplug */
|
|
||||||
envp[i++] = scratch;
|
|
||||||
length += scnprintf (scratch, buffer_size - length, "PCI_CLASS=%04X",
|
|
||||||
pdev->class);
|
|
||||||
if ((buffer_size - length <= 0) || (i >= num_envp))
|
|
||||||
return -ENOMEM;
|
|
||||||
++length;
|
|
||||||
scratch += length;
|
|
||||||
|
|
||||||
envp[i++] = scratch;
|
if (add_hotplug_env_var(envp, num_envp, &i,
|
||||||
length += scnprintf (scratch, buffer_size - length, "PCI_ID=%04X:%04X",
|
buffer, buffer_size, &length,
|
||||||
pdev->vendor, pdev->device);
|
"PCI_CLASS=%04X", pdev->class))
|
||||||
if ((buffer_size - length <= 0) || (i >= num_envp))
|
|
||||||
return -ENOMEM;
|
|
||||||
++length;
|
|
||||||
scratch += length;
|
|
||||||
|
|
||||||
envp[i++] = scratch;
|
|
||||||
length += scnprintf (scratch, buffer_size - length,
|
|
||||||
"PCI_SUBSYS_ID=%04X:%04X", pdev->subsystem_vendor,
|
|
||||||
pdev->subsystem_device);
|
|
||||||
if ((buffer_size - length <= 0) || (i >= num_envp))
|
|
||||||
return -ENOMEM;
|
|
||||||
++length;
|
|
||||||
scratch += length;
|
|
||||||
|
|
||||||
envp[i++] = scratch;
|
|
||||||
length += scnprintf (scratch, buffer_size - length, "PCI_SLOT_NAME=%s",
|
|
||||||
pci_name(pdev));
|
|
||||||
if ((buffer_size - length <= 0) || (i >= num_envp))
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
envp[i++] = scratch;
|
if (add_hotplug_env_var(envp, num_envp, &i,
|
||||||
length += scnprintf (scratch, buffer_size - length,
|
buffer, buffer_size, &length,
|
||||||
"MODALIAS=pci:v%08Xd%08Xsv%08Xsd%08Xbc%02Xsc%02Xi%02x",
|
"PCI_ID=%04X:%04X", pdev->vendor, pdev->device))
|
||||||
pdev->vendor, pdev->device,
|
return -ENOMEM;
|
||||||
pdev->subsystem_vendor, pdev->subsystem_device,
|
|
||||||
(u8)(pdev->class >> 16), (u8)(pdev->class >> 8),
|
if (add_hotplug_env_var(envp, num_envp, &i,
|
||||||
(u8)(pdev->class));
|
buffer, buffer_size, &length,
|
||||||
if ((buffer_size - length <= 0) || (i >= num_envp))
|
"PCI_SUBSYS_ID=%04X:%04X", pdev->subsystem_vendor,
|
||||||
|
pdev->subsystem_device))
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
if (add_hotplug_env_var(envp, num_envp, &i,
|
||||||
|
buffer, buffer_size, &length,
|
||||||
|
"PCI_SLOT_NAME=%s", pci_name(pdev)))
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
if (add_hotplug_env_var(envp, num_envp, &i,
|
||||||
|
buffer, buffer_size, &length,
|
||||||
|
"MODALIAS=pci:v%08Xd%08Xsv%08Xsd%08Xbc%02Xsc%02Xi%02x",
|
||||||
|
pdev->vendor, pdev->device,
|
||||||
|
pdev->subsystem_vendor, pdev->subsystem_device,
|
||||||
|
(u8)(pdev->class >> 16), (u8)(pdev->class >> 8),
|
||||||
|
(u8)(pdev->class)))
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
envp[i] = NULL;
|
envp[i] = NULL;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче