Rabin Vincent | fbf1ead | 2010-09-29 19:46:32 +0530 | [diff] [blame^] | 1 | /* |
| 2 | * Copyright (C) ST-Ericsson SA 2010 |
| 3 | * |
| 4 | * Author: Rabin Vincent <rabin.vincent@stericsson.com> for ST-Ericsson |
| 5 | * License terms: GNU General Public License (GPL), version 2. |
| 6 | */ |
| 7 | |
| 8 | #ifndef __DEVICES_DB8500_H |
| 9 | #define __DEVICES_DB8500_H |
| 10 | |
| 11 | #include "devices-common.h" |
| 12 | |
| 13 | struct ske_keypad_platform_data; |
| 14 | struct pl022_ssp_controller; |
| 15 | |
| 16 | static inline struct platform_device * |
| 17 | db8500_add_ske_keypad(struct ske_keypad_platform_data *pdata) |
| 18 | { |
| 19 | return dbx500_add_platform_device_4k1irq("nmk-ske-keypad", -1, |
| 20 | U8500_SKE_BASE, |
| 21 | IRQ_DB8500_KB, pdata); |
| 22 | } |
| 23 | |
| 24 | static inline struct amba_device * |
| 25 | db8500_add_ssp(const char *name, resource_size_t base, int irq, |
| 26 | struct pl022_ssp_controller *pdata) |
| 27 | { |
| 28 | return dbx500_add_amba_device(name, base, irq, pdata, SSP_PER_ID); |
| 29 | } |
| 30 | |
| 31 | |
| 32 | #define db8500_add_i2c0(pdata) \ |
| 33 | dbx500_add_i2c(0, U8500_I2C0_BASE, IRQ_DB8500_I2C0, pdata) |
| 34 | #define db8500_add_i2c1(pdata) \ |
| 35 | dbx500_add_i2c(1, U8500_I2C1_BASE, IRQ_DB8500_I2C1, pdata) |
| 36 | #define db8500_add_i2c2(pdata) \ |
| 37 | dbx500_add_i2c(2, U8500_I2C2_BASE, IRQ_DB8500_I2C2, pdata) |
| 38 | #define db8500_add_i2c3(pdata) \ |
| 39 | dbx500_add_i2c(3, U8500_I2C3_BASE, IRQ_DB8500_I2C3, pdata) |
| 40 | #define db8500_add_i2c4(pdata) \ |
| 41 | dbx500_add_i2c(4, U8500_I2C4_BASE, IRQ_DB8500_I2C4, pdata) |
| 42 | |
| 43 | #define db8500_add_msp0_i2s(pdata) \ |
| 44 | dbx500_add_msp_i2s(0, U8500_MSP0_BASE, IRQ_DB8500_MSP0, pdata) |
| 45 | #define db8500_add_msp1_i2s(pdata) \ |
| 46 | dbx500_add_msp_i2s(1, U8500_MSP1_BASE, IRQ_DB8500_MSP1, pdata) |
| 47 | #define db8500_add_msp2_i2s(pdata) \ |
| 48 | dbx500_add_msp_i2s(2, U8500_MSP2_BASE, IRQ_DB8500_MSP2, pdata) |
| 49 | #define db8500_add_msp3_i2s(pdata) \ |
| 50 | dbx500_add_msp_i2s(3, U8500_MSP3_BASE, IRQ_DB8500_MSP1, pdata) |
| 51 | |
| 52 | #define db8500_add_msp0_spi(pdata) \ |
| 53 | dbx500_add_msp_spi("msp0", U8500_MSP0_BASE, IRQ_DB8500_MSP0, pdata) |
| 54 | #define db8500_add_msp1_spi(pdata) \ |
| 55 | dbx500_add_msp_spi("msp1", U8500_MSP1_BASE, IRQ_DB8500_MSP1, pdata) |
| 56 | #define db8500_add_msp2_spi(pdata) \ |
| 57 | dbx500_add_msp_spi("msp2", U8500_MSP2_BASE, IRQ_DB8500_MSP2, pdata) |
| 58 | #define db8500_add_msp3_spi(pdata) \ |
| 59 | dbx500_add_msp_spi("msp3", U8500_MSP3_BASE, IRQ_DB8500_MSP1, pdata) |
| 60 | |
| 61 | #define db8500_add_rtc() \ |
| 62 | dbx500_add_rtc(U8500_RTC_BASE, IRQ_DB8500_RTC); |
| 63 | |
| 64 | #define db8500_add_sdi0(pdata) \ |
| 65 | dbx500_add_sdi("sdi0", U8500_SDI0_BASE, IRQ_DB8500_SDMMC0, pdata) |
| 66 | #define db8500_add_sdi1(pdata) \ |
| 67 | dbx500_add_sdi("sdi1", U8500_SDI1_BASE, IRQ_DB8500_SDMMC1, pdata) |
| 68 | #define db8500_add_sdi2(pdata) \ |
| 69 | dbx500_add_sdi("sdi2", U8500_SDI2_BASE, IRQ_DB8500_SDMMC2, pdata) |
| 70 | #define db8500_add_sdi3(pdata) \ |
| 71 | dbx500_add_sdi("sdi3", U8500_SDI3_BASE, IRQ_DB8500_SDMMC3, pdata) |
| 72 | #define db8500_add_sdi4(pdata) \ |
| 73 | dbx500_add_sdi("sdi4", U8500_SDI4_BASE, IRQ_DB8500_SDMMC4, pdata) |
| 74 | #define db8500_add_sdi5(pdata) \ |
| 75 | dbx500_add_sdi("sdi5", U8500_SDI5_BASE, IRQ_DB8500_SDMMC5, pdata) |
| 76 | |
| 77 | #define db8500_add_ssp0(pdata) \ |
| 78 | db8500_add_ssp("ssp0", U8500_SSP0_BASE, IRQ_DB8500_SSP0, pdata) |
| 79 | #define db8500_add_ssp1(pdata) \ |
| 80 | db8500_add_ssp("ssp1", U8500_SSP1_BASE, IRQ_DB8500_SSP1, pdata) |
| 81 | |
| 82 | #define db8500_add_spi0(pdata) \ |
| 83 | dbx500_add_spi("spi0", U8500_SPI0_BASE, IRQ_DB8500_SPI0, pdata) |
| 84 | #define db8500_add_spi1(pdata) \ |
| 85 | dbx500_add_spi("spi1", U8500_SPI1_BASE, IRQ_DB8500_SPI1, pdata) |
| 86 | #define db8500_add_spi2(pdata) \ |
| 87 | dbx500_add_spi("spi2", U8500_SPI2_BASE, IRQ_DB8500_SPI2, pdata) |
| 88 | #define db8500_add_spi3(pdata) \ |
| 89 | dbx500_add_spi("spi3", U8500_SPI3_BASE, IRQ_DB8500_SPI3, pdata) |
| 90 | |
| 91 | #define db8500_add_uart0() \ |
| 92 | dbx500_add_uart("uart0", U8500_UART0_BASE, IRQ_DB8500_UART0) |
| 93 | #define db8500_add_uart1() \ |
| 94 | dbx500_add_uart("uart1", U8500_UART1_BASE, IRQ_DB8500_UART1) |
| 95 | #define db8500_add_uart2() \ |
| 96 | dbx500_add_uart("uart2", U8500_UART2_BASE, IRQ_DB8500_UART2) |
| 97 | |
| 98 | #endif |