diff options
Diffstat (limited to 'arch')
5 files changed, 94 insertions, 0 deletions
diff --git a/arch/arm/mach-tegra/board_nvodm.c b/arch/arm/mach-tegra/board_nvodm.c index f81736679916..0717929e1ca7 100644 --- a/arch/arm/mach-tegra/board_nvodm.c +++ b/arch/arm/mach-tegra/board_nvodm.c @@ -386,6 +386,7 @@ static void __init register_enc28j60(void) } #endif + #ifndef CONFIG_KEYBOARD_TEGRA #define kbc_init() do { } while (0) @@ -448,6 +449,58 @@ fail: } #endif +static struct spi_board_info tegra_spi_ipc_devices[] __initdata = +{ + { + .modalias = "spi_ipc", + .bus_num = 0, + .chip_select = 0, + .mode = SPI_MODE_1, + .max_speed_hz = 12000000, + .platform_data = NULL, + .irq = 0, + }, +}; + +static void __init register_spi_ipc_devices(void) +{ + NvError err; + NvU32 irq; + NvU32 instance = 0xFFFF; + NvU32 cs = 0xFFFF; + const NvOdmPeripheralConnectivity *pConnectivity = NULL; + int i; + + pConnectivity = + NvOdmPeripheralGetGuid(NV_ODM_GUID('s','p','i',' ','_','i','p','c')); + if (!pConnectivity) + return; + + for (i = 0; i < pConnectivity->NumAddress; i++) + { + switch (pConnectivity->AddressList[i].Interface) + { + case NvOdmIoModule_Spi: + instance = pConnectivity->AddressList[i].Instance; + cs = pConnectivity->AddressList[i].Address; + break; + default: + break; + } + } + + /* Infineon SPI Protocol driver needs one SPI info and a gpio for interrupt */ + if (instance == 0xffff || cs == 0xffff) + return; + + printk("Enabled Infineon IPC Protocol driver\n"); + + tegra_spi_ipc_devices[0].bus_num = instance; + tegra_spi_ipc_devices[0].chip_select = cs; + spi_register_board_info(tegra_spi_ipc_devices, ARRAY_SIZE(tegra_spi_ipc_devices)); +} + + static void __init tegra_machine_init(void) { #if defined(CONFIG_USB_ANDROID) || defined(CONFIG_USB_ANDROID_MODULE) @@ -481,6 +534,7 @@ static void __init tegra_machine_init(void) #endif register_enc28j60(); + register_spi_ipc_devices(); /* register the devices */ #ifdef CONFIG_MTD_NAND_TEGRA diff --git a/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query.c b/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query.c index 0b21b7245009..fa8098570209 100755 --- a/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query.c +++ b/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query.c @@ -770,6 +770,9 @@ NvOdmQuerySpiGetDeviceInfo( static const NvOdmQuerySpiDeviceInfo s_Spi1Cs0Info_EmpRil = {NvOdmQuerySpiSignalMode_0, NV_TRUE, NV_TRUE}; + static const NvOdmQuerySpiDeviceInfo s_Spi1Cs0Info_IfxRil = + {NvOdmQuerySpiSignalMode_1, NV_TRUE, NV_FALSE}; + static const NvOdmQuerySpiDeviceInfo s_Spi1Cs0Info = {NvOdmQuerySpiSignalMode_0, NV_TRUE, NV_FALSE}; @@ -787,6 +790,11 @@ NvOdmQuerySpiGetDeviceInfo( (ControllerId == 0 ) && (ChipSelect == 0)) return &s_Spi1Cs0Info_EmpRil; break; + case TEGRA_DEVKIT_BCT_CUSTOPT_0_RIL_IFX: + if ((OdmIoModule == NvOdmIoModule_Spi) && + (ControllerId == 0 ) && (ChipSelect == 0)) + return &s_Spi1Cs0Info_IfxRil; + break; } if ((OdmIoModule == NvOdmIoModule_Spi) && diff --git a/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query_discovery.c b/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query_discovery.c index e14fa7c7deec..9cf5ddf199a2 100644 --- a/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query_discovery.c +++ b/arch/arm/mach-tegra/odm_kit/query/whistler/nvodm_query_discovery.c @@ -772,6 +772,19 @@ NvIsFilteredPeripheral(const NvOdmPeripheralConnectivity* pConnectivity) } } + if (pConnectivity->Guid == NV_ODM_GUID('s','p','i',' ','_','i','p','c')) + { + if (ril == TEGRA_DEVKIT_BCT_CUSTOPT_0_RIL_IFX) + { + return NV_FALSE; // IFX supported - don't filter it + } + else + { + return NV_TRUE; // IFX not supported - filter it + } + } + + if (!Personality) Personality = TEGRA_DEVKIT_DEFAULT_PERSONALITY; diff --git a/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_addresses.h b/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_addresses.h index 7dca2fca27a0..70f20af74044 100644 --- a/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_addresses.h +++ b/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_addresses.h @@ -83,3 +83,14 @@ static const NvOdmIoAddress s_ffaEmpM570Addresses[] = { NvOdmIoModule_Gpio, 0x19, 0x0 }, /* GPIO Port Z and Pin 0 AWR */ { NvOdmIoModule_Gpio, 0x18, 0x6 }, /* GPIO Port Y and Pin 6 CWR */ }; + +// IFX Modem module +static const NvOdmIoAddress s_ffaInfnAddresses[] = +{ + { NvOdmIoModule_Spi, 0x0, 0x0 }, /* Spi Controller 0 and Chip Select 0 */ + { NvOdmIoModule_Gpio, 0x18, 0x6 }, /* GPIO Port Y and Pin 6 SRDY */ + { NvOdmIoModule_Gpio, 0x19, 0x0 }, /* GPIO Port Z and Pin 0 MRDY */ + { NvOdmIoModule_Gpio, 0x15, 0x0 }, /* GPIO Port V and Pin 0 Reset */ + { NvOdmIoModule_Gpio, 0x15, 0x1 } /* GPIO Port V and Pin 1 Power */ +}; + diff --git a/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_peripherals.h b/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_peripherals.h index 67e7cf18cc61..69b364f11689 100644 --- a/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_peripherals.h +++ b/arch/arm/mach-tegra/odm_kit/query/whistler/subboards/nvodm_query_discovery_e951_peripherals.h @@ -71,4 +71,12 @@ NvOdmPeripheralClass_Other }, +// IFX Modem on COMMs Module +{ + NV_ODM_GUID('s','p','i',' ','_','i','p','c'), + s_ffaInfnAddresses, + NV_ARRAY_SIZE(s_ffaInfnAddresses), + NvOdmPeripheralClass_Other +}, + // NOTE: This list *must* end with a trailing comma. |