aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-pxa/em-x270.c
diff options
context:
space:
mode:
authorMike Rapoport <mike@compulab.co.il>2009-02-02 01:57:55 -0500
committerEric Miao <eric.miao@marvell.com>2009-02-02 04:40:17 -0500
commit7f14a78713e0b4517f785402accaccca22df93c1 (patch)
tree09f654c9de9222e2a33d1bfcfe6a0ca7b02177ae /arch/arm/mach-pxa/em-x270.c
parent4a697e83cf8b20b35942c93b873fe17e54d7e6c5 (diff)
[ARM] pxa: add eXeda platform support
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.c149
1 files changed, 128 insertions, 21 deletions
diff --git a/arch/arm/mach-pxa/em-x270.c b/arch/arm/mach-pxa/em-x270.c
index ea099183773d..9f15a7c9cc5f 100644
--- a/arch/arm/mach-pxa/em-x270.c
+++ b/arch/arm/mach-pxa/em-x270.c
@@ -11,6 +11,7 @@
11 11
12#include <linux/irq.h> 12#include <linux/irq.h>
13#include <linux/platform_device.h> 13#include <linux/platform_device.h>
14#include <linux/delay.h>
14 15
15#include <linux/dm9000.h> 16#include <linux/dm9000.h>
16#include <linux/rtc-v3020.h> 17#include <linux/rtc-v3020.h>
@@ -47,18 +48,21 @@
47#include "generic.h" 48#include "generic.h"
48#include "devices.h" 49#include "devices.h"
49 50
50/* GPIO IRQ usage */ 51/* EM-X270 specific GPIOs */
51#define GPIO41_ETHIRQ (41)
52#define GPIO13_MMC_CD (13) 52#define GPIO13_MMC_CD (13)
53#define EM_X270_ETHIRQ IRQ_GPIO(GPIO41_ETHIRQ) 53#define GPIO95_MMC_WP (95)
54#define GPIO56_NAND_RB (56)
54 55
55/* NAND control GPIOs */ 56/* eXeda specific GPIOs */
56#define GPIO11_NAND_CS (11) 57#define GPIO114_MMC_CD (114)
57#define GPIO56_NAND_RB (56) 58#define GPIO20_NAND_RB (20)
59#define GPIO38_SD_PWEN (38)
58 60
59/* Miscelaneous GPIOs */ 61/* common GPIOs */
62#define GPIO11_NAND_CS (11)
60#define GPIO93_CAM_RESET (93) 63#define GPIO93_CAM_RESET (93)
61#define GPIO95_MMC_WP (95) 64#define GPIO41_ETHIRQ (41)
65#define EM_X270_ETHIRQ IRQ_GPIO(GPIO41_ETHIRQ)
62 66
63static int mmc_cd; 67static int mmc_cd;
64static int nand_rb; 68static int nand_rb;
@@ -190,6 +194,12 @@ static unsigned long em_x270_pin_config[] = {
190 GPIO95_GPIO, /* MMC Write protect */ 194 GPIO95_GPIO, /* MMC Write protect */
191}; 195};
192 196
197static unsigned long exeda_pin_config[] = {
198 GPIO20_GPIO, /* NAND Ready/Busy */
199 GPIO38_GPIO | MFP_LPM_DRIVE_LOW, /* SD slot power */
200 GPIO114_GPIO, /* MMC card detect */
201};
202
193#if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE) 203#if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE)
194static struct resource em_x270_dm9000_resource[] = { 204static struct resource em_x270_dm9000_resource[] = {
195 [0] = { 205 [0] = {
@@ -500,14 +510,24 @@ static int em_x270_mci_init(struct device *dev,
500 goto err_irq; 510 goto err_irq;
501 } 511 }
502 512
503 err = gpio_request(GPIO95_MMC_WP, "MMC WP"); 513 if (machine_is_em_x270()) {
504 if (err) { 514 err = gpio_request(GPIO95_MMC_WP, "MMC WP");
505 dev_err(dev, "can't request MMC write protect: %d\n", err); 515 if (err) {
506 goto err_gpio_wp; 516 dev_err(dev, "can't request MMC write protect: %d\n",
517 err);
518 goto err_gpio_wp;
519 }
520 gpio_direction_input(GPIO95_MMC_WP);
521 } else {
522 err = gpio_request(GPIO38_SD_PWEN, "sdio power");
523 if (err) {
524 dev_err(dev, "can't request MMC power control : %d\n",
525 err);
526 goto err_gpio_wp;
527 }
528 gpio_direction_output(GPIO38_SD_PWEN, 1);
507 } 529 }
508 530
509 gpio_direction_input(GPIO95_MMC_WP);
510
511 return 0; 531 return 0;
512 532
513err_gpio_wp: 533err_gpio_wp:
@@ -535,6 +555,12 @@ static void em_x270_mci_setpower(struct device *dev, unsigned int vdd)
535static void em_x270_mci_exit(struct device *dev, void *data) 555static void em_x270_mci_exit(struct device *dev, void *data)
536{ 556{
537 free_irq(gpio_to_irq(mmc_cd), data); 557 free_irq(gpio_to_irq(mmc_cd), data);
558 regulator_put(em_x270_sdio_ldo);
559
560 if (machine_is_em_x270())
561 gpio_free(GPIO95_MMC_WP);
562 else
563 gpio_free(GPIO38_SD_PWEN);
538} 564}
539 565
540static int em_x270_mci_get_ro(struct device *dev) 566static int em_x270_mci_get_ro(struct device *dev)
@@ -549,12 +575,14 @@ static struct pxamci_platform_data em_x270_mci_platform_data = {
549 MMC_VDD_30_31|MMC_VDD_31_32, 575 MMC_VDD_30_31|MMC_VDD_31_32,
550 .init = em_x270_mci_init, 576 .init = em_x270_mci_init,
551 .setpower = em_x270_mci_setpower, 577 .setpower = em_x270_mci_setpower,
552 .get_ro = em_x270_mci_get_ro,
553 .exit = em_x270_mci_exit, 578 .exit = em_x270_mci_exit,
554}; 579};
555 580
556static void __init em_x270_init_mmc(void) 581static void __init em_x270_init_mmc(void)
557{ 582{
583 if (machine_is_em_x270())
584 em_x270_mci_platform_data.get_ro = em_x270_mci_get_ro;
585
558 em_x270_mci_platform_data.detect_delay = msecs_to_jiffies(250); 586 em_x270_mci_platform_data.detect_delay = msecs_to_jiffies(250);
559 pxa_set_mci_info(&em_x270_mci_platform_data); 587 pxa_set_mci_info(&em_x270_mci_platform_data);
560} 588}
@@ -651,23 +679,76 @@ static inline void em_x270_init_ac97(void) {}
651#endif 679#endif
652 680
653#if defined(CONFIG_KEYBOARD_PXA27x) || defined(CONFIG_KEYBOARD_PXA27x_MODULE) 681#if defined(CONFIG_KEYBOARD_PXA27x) || defined(CONFIG_KEYBOARD_PXA27x_MODULE)
654static unsigned int em_x270_matrix_keys[] = { 682static unsigned int em_x270_module_matrix_keys[] = {
655 KEY(0, 0, KEY_A), KEY(1, 0, KEY_UP), KEY(2, 1, KEY_B), 683 KEY(0, 0, KEY_A), KEY(1, 0, KEY_UP), KEY(2, 1, KEY_B),
656 KEY(0, 2, KEY_LEFT), KEY(1, 1, KEY_ENTER), KEY(2, 0, KEY_RIGHT), 684 KEY(0, 2, KEY_LEFT), KEY(1, 1, KEY_ENTER), KEY(2, 0, KEY_RIGHT),
657 KEY(0, 1, KEY_C), KEY(1, 2, KEY_DOWN), KEY(2, 2, KEY_D), 685 KEY(0, 1, KEY_C), KEY(1, 2, KEY_DOWN), KEY(2, 2, KEY_D),
658}; 686};
659 687
660struct pxa27x_keypad_platform_data em_x270_keypad_info = { 688struct pxa27x_keypad_platform_data em_x270_module_keypad_info = {
661 /* code map for the matrix keys */ 689 /* code map for the matrix keys */
662 .matrix_key_rows = 3, 690 .matrix_key_rows = 3,
663 .matrix_key_cols = 3, 691 .matrix_key_cols = 3,
664 .matrix_key_map = em_x270_matrix_keys, 692 .matrix_key_map = em_x270_module_matrix_keys,
665 .matrix_key_map_size = ARRAY_SIZE(em_x270_matrix_keys), 693 .matrix_key_map_size = ARRAY_SIZE(em_x270_module_matrix_keys),
694};
695
696static unsigned int em_x270_exeda_matrix_keys[] = {
697 KEY(0, 0, KEY_RIGHTSHIFT), KEY(0, 1, KEY_RIGHTCTRL),
698 KEY(0, 2, KEY_RIGHTALT), KEY(0, 3, KEY_SPACE),
699 KEY(0, 4, KEY_LEFTALT), KEY(0, 5, KEY_LEFTCTRL),
700 KEY(0, 6, KEY_ENTER), KEY(0, 7, KEY_SLASH),
701
702 KEY(1, 0, KEY_DOT), KEY(1, 1, KEY_M),
703 KEY(1, 2, KEY_N), KEY(1, 3, KEY_B),
704 KEY(1, 4, KEY_V), KEY(1, 5, KEY_C),
705 KEY(1, 6, KEY_X), KEY(1, 7, KEY_Z),
706
707 KEY(2, 0, KEY_LEFTSHIFT), KEY(2, 1, KEY_SEMICOLON),
708 KEY(2, 2, KEY_L), KEY(2, 3, KEY_K),
709 KEY(2, 4, KEY_J), KEY(2, 5, KEY_H),
710 KEY(2, 6, KEY_G), KEY(2, 7, KEY_F),
711
712 KEY(3, 0, KEY_D), KEY(3, 1, KEY_S),
713 KEY(3, 2, KEY_A), KEY(3, 3, KEY_TAB),
714 KEY(3, 4, KEY_BACKSPACE), KEY(3, 5, KEY_P),
715 KEY(3, 6, KEY_O), KEY(3, 7, KEY_I),
716
717 KEY(4, 0, KEY_U), KEY(4, 1, KEY_Y),
718 KEY(4, 2, KEY_T), KEY(4, 3, KEY_R),
719 KEY(4, 4, KEY_E), KEY(4, 5, KEY_W),
720 KEY(4, 6, KEY_Q), KEY(4, 7, KEY_MINUS),
721
722 KEY(5, 0, KEY_0), KEY(5, 1, KEY_9),
723 KEY(5, 2, KEY_8), KEY(5, 3, KEY_7),
724 KEY(5, 4, KEY_6), KEY(5, 5, KEY_5),
725 KEY(5, 6, KEY_4), KEY(5, 7, KEY_3),
726
727 KEY(6, 0, KEY_2), KEY(6, 1, KEY_1),
728 KEY(6, 2, KEY_ENTER), KEY(6, 3, KEY_END),
729 KEY(6, 4, KEY_DOWN), KEY(6, 5, KEY_UP),
730 KEY(6, 6, KEY_MENU), KEY(6, 7, KEY_F1),
731
732 KEY(7, 0, KEY_LEFT), KEY(7, 1, KEY_RIGHT),
733 KEY(7, 2, KEY_BACK), KEY(7, 3, KEY_HOME),
734 KEY(7, 4, 0), KEY(7, 5, 0),
735 KEY(7, 6, 0), KEY(7, 7, 0),
736};
737
738struct pxa27x_keypad_platform_data em_x270_exeda_keypad_info = {
739 /* code map for the matrix keys */
740 .matrix_key_rows = 8,
741 .matrix_key_cols = 8,
742 .matrix_key_map = em_x270_exeda_matrix_keys,
743 .matrix_key_map_size = ARRAY_SIZE(em_x270_exeda_matrix_keys),
666}; 744};
667 745
668static void __init em_x270_init_keypad(void) 746static void __init em_x270_init_keypad(void)
669{ 747{
670 pxa_set_keypad_info(&em_x270_keypad_info); 748 if (machine_is_em_x270())
749 pxa_set_keypad_info(&em_x270_module_keypad_info);
750 else
751 pxa_set_keypad_info(&em_x270_exeda_keypad_info);
671} 752}
672#else 753#else
673static inline void em_x270_init_keypad(void) {} 754static inline void em_x270_init_keypad(void) {}
@@ -921,6 +1002,7 @@ static void __init em_x270_init_da9030(void)
921 1002
922static void __init em_x270_module_init(void) 1003static void __init em_x270_module_init(void)
923{ 1004{
1005 pr_info("%s\n", __func__);
924 pxa2xx_mfp_config(ARRAY_AND_SIZE(em_x270_pin_config)); 1006 pxa2xx_mfp_config(ARRAY_AND_SIZE(em_x270_pin_config));
925 1007
926 mmc_cd = GPIO13_MMC_CD; 1008 mmc_cd = GPIO13_MMC_CD;
@@ -928,11 +1010,26 @@ static void __init em_x270_module_init(void)
928 dm9000_flags = DM9000_PLATF_32BITONLY; 1010 dm9000_flags = DM9000_PLATF_32BITONLY;
929} 1011}
930 1012
1013static void __init em_x270_exeda_init(void)
1014{
1015 pr_info("%s\n", __func__);
1016 pxa2xx_mfp_config(ARRAY_AND_SIZE(exeda_pin_config));
1017
1018 mmc_cd = GPIO114_MMC_CD;
1019 nand_rb = GPIO20_NAND_RB;
1020 dm9000_flags = DM9000_PLATF_16BITONLY;
1021}
1022
931static void __init em_x270_init(void) 1023static void __init em_x270_init(void)
932{ 1024{
933 pxa2xx_mfp_config(ARRAY_AND_SIZE(common_pin_config)); 1025 pxa2xx_mfp_config(ARRAY_AND_SIZE(common_pin_config));
934 1026
935 em_x270_module_init(); 1027 if (machine_is_em_x270())
1028 em_x270_module_init();
1029 else if (machine_is_exeda())
1030 em_x270_exeda_init();
1031 else
1032 panic("Unsupported machine: %d\n", machine_arch_type);
936 1033
937 em_x270_init_da9030(); 1034 em_x270_init_da9030();
938 em_x270_init_dm9000(); 1035 em_x270_init_dm9000();
@@ -958,3 +1055,13 @@ MACHINE_START(EM_X270, "Compulab EM-X270")
958 .timer = &pxa_timer, 1055 .timer = &pxa_timer,
959 .init_machine = em_x270_init, 1056 .init_machine = em_x270_init,
960MACHINE_END 1057MACHINE_END
1058
1059MACHINE_START(EXEDA, "Compulab eXeda")
1060 .boot_params = 0xa0000100,
1061 .phys_io = 0x40000000,
1062 .io_pg_offst = (io_p2v(0x40000000) >> 18) & 0xfffc,
1063 .map_io = pxa_map_io,
1064 .init_irq = pxa27x_init_irq,
1065 .timer = &pxa_timer,
1066 .init_machine = em_x270_init,
1067MACHINE_END