diff --git a/arch/arm/mach-sc/board-sp7715ga.c b/arch/arm/mach-sc/board-sp7715ga.c
index d80e056..cc9db11 100755
--- a/arch/arm/mach-sc/board-sp7715ga.c
+++ b/arch/arm/mach-sc/board-sp7715ga.c
@@ -26,8 +26,10 @@
 #include <asm/localtimer.h>
 
 #include <linux/i2c.h>
-//#include <linux/i2c/ft53x6_ts.h>
+#if(defined(CONFIG_TOUCHSCREEN))
+#include <linux/i2c/ft53x6_ts.h>
 #include <linux/i2c/focaltech.h>
+#endif
 #if(defined(CONFIG_INPUT_LIS3DH_I2C)||defined(CONFIG_INPUT_LIS3DH_I2C_MODULE))
 #include <linux/i2c/lis3dh.h>
 #endif
@@ -67,6 +69,11 @@
 #include <mach/regulator.h>
 #include <mach/i2s.h>
 
+#if defined(CONFIG_KEYBOARD_GPIO)
+#include <linux/gpio_keys.h>
+#include <linux/interrupt.h>
+#endif
+
 extern void __init sci_reserve(void);
 extern void __init sci_map_io(void);
 extern void __init sci_init_irq(void);
@@ -78,15 +85,35 @@ extern int __init sprd_ramconsole_init(void);
 #endif
 
 /*keypad define */
-#define CUSTOM_KEYPAD_ROWS          (SCI_ROW0 | SCI_ROW1)
-#define CUSTOM_KEYPAD_COLS          (SCI_COL0 | SCI_COL1)
-#define ROWS	(2)
-#define COLS	(2)
+#define CUSTOM_KEYPAD_ROWS          (SCI_ROW0 | SCI_ROW1 | SCI_ROW2 )
+#define CUSTOM_KEYPAD_COLS          (SCI_COL0 | SCI_COL1 | SCI_COL2 )
+#define ROWS	(3)
+#define COLS	(3)
+
+#if defined(CONFIG_KEYBOARD_GPIO)
+#define GPIO_1_KEY 101
+#define GPIO_2_KEY 108
+#define GPIO_4_KEY 107
+#define GPIO_6_KEY 109
+#define GPIO_NUMERIC_STAR_KEY 100
+#define GPIO_UP_KEY 99
+#define GPIO_9_KEY 102
+#define GPIO_7_KEY 103
+#define GPIO_8_KEY 106
+#define GPIO_LEFT_KEY 105
+#define GPIO_RIGHT_KEY 110
+#define GPIO_SELECT_KEY 104
+#endif
 
 static const unsigned int board_keymap[] = {
-	KEY(0, 0, KEY_VOLUMEDOWN),
-	KEY(1, 0, KEY_VOLUMEUP),
-	KEY(0, 1, KEY_CAMERA),
+	KEY(0, 0, KEY_5),
+	KEY(1, 0, KEY_BACK),
+	KEY(2, 0, KEY_DOWN),
+	KEY(0, 1, KEY_SEND),
+	KEY(1, 1, KEY_0),
+	KEY(0, 2, KEY_3),
+	KEY(1, 2, KEY_MENU),
+	KEY(2, 2, KEY_SLASH),
 };
 
 static const struct matrix_keymap_data customize_keymap = {
@@ -108,6 +135,9 @@ static struct sci_keypad_platform_data sci_keypad_data = {
 static struct platform_device rfkill_device;
 static struct platform_device brcm_bluesleep_device;
 static struct platform_device kb_backlight_device;
+#if defined(CONFIG_KEYBOARD_GPIO)
+static struct platform_device gpio_button_device;
+#endif
 
 static struct platform_device *devices[] __initdata = {
 	&sprd_serial_device0,
@@ -200,6 +230,9 @@ static struct platform_device *devices[] __initdata = {
 #ifdef  CONFIG_RF_SHARK	
 	&trout_fm_device,
 #endif
+#if defined(CONFIG_KEYBOARD_GPIO)
+	&gpio_button_device,
+#endif
 	&sprd_headset_device,
     &sprd_saudio_voip_device,
 };
@@ -272,6 +305,121 @@ static struct platform_device rfkill_device = {
 };
 #endif
 
+#if defined(CONFIG_KEYBOARD_GPIO)
+static struct gpio_keys_button gpio_buttons[] = {
+	{
+		.gpio	= GPIO_1_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_1,
+		.desc = "Key 1",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_2_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_2,
+		.desc = "Key 2",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_4_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_4,
+		.desc = "Key 4",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_6_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_6,
+		.desc = "Key 6",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_7_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_7,
+		.desc = "Key 7",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_8_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_8,
+		.desc = "Key 8",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_9_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_9,
+		.desc = "Key 9",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_UP_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_UP,
+		.desc = "Up key",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_LEFT_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_LEFT,
+		.desc = "Left key",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_RIGHT_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_RIGHT,
+		.desc = "Right key",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_SELECT_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_ENTER,
+		.desc = "Select key",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+	{
+		.gpio	= GPIO_NUMERIC_STAR_KEY,
+		.ds_irqflags = IRQF_TRIGGER_LOW,
+		.code = KEY_KPASTERISK,
+		.desc = "Star key",
+		.active_low = 1,
+		.debounce_interval = 2,
+	},
+};
+
+static struct gpio_keys_platform_data gpio_button_data = {
+	.buttons = gpio_buttons,
+	.nbuttons = ARRAY_SIZE(gpio_buttons),
+};
+
+static struct platform_device gpio_button_device = {
+	.name = "gpio-keys",
+	.id = -1,
+	.num_resources = 0,
+	.dev = {
+			.platform_data = &gpio_button_data,
+	}
+};
+#endif
+
 /* keypad backlight */
 static struct platform_device kb_backlight_device = {
 	.name           = "keyboard-backlight",
@@ -324,7 +472,7 @@ static struct serial_data plat_data2 = {
 	.clk = 26000000,
 };
 
-static struct ft5x0x_ts_platform_data ft5x0x_ts_info = {
+/*static struct ft5x0x_ts_platform_data ft5x0x_ts_info = {
 	.irq_gpio_number	= GPIO_TOUCH_IRQ,
 	.reset_gpio_number	= GPIO_TOUCH_RESET,
 	.vdd_name 			= "vdd28",
@@ -341,7 +489,7 @@ static struct ft5x0x_ts_platform_data ft5x0x_ts_info = {
         .TP_MAX_X = 540,
         .TP_MAX_Y = 960,
 #endif
-};
+};*/
 
 #if(defined(CONFIG_INPUT_LTR558_I2C)||defined(CONFIG_INPUT_LTR558_I2C_MODULE))
 static struct ltr558_pls_platform_data ltr558_pls_info = {
@@ -411,10 +411,12 @@ static struct i2c_board_info i2c0_boardinfo[] = {
 };
 
 static struct i2c_board_info i2c1_boardinfo[] = {
+#if(defined(CONFIG_TOUCHSCREEN))
 	{
 		I2C_BOARD_INFO(FOCALTECH_TS_NAME, FOCALTECH_TS_ADDR),
 		.platform_data = &ft5x0x_ts_info,
 	},
+#endif
 };
 
 static struct i2c_board_info i2c2_boardinfo[] = {
@@ -461,8 +611,8 @@ static struct i2c_board_info i2c2_boardinfo[] = {
 static int sc8810_add_i2c_devices(void)
 {
 	i2c_register_board_info(0, i2c0_boardinfo, ARRAY_SIZE(i2c0_boardinfo));
-	i2c_register_board_info(1, i2c1_boardinfo, ARRAY_SIZE(i2c1_boardinfo));
-	i2c_register_board_info(2, i2c2_boardinfo, ARRAY_SIZE(i2c2_boardinfo));
+	//i2c_register_board_info(1, i2c1_boardinfo, ARRAY_SIZE(i2c1_boardinfo));
+	//i2c_register_board_info(2, i2c2_boardinfo, ARRAY_SIZE(i2c2_boardinfo));
 	return 0;
 }