^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) #ifndef __ASM_MACH_PXA910_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) #define __ASM_MACH_PXA910_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) extern void pxa910_timer_init(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) extern void __init icu_init_irq(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) extern void __init pxa910_init_irq(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #include <linux/i2c.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) #include <linux/platform_data/i2c-pxa.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #include <linux/platform_data/mtd-nand-pxa3xx.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #include <video/mmp_disp.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) #include "devices.h"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) extern struct pxa_device_desc pxa910_device_uart1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) extern struct pxa_device_desc pxa910_device_uart2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) extern struct pxa_device_desc pxa910_device_twsi0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) extern struct pxa_device_desc pxa910_device_twsi1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) extern struct pxa_device_desc pxa910_device_pwm1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) extern struct pxa_device_desc pxa910_device_pwm2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) extern struct pxa_device_desc pxa910_device_pwm3;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) extern struct pxa_device_desc pxa910_device_pwm4;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) extern struct pxa_device_desc pxa910_device_nand;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) extern struct platform_device pxa168_device_usb_phy;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) extern struct platform_device pxa168_device_u2o;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) extern struct platform_device pxa168_device_u2ootg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) extern struct platform_device pxa168_device_u2oehci;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) extern struct pxa_device_desc pxa910_device_disp;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) extern struct pxa_device_desc pxa910_device_fb;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) extern struct pxa_device_desc pxa910_device_panel;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) extern struct platform_device pxa910_device_gpio;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) extern struct platform_device pxa910_device_rtc;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) static inline int pxa910_add_uart(int id)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) struct pxa_device_desc *d = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) switch (id) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) case 1: d = &pxa910_device_uart1; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) case 2: d = &pxa910_device_uart2; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) if (d == NULL)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) return -EINVAL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) return pxa_register_device(d, NULL, 0);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) static inline int pxa910_add_twsi(int id, struct i2c_pxa_platform_data *data,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) struct i2c_board_info *info, unsigned size)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) struct pxa_device_desc *d = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) int ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) switch (id) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) case 0: d = &pxa910_device_twsi0; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) case 1: d = &pxa910_device_twsi1; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) default:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) return -EINVAL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) ret = i2c_register_board_info(id, info, size);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) if (ret)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) return pxa_register_device(d, data, sizeof(*data));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) static inline int pxa910_add_pwm(int id)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) struct pxa_device_desc *d = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74) switch (id) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) case 1: d = &pxa910_device_pwm1; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) case 2: d = &pxa910_device_pwm2; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77) case 3: d = &pxa910_device_pwm3; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) case 4: d = &pxa910_device_pwm4; break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) default:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80) return -EINVAL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83) return pxa_register_device(d, NULL, 0);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86) static inline int pxa910_add_nand(struct pxa3xx_nand_platform_data *info)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88) return pxa_register_device(&pxa910_device_nand, info, sizeof(*info));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90) #endif /* __ASM_MACH_PXA910_H */