| /* |
| * Copyright (C) ST-Ericsson SA 2010 |
| * |
| * Author: Rabin Vincent <rabin.vincent@stericsson.com> for ST-Ericsson |
| * License terms: GNU General Public License (GPL), version 2. |
| */ |
| |
| #ifndef __DEVICES_COMMON_H |
| #define __DEVICES_COMMON_H |
| |
| #include <linux/platform_device.h> |
| #include <linux/dma-mapping.h> |
| #include <linux/sys_soc.h> |
| #include <linux/amba/bus.h> |
| #include <linux/platform_data/i2c-nomadik.h> |
| #include <linux/platform_data/crypto-ux500.h> |
| |
| struct spi_master_cntlr; |
| |
| static inline struct amba_device * |
| dbx500_add_msp_spi(struct device *parent, const char *name, |
| resource_size_t base, int irq, |
| struct spi_master_cntlr *pdata) |
| { |
| return amba_ahb_device_add(parent, name, base, SZ_4K, irq, 0, |
| pdata, 0); |
| } |
| |
| static inline struct amba_device * |
| dbx500_add_spi(struct device *parent, const char *name, resource_size_t base, |
| int irq, struct spi_master_cntlr *pdata, |
| u32 periphid) |
| { |
| return amba_ahb_device_add(parent, name, base, SZ_4K, irq, 0, |
| pdata, periphid); |
| } |
| |
| struct mmci_platform_data; |
| |
| static inline struct amba_device * |
| dbx500_add_sdi(struct device *parent, const char *name, resource_size_t base, |
| int irq, struct mmci_platform_data *pdata, u32 periphid) |
| { |
| return amba_ahb_device_add(parent, name, base, SZ_4K, irq, 0, |
| pdata, periphid); |
| } |
| |
| struct amba_pl011_data; |
| |
| static inline struct amba_device * |
| dbx500_add_uart(struct device *parent, const char *name, resource_size_t base, |
| int irq, struct amba_pl011_data *pdata) |
| { |
| return amba_ahb_device_add(parent, name, base, SZ_4K, irq, 0, pdata, 0); |
| } |
| |
| struct nmk_i2c_controller; |
| |
| static inline struct amba_device * |
| dbx500_add_i2c(struct device *parent, int id, resource_size_t base, int irq, |
| struct nmk_i2c_controller *data) |
| { |
| /* Conjure a name similar to what the platform device used to have */ |
| char name[16]; |
| |
| snprintf(name, sizeof(name), "nmk-i2c.%d", id); |
| return amba_apb_device_add(parent, name, base, SZ_4K, irq, 0, data, 0); |
| } |
| |
| static inline struct amba_device * |
| dbx500_add_rtc(struct device *parent, resource_size_t base, int irq) |
| { |
| return amba_apb_device_add(parent, "rtc-pl031", base, SZ_4K, irq, |
| 0, NULL, 0); |
| } |
| |
| struct cryp_platform_data; |
| |
| static inline struct platform_device * |
| dbx500_add_cryp1(struct device *parent, int id, resource_size_t base, int irq, |
| struct cryp_platform_data *pdata) |
| { |
| struct resource res[] = { |
| DEFINE_RES_MEM(base, SZ_4K), |
| DEFINE_RES_IRQ(irq), |
| }; |
| |
| struct platform_device_info pdevinfo = { |
| .parent = parent, |
| .name = "cryp1", |
| .id = id, |
| .res = res, |
| .num_res = ARRAY_SIZE(res), |
| .data = pdata, |
| .size_data = sizeof(*pdata), |
| .dma_mask = DMA_BIT_MASK(32), |
| }; |
| |
| return platform_device_register_full(&pdevinfo); |
| } |
| |
| struct hash_platform_data; |
| |
| static inline struct platform_device * |
| dbx500_add_hash1(struct device *parent, int id, resource_size_t base, |
| struct hash_platform_data *pdata) |
| { |
| struct resource res[] = { |
| DEFINE_RES_MEM(base, SZ_4K), |
| }; |
| |
| struct platform_device_info pdevinfo = { |
| .parent = parent, |
| .name = "hash1", |
| .id = id, |
| .res = res, |
| .num_res = ARRAY_SIZE(res), |
| .data = pdata, |
| .size_data = sizeof(*pdata), |
| .dma_mask = DMA_BIT_MASK(32), |
| }; |
| |
| return platform_device_register_full(&pdevinfo); |
| } |
| |
| struct nmk_gpio_platform_data; |
| |
| void dbx500_add_gpios(struct device *parent, resource_size_t *base, int num, |
| int irq, struct nmk_gpio_platform_data *pdata); |
| |
| static inline void |
| dbx500_add_pinctrl(struct device *parent, const char *name) |
| { |
| struct platform_device_info pdevinfo = { |
| .parent = parent, |
| .name = name, |
| .id = -1, |
| }; |
| |
| platform_device_register_full(&pdevinfo); |
| } |
| |
| #endif |