blob: 37632d964d50551fb1d7d692e39ec92be817d571 [file] [log] [blame]
Eric Miao49cbe782009-01-20 14:15:18 +08001#ifndef __ASM_MACH_PXA168_H
2#define __ASM_MACH_PXA168_H
3
Eric Miao27287012010-07-15 22:22:33 +08004struct sys_timer;
5
6extern struct sys_timer pxa168_timer;
7extern void __init pxa168_init_irq(void);
Russell King9854a382011-11-05 15:40:09 +00008extern void pxa168_restart(char, const char *);
Mark F. Brownab5739a2010-09-03 18:28:10 -04009extern void pxa168_clear_keypad_wakeup(void);
Eric Miao27287012010-07-15 22:22:33 +080010
Eric Miao1a779202009-04-13 15:34:54 +080011#include <linux/i2c.h>
Sebastian Andrzej Siewiorb4593962011-02-23 12:38:16 +010012#include <linux/i2c/pxa-i2c.h>
Eric Miao49cbe782009-01-20 14:15:18 +080013#include <mach/devices.h>
Arnd Bergmann293b2da2012-08-24 15:16:48 +020014#include <linux/platform_data/mtd-nand-pxa3xx.h>
Mark F. Brown58cf68b2010-08-25 23:51:54 -040015#include <video/pxa168fb.h>
Arnd Bergmann293b2da2012-08-24 15:16:48 +020016#include <linux/platform_data/keypad-pxa27x.h>
Mark F. Brownab5739a2010-09-03 18:28:10 -040017#include <mach/cputype.h>
Tanmay Upadhyay80def0d2011-05-02 11:29:59 +053018#include <linux/pxa168_eth.h>
Neil Zhang161105b2012-05-03 14:19:15 +080019#include <linux/platform_data/mv_usb.h>
Eric Miao49cbe782009-01-20 14:15:18 +080020
21extern struct pxa_device_desc pxa168_device_uart1;
22extern struct pxa_device_desc pxa168_device_uart2;
Tanmay Upadhyay26407f82011-05-02 11:29:58 +053023extern struct pxa_device_desc pxa168_device_uart3;
Eric Miao1a779202009-04-13 15:34:54 +080024extern struct pxa_device_desc pxa168_device_twsi0;
25extern struct pxa_device_desc pxa168_device_twsi1;
Eric Miaoa27ba762009-04-13 18:29:52 +080026extern struct pxa_device_desc pxa168_device_pwm1;
27extern struct pxa_device_desc pxa168_device_pwm2;
28extern struct pxa_device_desc pxa168_device_pwm3;
29extern struct pxa_device_desc pxa168_device_pwm4;
Haojian Zhuang7e499222010-03-19 11:53:17 -040030extern struct pxa_device_desc pxa168_device_ssp1;
31extern struct pxa_device_desc pxa168_device_ssp2;
32extern struct pxa_device_desc pxa168_device_ssp3;
33extern struct pxa_device_desc pxa168_device_ssp4;
34extern struct pxa_device_desc pxa168_device_ssp5;
Haojian Zhuanga0f266c2009-10-13 15:24:55 +080035extern struct pxa_device_desc pxa168_device_nand;
Mark F. Brown58cf68b2010-08-25 23:51:54 -040036extern struct pxa_device_desc pxa168_device_fb;
Mark F. Brown6d109462010-09-03 18:28:07 -040037extern struct pxa_device_desc pxa168_device_keypad;
Tanmay Upadhyay80def0d2011-05-02 11:29:59 +053038extern struct pxa_device_desc pxa168_device_eth;
Eric Miao49cbe782009-01-20 14:15:18 +080039
Tanmay Upadhyay3abd7f62011-07-20 10:00:58 +053040/* pdata can be NULL */
Neil Zhang161105b2012-05-03 14:19:15 +080041extern int __init pxa168_add_usb_host(struct mv_usb_platform_data *pdata);
42
Tanmay Upadhyay3abd7f62011-07-20 10:00:58 +053043
Haojian Zhuang157d2642011-10-17 20:37:52 +080044extern struct platform_device pxa168_device_gpio;
45
Eric Miao49cbe782009-01-20 14:15:18 +080046static inline int pxa168_add_uart(int id)
47{
48 struct pxa_device_desc *d = NULL;
49
50 switch (id) {
51 case 1: d = &pxa168_device_uart1; break;
52 case 2: d = &pxa168_device_uart2; break;
Tanmay Upadhyay26407f82011-05-02 11:29:58 +053053 case 3: d = &pxa168_device_uart3; break;
Eric Miao49cbe782009-01-20 14:15:18 +080054 }
55
56 if (d == NULL)
57 return -EINVAL;
58
59 return pxa_register_device(d, NULL, 0);
60}
Eric Miao1a779202009-04-13 15:34:54 +080061
62static inline int pxa168_add_twsi(int id, struct i2c_pxa_platform_data *data,
63 struct i2c_board_info *info, unsigned size)
64{
65 struct pxa_device_desc *d = NULL;
66 int ret;
67
68 switch (id) {
69 case 0: d = &pxa168_device_twsi0; break;
70 case 1: d = &pxa168_device_twsi1; break;
71 default:
72 return -EINVAL;
73 }
74
75 ret = i2c_register_board_info(id, info, size);
76 if (ret)
77 return ret;
78
79 return pxa_register_device(d, data, sizeof(*data));
80}
Eric Miaoa27ba762009-04-13 18:29:52 +080081
82static inline int pxa168_add_pwm(int id)
83{
84 struct pxa_device_desc *d = NULL;
85
86 switch (id) {
87 case 1: d = &pxa168_device_pwm1; break;
88 case 2: d = &pxa168_device_pwm2; break;
89 case 3: d = &pxa168_device_pwm3; break;
90 case 4: d = &pxa168_device_pwm4; break;
91 default:
92 return -EINVAL;
93 }
94
95 return pxa_register_device(d, NULL, 0);
96}
Haojian Zhuanga0f266c2009-10-13 15:24:55 +080097
Haojian Zhuang7e499222010-03-19 11:53:17 -040098static inline int pxa168_add_ssp(int id)
99{
100 struct pxa_device_desc *d = NULL;
101
102 switch (id) {
103 case 1: d = &pxa168_device_ssp1; break;
104 case 2: d = &pxa168_device_ssp2; break;
105 case 3: d = &pxa168_device_ssp3; break;
106 case 4: d = &pxa168_device_ssp4; break;
107 case 5: d = &pxa168_device_ssp5; break;
108 default:
109 return -EINVAL;
110 }
111 return pxa_register_device(d, NULL, 0);
112}
113
Haojian Zhuanga0f266c2009-10-13 15:24:55 +0800114static inline int pxa168_add_nand(struct pxa3xx_nand_platform_data *info)
115{
116 return pxa_register_device(&pxa168_device_nand, info, sizeof(*info));
117}
Mark F. Brown58cf68b2010-08-25 23:51:54 -0400118
119static inline int pxa168_add_fb(struct pxa168fb_mach_info *mi)
120{
121 return pxa_register_device(&pxa168_device_fb, mi, sizeof(*mi));
122}
123
Mark F. Brown6d109462010-09-03 18:28:07 -0400124static inline int pxa168_add_keypad(struct pxa27x_keypad_platform_data *data)
125{
Mark F. Brownab5739a2010-09-03 18:28:10 -0400126 if (cpu_is_pxa168())
127 data->clear_wakeup_event = pxa168_clear_keypad_wakeup;
128
Mark F. Brown6d109462010-09-03 18:28:07 -0400129 return pxa_register_device(&pxa168_device_keypad, data, sizeof(*data));
130}
131
Tanmay Upadhyay80def0d2011-05-02 11:29:59 +0530132static inline int pxa168_add_eth(struct pxa168_eth_platform_data *data)
133{
134 return pxa_register_device(&pxa168_device_eth, data, sizeof(*data));
135}
Eric Miao49cbe782009-01-20 14:15:18 +0800136#endif /* __ASM_MACH_PXA168_H */