Re: [Pcihpd-discuss] [patch 1/2] acpiphp: allocate resources for adapters with bridges

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Kristen,

At Fri, 07 Oct 2005 10:45:46 -0700,
Kristen Accardi <[email protected]> wrote:
> 
> Allocate resources for adapters with p2p bridges.
> 
> Signed-off-by: Kristen Carlson Accardi <[email protected]>
> 
> diff -uprN -X linux-2.6.14-rc2/Documentation/dontdiff linux-2.6.14-rc2/drivers/pci/hotplug/acpiphp_glue.c linux-2.6.14-rc2-kca1/drivers/pci/hotplug/acpiphp_glue.c
> --- linux-2.6.14-rc2/drivers/pci/hotplug/acpiphp_glue.c	2005-08-28 16:41:01.000000000 -0700
> +++ linux-2.6.14-rc2-kca1/drivers/pci/hotplug/acpiphp_glue.c	2005-09-28 10:43:15.000000000 -0700
> @@ -58,6 +58,9 @@ static LIST_HEAD(bridge_list);
>  
>  static void handle_hotplug_event_bridge (acpi_handle, u32, void *);
>  static void handle_hotplug_event_func (acpi_handle, u32, void *);
> +static void acpiphp_sanitize_bus(struct pci_bus *bus);
> +static void acpiphp_set_hpp_values(acpi_handle handle, struct pci_bus *bus);
> +
>  
>  /*
>   * initialization & terminatation routines
> @@ -207,6 +210,9 @@ register_slot(acpi_handle handle, u32 lv
>  		slot->flags |= (SLOT_ENABLED | SLOT_POWEREDON);
>  	}
>  
> +	/* store the handle in the slot for later. */
> +	slot->handle = handle;
> +
>  	/* install notify handler */
>  	status = acpi_install_notify_handler(handle,
>  					     ACPI_SYSTEM_NOTIFY,
> @@ -796,7 +802,12 @@ static int enable_device(struct acpiphp_
>  		}
>  	}
>  
> +	pci_bus_size_bridges(bus);
>  	pci_bus_assign_resources(bus);
> +	acpiphp_sanitize_bus(bus);
> +	acpiphp_set_hpp_values(slot->handle, bus);
> +	pci_enable_bridges(bus);
> +	acpiphp_configure_ioapics(slot->handle);
>  	pci_bus_add_devices(bus);
>  
>  	/* associate pci_dev to our representation */
> diff -uprN -X linux-2.6.14-rc2/Documentation/dontdiff linux-2.6.14-rc2/drivers/pci/hotplug/acpiphp.h linux-2.6.14-rc2-kca1/drivers/pci/hotplug/acpiphp.h
> --- linux-2.6.14-rc2/drivers/pci/hotplug/acpiphp.h	2005-08-28 16:41:01.000000000 -0700
> +++ linux-2.6.14-rc2-kca1/drivers/pci/hotplug/acpiphp.h	2005-09-28 10:43:15.000000000 -0700
> @@ -119,6 +119,7 @@ struct acpiphp_slot {
>  	struct list_head funcs;		/* one slot may have different
>  					   objects (i.e. for each function) */
>  	struct semaphore crit_sect;
> +	acpi_handle handle;
>  
>  	u32		id;		/* slot id (serial #) for hotplug core */
>  	u8		device;		/* pci device# */


If the p2p bridge is one of the multi-function devices,
the slot->handle would be over-written by the last found
device's handle.
Is your adaptor is *non*-multifunctional?

I'm also working for p2p hotplug with acpiphp, and your code
is almost same to mine. I could find some bugs in my patch
by your patch. I'll update my patch.

Thanks,
MUNE

-- 
MUNEDA Takahiro <[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/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux