diff options
author | Mike Rapoport <mike@compulab.co.il> | 2009-05-12 09:31:13 -0400 |
---|---|---|
committer | Eric Miao <eric.y.miao@gmail.com> | 2009-06-04 22:50:23 -0400 |
commit | 76e3fc36eb3d78997e7f4dcdc01cc38dc3178201 (patch) | |
tree | d4ccdf2c74aa69a975c5370436dda084f7431f68 /arch/arm/mach-pxa/em-x270.c | |
parent | 1ce2c51e6d594d19126f51bba88aa9f57eb7cea6 (diff) |
[ARM] pxa/em-x270: add exeda GPIO extender and update GPIO mappings
Signed-off-by: Mike Rapoport <mike@compulab.co.il>
Signed-off-by: Eric Miao <eric.miao@marvell.com>
Diffstat (limited to 'arch/arm/mach-pxa/em-x270.c')
-rw-r--r-- | arch/arm/mach-pxa/em-x270.c | 64 |
1 files changed, 46 insertions, 18 deletions
diff --git a/arch/arm/mach-pxa/em-x270.c b/arch/arm/mach-pxa/em-x270.c index 3503f523070b..e2f9834e2daa 100644 --- a/arch/arm/mach-pxa/em-x270.c +++ b/arch/arm/mach-pxa/em-x270.c | |||
@@ -28,6 +28,8 @@ | |||
28 | #include <linux/spi/libertas_spi.h> | 28 | #include <linux/spi/libertas_spi.h> |
29 | #include <linux/power_supply.h> | 29 | #include <linux/power_supply.h> |
30 | #include <linux/apm-emulation.h> | 30 | #include <linux/apm-emulation.h> |
31 | #include <linux/i2c.h> | ||
32 | #include <linux/i2c/pca953x.h> | ||
31 | 33 | ||
32 | #include <media/soc_camera.h> | 34 | #include <media/soc_camera.h> |
33 | 35 | ||
@@ -52,15 +54,18 @@ | |||
52 | #define GPIO13_MMC_CD (13) | 54 | #define GPIO13_MMC_CD (13) |
53 | #define GPIO95_MMC_WP (95) | 55 | #define GPIO95_MMC_WP (95) |
54 | #define GPIO56_NAND_RB (56) | 56 | #define GPIO56_NAND_RB (56) |
57 | #define GPIO93_CAM_RESET (93) | ||
55 | 58 | ||
56 | /* eXeda specific GPIOs */ | 59 | /* eXeda specific GPIOs */ |
57 | #define GPIO114_MMC_CD (114) | 60 | #define GPIO114_MMC_CD (114) |
58 | #define GPIO20_NAND_RB (20) | 61 | #define GPIO20_NAND_RB (20) |
59 | #define GPIO38_SD_PWEN (38) | 62 | #define GPIO38_SD_PWEN (38) |
63 | #define GPIO37_WLAN_RST (37) | ||
64 | #define GPIO95_TOUCHPAD_INT (95) | ||
65 | #define GPIO130_CAM_RESET (130) | ||
60 | 66 | ||
61 | /* common GPIOs */ | 67 | /* common GPIOs */ |
62 | #define GPIO11_NAND_CS (11) | 68 | #define GPIO11_NAND_CS (11) |
63 | #define GPIO93_CAM_RESET (93) | ||
64 | #define GPIO41_ETHIRQ (41) | 69 | #define GPIO41_ETHIRQ (41) |
65 | #define EM_X270_ETHIRQ IRQ_GPIO(GPIO41_ETHIRQ) | 70 | #define EM_X270_ETHIRQ IRQ_GPIO(GPIO41_ETHIRQ) |
66 | #define GPIO115_WLAN_PWEN (115) | 71 | #define GPIO115_WLAN_PWEN (115) |
@@ -69,6 +74,7 @@ | |||
69 | static int mmc_cd; | 74 | static int mmc_cd; |
70 | static int nand_rb; | 75 | static int nand_rb; |
71 | static int dm9000_flags; | 76 | static int dm9000_flags; |
77 | static int cam_reset; | ||
72 | 78 | ||
73 | static unsigned long common_pin_config[] = { | 79 | static unsigned long common_pin_config[] = { |
74 | /* AC'97 */ | 80 | /* AC'97 */ |
@@ -180,7 +186,6 @@ static unsigned long common_pin_config[] = { | |||
180 | 186 | ||
181 | /* power controls */ | 187 | /* power controls */ |
182 | GPIO20_GPIO | MFP_LPM_DRIVE_LOW, /* GPRS_PWEN */ | 188 | GPIO20_GPIO | MFP_LPM_DRIVE_LOW, /* GPRS_PWEN */ |
183 | GPIO93_GPIO | MFP_LPM_DRIVE_LOW, /* Camera reset */ | ||
184 | GPIO115_GPIO | MFP_LPM_DRIVE_LOW, /* WLAN_PWEN */ | 189 | GPIO115_GPIO | MFP_LPM_DRIVE_LOW, /* WLAN_PWEN */ |
185 | 190 | ||
186 | /* NAND controls */ | 191 | /* NAND controls */ |
@@ -191,14 +196,16 @@ static unsigned long common_pin_config[] = { | |||
191 | }; | 196 | }; |
192 | 197 | ||
193 | static unsigned long em_x270_pin_config[] = { | 198 | static unsigned long em_x270_pin_config[] = { |
194 | GPIO13_GPIO, /* MMC card detect */ | 199 | GPIO13_GPIO, /* MMC card detect */ |
195 | GPIO56_GPIO, /* NAND Ready/Busy */ | 200 | GPIO56_GPIO, /* NAND Ready/Busy */ |
196 | GPIO95_GPIO, /* MMC Write protect */ | 201 | GPIO93_GPIO | MFP_LPM_DRIVE_LOW, /* Camera reset */ |
202 | GPIO95_GPIO, /* MMC Write protect */ | ||
197 | }; | 203 | }; |
198 | 204 | ||
199 | static unsigned long exeda_pin_config[] = { | 205 | static unsigned long exeda_pin_config[] = { |
200 | GPIO20_GPIO, /* NAND Ready/Busy */ | 206 | GPIO20_GPIO, /* NAND Ready/Busy */ |
201 | GPIO38_GPIO | MFP_LPM_DRIVE_LOW, /* SD slot power */ | 207 | GPIO38_GPIO | MFP_LPM_DRIVE_LOW, /* SD slot power */ |
208 | GPIO95_GPIO, /* touchpad IRQ */ | ||
202 | GPIO114_GPIO, /* MMC card detect */ | 209 | GPIO114_GPIO, /* MMC card detect */ |
203 | }; | 210 | }; |
204 | 211 | ||
@@ -863,26 +870,26 @@ static int em_x270_sensor_init(struct device *dev) | |||
863 | { | 870 | { |
864 | int ret; | 871 | int ret; |
865 | 872 | ||
866 | ret = gpio_request(GPIO93_CAM_RESET, "camera reset"); | 873 | ret = gpio_request(cam_reset, "camera reset"); |
867 | if (ret) | 874 | if (ret) |
868 | return ret; | 875 | return ret; |
869 | 876 | ||
870 | gpio_direction_output(GPIO93_CAM_RESET, 0); | 877 | gpio_direction_output(cam_reset, 0); |
871 | 878 | ||
872 | em_x270_camera_ldo = regulator_get(NULL, "vcc cam"); | 879 | em_x270_camera_ldo = regulator_get(NULL, "vcc cam"); |
873 | if (em_x270_camera_ldo == NULL) { | 880 | if (em_x270_camera_ldo == NULL) { |
874 | gpio_free(GPIO93_CAM_RESET); | 881 | gpio_free(cam_reset); |
875 | return -ENODEV; | 882 | return -ENODEV; |
876 | } | 883 | } |
877 | 884 | ||
878 | ret = regulator_enable(em_x270_camera_ldo); | 885 | ret = regulator_enable(em_x270_camera_ldo); |
879 | if (ret) { | 886 | if (ret) { |
880 | regulator_put(em_x270_camera_ldo); | 887 | regulator_put(em_x270_camera_ldo); |
881 | gpio_free(GPIO93_CAM_RESET); | 888 | gpio_free(cam_reset); |
882 | return ret; | 889 | return ret; |
883 | } | 890 | } |
884 | 891 | ||
885 | gpio_set_value(GPIO93_CAM_RESET, 1); | 892 | gpio_set_value(cam_reset, 1); |
886 | 893 | ||
887 | return 0; | 894 | return 0; |
888 | } | 895 | } |
@@ -902,7 +909,7 @@ static int em_x270_sensor_power(struct device *dev, int on) | |||
902 | if (on == is_on) | 909 | if (on == is_on) |
903 | return 0; | 910 | return 0; |
904 | 911 | ||
905 | gpio_set_value(GPIO93_CAM_RESET, !on); | 912 | gpio_set_value(cam_reset, !on); |
906 | 913 | ||
907 | if (on) | 914 | if (on) |
908 | ret = regulator_enable(em_x270_camera_ldo); | 915 | ret = regulator_enable(em_x270_camera_ldo); |
@@ -912,7 +919,7 @@ static int em_x270_sensor_power(struct device *dev, int on) | |||
912 | if (ret) | 919 | if (ret) |
913 | return ret; | 920 | return ret; |
914 | 921 | ||
915 | gpio_set_value(GPIO93_CAM_RESET, on); | 922 | gpio_set_value(cam_reset, on); |
916 | 923 | ||
917 | return 0; | 924 | return 0; |
918 | } | 925 | } |
@@ -929,13 +936,8 @@ static struct i2c_board_info em_x270_i2c_cam_info[] = { | |||
929 | }, | 936 | }, |
930 | }; | 937 | }; |
931 | 938 | ||
932 | static struct i2c_pxa_platform_data em_x270_i2c_info = { | ||
933 | .fast_mode = 1, | ||
934 | }; | ||
935 | |||
936 | static void __init em_x270_init_camera(void) | 939 | static void __init em_x270_init_camera(void) |
937 | { | 940 | { |
938 | pxa_set_i2c_info(&em_x270_i2c_info); | ||
939 | i2c_register_board_info(0, ARRAY_AND_SIZE(em_x270_i2c_cam_info)); | 941 | i2c_register_board_info(0, ARRAY_AND_SIZE(em_x270_i2c_cam_info)); |
940 | pxa_set_camera_info(&em_x270_camera_platform_data); | 942 | pxa_set_camera_info(&em_x270_camera_platform_data); |
941 | } | 943 | } |
@@ -1069,6 +1071,29 @@ static void __init em_x270_init_da9030(void) | |||
1069 | i2c_register_board_info(1, &em_x270_i2c_pmic_info, 1); | 1071 | i2c_register_board_info(1, &em_x270_i2c_pmic_info, 1); |
1070 | } | 1072 | } |
1071 | 1073 | ||
1074 | static struct pca953x_platform_data exeda_gpio_ext_pdata = { | ||
1075 | .gpio_base = 128, | ||
1076 | }; | ||
1077 | |||
1078 | static struct i2c_board_info exeda_i2c_info[] = { | ||
1079 | { | ||
1080 | I2C_BOARD_INFO("pca9555", 0x21), | ||
1081 | .platform_data = &exeda_gpio_ext_pdata, | ||
1082 | }, | ||
1083 | }; | ||
1084 | |||
1085 | static struct i2c_pxa_platform_data em_x270_i2c_info = { | ||
1086 | .fast_mode = 1, | ||
1087 | }; | ||
1088 | |||
1089 | static void __init em_x270_init_i2c(void) | ||
1090 | { | ||
1091 | pxa_set_i2c_info(&em_x270_i2c_info); | ||
1092 | |||
1093 | if (machine_is_exeda()) | ||
1094 | i2c_register_board_info(0, ARRAY_AND_SIZE(exeda_i2c_info)); | ||
1095 | } | ||
1096 | |||
1072 | static void __init em_x270_module_init(void) | 1097 | static void __init em_x270_module_init(void) |
1073 | { | 1098 | { |
1074 | pr_info("%s\n", __func__); | 1099 | pr_info("%s\n", __func__); |
@@ -1077,6 +1102,7 @@ static void __init em_x270_module_init(void) | |||
1077 | mmc_cd = GPIO13_MMC_CD; | 1102 | mmc_cd = GPIO13_MMC_CD; |
1078 | nand_rb = GPIO56_NAND_RB; | 1103 | nand_rb = GPIO56_NAND_RB; |
1079 | dm9000_flags = DM9000_PLATF_32BITONLY; | 1104 | dm9000_flags = DM9000_PLATF_32BITONLY; |
1105 | cam_reset = GPIO93_CAM_RESET; | ||
1080 | } | 1106 | } |
1081 | 1107 | ||
1082 | static void __init em_x270_exeda_init(void) | 1108 | static void __init em_x270_exeda_init(void) |
@@ -1087,6 +1113,7 @@ static void __init em_x270_exeda_init(void) | |||
1087 | mmc_cd = GPIO114_MMC_CD; | 1113 | mmc_cd = GPIO114_MMC_CD; |
1088 | nand_rb = GPIO20_NAND_RB; | 1114 | nand_rb = GPIO20_NAND_RB; |
1089 | dm9000_flags = DM9000_PLATF_16BITONLY; | 1115 | dm9000_flags = DM9000_PLATF_16BITONLY; |
1116 | cam_reset = GPIO130_CAM_RESET; | ||
1090 | } | 1117 | } |
1091 | 1118 | ||
1092 | static void __init em_x270_init(void) | 1119 | static void __init em_x270_init(void) |
@@ -1111,8 +1138,9 @@ static void __init em_x270_init(void) | |||
1111 | em_x270_init_keypad(); | 1138 | em_x270_init_keypad(); |
1112 | em_x270_init_gpio_keys(); | 1139 | em_x270_init_gpio_keys(); |
1113 | em_x270_init_ac97(); | 1140 | em_x270_init_ac97(); |
1114 | em_x270_init_camera(); | ||
1115 | em_x270_init_spi(); | 1141 | em_x270_init_spi(); |
1142 | em_x270_init_i2c(); | ||
1143 | em_x270_init_camera(); | ||
1116 | } | 1144 | } |
1117 | 1145 | ||
1118 | MACHINE_START(EM_X270, "Compulab EM-X270") | 1146 | MACHINE_START(EM_X270, "Compulab EM-X270") |