/* * Copyright (C) ST-Ericsson SA 2010 * * Author: Rabin Vincent for ST-Ericsson * License terms: GNU General Public License (GPL), version 2. */ #ifndef __DEVICES_COMMON_H #define __DEVICES_COMMON_H #include #include #include #include #include extern struct amba_device * dbx500_add_amba_device(struct device *parent, const char *name, resource_size_t base, int irq, void *pdata, unsigned int periphid); extern struct platform_device * dbx500_add_platform_device_noirq(const char *name, int id, resource_size_t base, void *pdata); 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 dbx500_add_amba_device(parent, name, base, irq, 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 dbx500_add_amba_device(parent, name, base, irq, 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 dbx500_add_amba_device(parent, name, base, irq, 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 dbx500_add_amba_device(parent, name, base, irq, pdata, 0); } struct nmk_i2c_controller; static inline struct platform_device * dbx500_add_i2c(struct device *parent, int id, resource_size_t base, int irq, struct nmk_i2c_controller *data) { struct resource res[] = { DEFINE_RES_MEM(base, SZ_4K), DEFINE_RES_IRQ(irq), }; struct platform_device_info pdevinfo = { .parent = parent, .name = "nmk-i2c", .id = id, .res = res, .num_res = ARRAY_SIZE(res), .data = data, .size_data = sizeof(*data), .dma_mask = DMA_BIT_MASK(32), }; return platform_device_register_full(&pdevinfo); } static inline struct amba_device * dbx500_add_rtc(struct device *parent, resource_size_t base, int irq) { return dbx500_add_amba_device(parent, "rtc-pl031", base, irq, 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); #endif