Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^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 */