diff options
Diffstat (limited to 'target/linux/s3c24xx/patches-2.6.26/0135-tracking-2.6.26-rc1-sdio-pnp-changes.patch.patch')
-rwxr-xr-x | target/linux/s3c24xx/patches-2.6.26/0135-tracking-2.6.26-rc1-sdio-pnp-changes.patch.patch | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/target/linux/s3c24xx/patches-2.6.26/0135-tracking-2.6.26-rc1-sdio-pnp-changes.patch.patch b/target/linux/s3c24xx/patches-2.6.26/0135-tracking-2.6.26-rc1-sdio-pnp-changes.patch.patch new file mode 100755 index 0000000..c7ac432 --- /dev/null +++ b/target/linux/s3c24xx/patches-2.6.26/0135-tracking-2.6.26-rc1-sdio-pnp-changes.patch.patch @@ -0,0 +1,111 @@ +From 5986281af77185adca248453ca06ce4bcca6bfb9 Mon Sep 17 00:00:00 2001 +From: Andy Green <andy@openmoko.com> +Date: Fri, 25 Jul 2008 23:06:07 +0100 +Subject: [PATCH] tracking-2.6.26-rc1-sdio-pnp-changes.patch + Signed-off-by: Andy Green <andy@openmoko.com> + +--- + drivers/sdio/stack/busdriver/sdio_bus_os.c | 33 +++++++++++----------------- + 1 files changed, 13 insertions(+), 20 deletions(-) + +diff --git a/drivers/sdio/stack/busdriver/sdio_bus_os.c b/drivers/sdio/stack/busdriver/sdio_bus_os.c +index dbdb955..2650d93 100644 +--- a/drivers/sdio/stack/busdriver/sdio_bus_os.c ++++ b/drivers/sdio/stack/busdriver/sdio_bus_os.c +@@ -60,6 +60,8 @@ void pnp_remove_card_device(struct pnp_dev *dev); + #include <linux/sdio/sdio_busdriver.h> + #include <linux/sdio/sdio_lib.h> + #include "_busdriver.h" ++/* new for 2.6.26-rc1 --- not sure this is a great way... */ ++#include "../../../pnp/base.h" + + #define DESCRIPTION "SDIO Bus Driver" + #define AUTHOR "Atheros Communications, Inc." +@@ -369,14 +371,14 @@ static spinlock_t InUseDevicesLock = SPIN_LOCK_UNLOCKED; + static const struct pnp_device_id pnp_idtable[] = { + {"SD_XXXX", 0} + }; +-static int sdio_get_resources(struct pnp_dev * pDev, struct pnp_resource_table * res) ++static int sdio_get_resources(struct pnp_dev * pDev) + { + DBG_PRINT(SDDBG_TRACE, + ("SDIO BusDriver - sdio_get_resources: %s\n", + pDev->dev.bus_id)); + return 0; + } +-static int sdio_set_resources(struct pnp_dev * pDev, struct pnp_resource_table * res) ++static int sdio_set_resources(struct pnp_dev * pDev) + { + DBG_PRINT(SDDBG_TRACE, + ("SDIO BusDriver - sdio_set_resources: %s\n", +@@ -494,7 +496,8 @@ static int UnregisterDriver(PSDFUNCTION pFunction) + */ + SDIO_STATUS OS_InitializeDevice(PSDDEVICE pDevice, PSDFUNCTION pFunction) + { +- struct pnp_id *pFdname; ++ char id_name[20]; ++ + memset(&pDevice->Device, 0, sizeof(pDevice->Device)); + pDevice->Device.dev.driver_data = (PVOID)pFunction; + //?? pDevice->Device.data = (PVOID)pFunction; +@@ -510,20 +513,12 @@ SDIO_STATUS OS_InitializeDevice(PSDDEVICE pDevice, PSDFUNCTION pFunction) + pDevice->Device.protocol = &sdio_protocol; + pDevice->Device.active = 1; + +- pnp_init_resource_table(&pDevice->Device.res); +- +- pFdname = KernelAlloc(sizeof(struct pnp_id)); +- +- if (NULL == pFdname) { +- return SDIO_STATUS_NO_RESOURCES; +- } + /* set the id as slot number/function number */ +- snprintf(pFdname->id, sizeof(pFdname->id), "SD_%02X%02X", ++ snprintf(id_name, sizeof(id_name) - 1, "SD_%02X%02X", + pDevice->pHcd->SlotNumber, (UINT)SDDEVICE_GET_SDIO_FUNCNO(pDevice)); +- pFdname->next = NULL; + DBG_PRINT(SDDBG_TRACE, ("SDIO BusDriver - OS_InitializeDevice adding id: %s\n", +- pFdname->id)); +- pnp_add_id(pFdname, &pDevice->Device); ++ id_name)); ++ pnp_add_id(&pDevice->Device, id_name); + + /* deal with DMA settings */ + if (pDevice->pHcd->pDmaDescription != NULL) { +@@ -620,9 +615,9 @@ void OS_RemoveDevice(PSDDEVICE pDevice) + SDIO_STATUS SDIO_BusAddOSDevice(PSDDMA_DESCRIPTION pDma, POS_PNPDRIVER pDriver, POS_PNPDEVICE pDevice) + { + int err; +- struct pnp_id *pFdname; + struct pnp_device_id *pFdid; + static int slotNumber = 0; /* we just use an increasing count for the slots number */ ++ char id_name[20]; + + if (pDma != NULL) { + pDevice->dev.dma_mask = &pDma->Mask; +@@ -653,19 +648,17 @@ SDIO_STATUS SDIO_BusAddOSDevice(PSDDMA_DESCRIPTION pDma, POS_PNPDRIVER pDriver, + pDevice->capabilities = PNP_REMOVABLE | PNP_DISABLE; + pDevice->active = 1; + +- pFdname = KernelAlloc(sizeof(struct pnp_id)); + /* set the id as slot number/function number */ +- snprintf(pFdname->id, sizeof(pFdname->id), "SD_%02X08", ++ snprintf(id_name, sizeof(id_name) - 1, "SD_%02X08", + 0); //??pDevice->pHcd->SlotNumber);//?????fix this, slotnumber isn't vaialble yet +- pFdname->next = NULL; +- pnp_add_id(pFdname, pDevice); ++ pnp_add_id(pDevice, id_name); + + /* get a unique device number */ + spin_lock(&InUseDevicesLock); + pDevice->number = FirstClearBit(&InUseDevices); + SetBit(&InUseDevices, pDevice->number); + spin_unlock(&InUseDevicesLock); +- pnp_init_resource_table(&pDevice->res); ++ + err = pnp_add_device(pDevice); + if (err < 0) { + DBG_PRINT(SDDBG_ERROR, ("SDIO BusDriver - SDIO_GetBusOSDevice failed pnp_device_add: %d\n", +-- +1.5.6.3 + |