/* * 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, resource_size_t base) { struct resource res[] = { DEFINE_RES_MEM(base, SZ_8K), }; struct platform_device_info pdevinfo = { .parent = parent, .name = name, .id = -1, .res = res, .num_res = ARRAY_SIZE(res), }; platform_device_register_full(&pdevinfo); } #endif