|
@@ -64,31 +64,31 @@ static struct map_desc mini2440_iodesc[] __initdata = {
|
|
};
|
|
};
|
|
|
|
|
|
#define UCON S3C2410_UCON_DEFAULT
|
|
#define UCON S3C2410_UCON_DEFAULT
|
|
-#define ULCON S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB
|
|
|
|
-#define UFCON S3C2410_UFCON_RXTRIG8 | S3C2410_UFCON_FIFOMODE
|
|
|
|
|
|
+#define ULCON (S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB)
|
|
|
|
+#define UFCON (S3C2410_UFCON_RXTRIG8 | S3C2410_UFCON_FIFOMODE)
|
|
|
|
|
|
|
|
|
|
static struct s3c2410_uartcfg mini2440_uartcfgs[] __initdata = {
|
|
static struct s3c2410_uartcfg mini2440_uartcfgs[] __initdata = {
|
|
[0] = {
|
|
[0] = {
|
|
- .hwport = 0,
|
|
|
|
- .flags = 0,
|
|
|
|
- .ucon = UCON,
|
|
|
|
- .ulcon = ULCON,
|
|
|
|
- .ufcon = UFCON,
|
|
|
|
|
|
+ .hwport = 0,
|
|
|
|
+ .flags = 0,
|
|
|
|
+ .ucon = UCON,
|
|
|
|
+ .ulcon = ULCON,
|
|
|
|
+ .ufcon = UFCON,
|
|
},
|
|
},
|
|
[1] = {
|
|
[1] = {
|
|
- .hwport = 1,
|
|
|
|
- .flags = 0,
|
|
|
|
- .ucon = UCON,
|
|
|
|
- .ulcon = ULCON,
|
|
|
|
- .ufcon = UFCON,
|
|
|
|
|
|
+ .hwport = 1,
|
|
|
|
+ .flags = 0,
|
|
|
|
+ .ucon = UCON,
|
|
|
|
+ .ulcon = ULCON,
|
|
|
|
+ .ufcon = UFCON,
|
|
},
|
|
},
|
|
[2] = {
|
|
[2] = {
|
|
- .hwport = 2,
|
|
|
|
- .flags = 0,
|
|
|
|
- .ucon = UCON,
|
|
|
|
- .ulcon = ULCON,
|
|
|
|
- .ufcon = UFCON,
|
|
|
|
|
|
+ .hwport = 2,
|
|
|
|
+ .flags = 0,
|
|
|
|
+ .ucon = UCON,
|
|
|
|
+ .ulcon = ULCON,
|
|
|
|
+ .ufcon = UFCON,
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
|
|
@@ -104,8 +104,8 @@ static struct s3c2410_udc_mach_info mini2440_udc_cfg __initdata = {
|
|
/*
|
|
/*
|
|
* This macro simplifies the table bellow
|
|
* This macro simplifies the table bellow
|
|
*/
|
|
*/
|
|
-#define _LCD_DECLARE(_clock,_xres,margin_left,margin_right,hsync, \
|
|
|
|
- _yres,margin_top,margin_bottom,vsync, refresh) \
|
|
|
|
|
|
+#define _LCD_DECLARE(_clock, _xres, margin_left, margin_right, hsync, \
|
|
|
|
+ _yres, margin_top, margin_bottom, vsync, refresh) \
|
|
.width = _xres, \
|
|
.width = _xres, \
|
|
.xres = _xres, \
|
|
.xres = _xres, \
|
|
.height = _yres, \
|
|
.height = _yres, \
|
|
@@ -128,7 +128,7 @@ static struct s3c2410fb_display mini2440_lcd_cfg[] __initdata = {
|
|
[0] = { /* mini2440 + 3.5" TFT + touchscreen */
|
|
[0] = { /* mini2440 + 3.5" TFT + touchscreen */
|
|
_LCD_DECLARE(
|
|
_LCD_DECLARE(
|
|
7, /* The 3.5 is quite fast */
|
|
7, /* The 3.5 is quite fast */
|
|
- 240, 21, 38, 6, /* x timing */
|
|
|
|
|
|
+ 240, 21, 38, 6, /* x timing */
|
|
320, 4, 4, 2, /* y timing */
|
|
320, 4, 4, 2, /* y timing */
|
|
60), /* refresh rate */
|
|
60), /* refresh rate */
|
|
.lcdcon5 = (S3C2410_LCDCON5_FRM565 |
|
|
.lcdcon5 = (S3C2410_LCDCON5_FRM565 |
|
|
@@ -140,7 +140,7 @@ static struct s3c2410fb_display mini2440_lcd_cfg[] __initdata = {
|
|
[1] = { /* mini2440 + 7" TFT + touchscreen */
|
|
[1] = { /* mini2440 + 7" TFT + touchscreen */
|
|
_LCD_DECLARE(
|
|
_LCD_DECLARE(
|
|
10, /* the 7" runs slower */
|
|
10, /* the 7" runs slower */
|
|
- 800, 40, 40, 48, /* x timing */
|
|
|
|
|
|
+ 800, 40, 40, 48, /* x timing */
|
|
480, 29, 3, 3, /* y timing */
|
|
480, 29, 3, 3, /* y timing */
|
|
50), /* refresh rate */
|
|
50), /* refresh rate */
|
|
.lcdcon5 = (S3C2410_LCDCON5_FRM565 |
|
|
.lcdcon5 = (S3C2410_LCDCON5_FRM565 |
|
|
@@ -148,7 +148,7 @@ static struct s3c2410fb_display mini2440_lcd_cfg[] __initdata = {
|
|
S3C2410_LCDCON5_INVVFRAME |
|
|
S3C2410_LCDCON5_INVVFRAME |
|
|
S3C2410_LCDCON5_PWREN),
|
|
S3C2410_LCDCON5_PWREN),
|
|
},
|
|
},
|
|
- /* The VGA shield can outout at several resolutions. All share
|
|
|
|
|
|
+ /* The VGA shield can outout at several resolutions. All share
|
|
* the same timings, however, anything smaller than 1024x768
|
|
* the same timings, however, anything smaller than 1024x768
|
|
* will only be displayed in the top left corner of a 1024x768
|
|
* will only be displayed in the top left corner of a 1024x768
|
|
* XGA output unless you add optional dip switches to the shield.
|
|
* XGA output unless you add optional dip switches to the shield.
|
|
@@ -158,9 +158,10 @@ static struct s3c2410fb_display mini2440_lcd_cfg[] __initdata = {
|
|
_LCD_DECLARE(
|
|
_LCD_DECLARE(
|
|
10,
|
|
10,
|
|
1024, 1, 2, 2, /* y timing */
|
|
1024, 1, 2, 2, /* y timing */
|
|
- 768, 200, 16, 16, /* x timing */
|
|
|
|
|
|
+ 768, 200, 16, 16, /* x timing */
|
|
24), /* refresh rate, maximum stable,
|
|
24), /* refresh rate, maximum stable,
|
|
- tested with the FPGA shield */
|
|
|
|
|
|
+ * tested with the FPGA shield
|
|
|
|
+ */
|
|
.lcdcon5 = (S3C2410_LCDCON5_FRM565 |
|
|
.lcdcon5 = (S3C2410_LCDCON5_FRM565 |
|
|
S3C2410_LCDCON5_HWSWP),
|
|
S3C2410_LCDCON5_HWSWP),
|
|
},
|
|
},
|
|
@@ -196,7 +197,8 @@ static struct s3c2410fb_mach_info mini2440_fb_info __initdata = {
|
|
|
|
|
|
/* Enable VD[2..7], VD[10..15], VD[18..23] and VCLK, syncs, VDEN
|
|
/* Enable VD[2..7], VD[10..15], VD[18..23] and VCLK, syncs, VDEN
|
|
* and disable the pull down resistors on pins we are using for LCD
|
|
* and disable the pull down resistors on pins we are using for LCD
|
|
- * data. */
|
|
|
|
|
|
+ * data.
|
|
|
|
+ */
|
|
|
|
|
|
.gpcup = (0xf << 1) | (0x3f << 10),
|
|
.gpcup = (0xf << 1) | (0x3f << 10),
|
|
|
|
|
|
@@ -232,10 +234,11 @@ static struct s3c2410fb_mach_info mini2440_fb_info __initdata = {
|
|
/* MMC/SD */
|
|
/* MMC/SD */
|
|
|
|
|
|
static struct s3c24xx_mci_pdata mini2440_mmc_cfg __initdata = {
|
|
static struct s3c24xx_mci_pdata mini2440_mmc_cfg __initdata = {
|
|
- .gpio_detect = S3C2410_GPG(8),
|
|
|
|
- .gpio_wprotect = S3C2410_GPH(8),
|
|
|
|
- .set_power = NULL,
|
|
|
|
- .ocr_avail = MMC_VDD_32_33|MMC_VDD_33_34,
|
|
|
|
|
|
+ .gpio_detect = S3C2410_GPG(8),
|
|
|
|
+ .gpio_wprotect = S3C2410_GPH(8),
|
|
|
|
+ .wprotect_invert = 1,
|
|
|
|
+ .set_power = NULL,
|
|
|
|
+ .ocr_avail = MMC_VDD_32_33|MMC_VDD_33_34,
|
|
};
|
|
};
|
|
|
|
|
|
/* NAND Flash on MINI2440 board */
|
|
/* NAND Flash on MINI2440 board */
|
|
@@ -254,7 +257,8 @@ static struct mtd_partition mini2440_default_nand_part[] __initdata = {
|
|
[2] = {
|
|
[2] = {
|
|
.name = "kernel",
|
|
.name = "kernel",
|
|
/* 5 megabytes, for a kernel with no modules
|
|
/* 5 megabytes, for a kernel with no modules
|
|
- * or a uImage with a ramdisk attached */
|
|
|
|
|
|
+ * or a uImage with a ramdisk attached
|
|
|
|
+ */
|
|
.size = 0x00500000,
|
|
.size = 0x00500000,
|
|
.offset = SZ_256K + SZ_128K,
|
|
.offset = SZ_256K + SZ_128K,
|
|
},
|
|
},
|
|
@@ -271,7 +275,7 @@ static struct s3c2410_nand_set mini2440_nand_sets[] __initdata = {
|
|
.nr_chips = 1,
|
|
.nr_chips = 1,
|
|
.nr_partitions = ARRAY_SIZE(mini2440_default_nand_part),
|
|
.nr_partitions = ARRAY_SIZE(mini2440_default_nand_part),
|
|
.partitions = mini2440_default_nand_part,
|
|
.partitions = mini2440_default_nand_part,
|
|
- .flash_bbt = 1, /* we use u-boot to create a BBT */
|
|
|
|
|
|
+ .flash_bbt = 1, /* we use u-boot to create a BBT */
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
|
|
@@ -282,7 +286,7 @@ static struct s3c2410_platform_nand mini2440_nand_info __initdata = {
|
|
.nr_sets = ARRAY_SIZE(mini2440_nand_sets),
|
|
.nr_sets = ARRAY_SIZE(mini2440_nand_sets),
|
|
.sets = mini2440_nand_sets,
|
|
.sets = mini2440_nand_sets,
|
|
.ignore_unset_ecc = 1,
|
|
.ignore_unset_ecc = 1,
|
|
- .ecc_mode = NAND_ECC_HW,
|
|
|
|
|
|
+ .ecc_mode = NAND_ECC_HW,
|
|
};
|
|
};
|
|
|
|
|
|
/* DM9000AEP 10/100 ethernet controller */
|
|
/* DM9000AEP 10/100 ethernet controller */
|
|
@@ -290,7 +294,7 @@ static struct s3c2410_platform_nand mini2440_nand_info __initdata = {
|
|
static struct resource mini2440_dm9k_resource[] = {
|
|
static struct resource mini2440_dm9k_resource[] = {
|
|
[0] = DEFINE_RES_MEM(MACH_MINI2440_DM9K_BASE, 4),
|
|
[0] = DEFINE_RES_MEM(MACH_MINI2440_DM9K_BASE, 4),
|
|
[1] = DEFINE_RES_MEM(MACH_MINI2440_DM9K_BASE + 4, 4),
|
|
[1] = DEFINE_RES_MEM(MACH_MINI2440_DM9K_BASE + 4, 4),
|
|
- [2] = DEFINE_RES_NAMED(IRQ_EINT7, 1, NULL, IORESOURCE_IRQ \
|
|
|
|
|
|
+ [2] = DEFINE_RES_NAMED(IRQ_EINT7, 1, NULL, IORESOURCE_IRQ
|
|
| IORESOURCE_IRQ_HIGHEDGE),
|
|
| IORESOURCE_IRQ_HIGHEDGE),
|
|
};
|
|
};
|
|
|
|
|
|
@@ -362,7 +366,8 @@ static struct gpio_keys_button mini2440_buttons[] = {
|
|
},
|
|
},
|
|
#if 0
|
|
#if 0
|
|
/* this pin is also known as TCLK1 and seems to already
|
|
/* this pin is also known as TCLK1 and seems to already
|
|
- * marked as "in use" somehow in the kernel -- possibly wrongly */
|
|
|
|
|
|
+ * marked as "in use" somehow in the kernel -- possibly wrongly
|
|
|
|
+ */
|
|
{
|
|
{
|
|
.gpio = S3C2410_GPG(11), /* K6 */
|
|
.gpio = S3C2410_GPG(11), /* K6 */
|
|
.code = KEY_F6,
|
|
.code = KEY_F6,
|
|
@@ -564,7 +569,8 @@ static char mini2440_features_str[12] __initdata = "0tb";
|
|
static int __init mini2440_features_setup(char *str)
|
|
static int __init mini2440_features_setup(char *str)
|
|
{
|
|
{
|
|
if (str)
|
|
if (str)
|
|
- strlcpy(mini2440_features_str, str, sizeof(mini2440_features_str));
|
|
|
|
|
|
+ strlcpy(mini2440_features_str, str,
|
|
|
|
+ sizeof(mini2440_features_str));
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -583,10 +589,10 @@ struct mini2440_features_t {
|
|
};
|
|
};
|
|
|
|
|
|
static void __init mini2440_parse_features(
|
|
static void __init mini2440_parse_features(
|
|
- struct mini2440_features_t * features,
|
|
|
|
- const char * features_str )
|
|
|
|
|
|
+ struct mini2440_features_t *features,
|
|
|
|
+ const char *features_str)
|
|
{
|
|
{
|
|
- const char * fp = features_str;
|
|
|
|
|
|
+ const char *fp = features_str;
|
|
|
|
|
|
features->count = 0;
|
|
features->count = 0;
|
|
features->done = 0;
|
|
features->done = 0;
|
|
@@ -598,13 +604,14 @@ static void __init mini2440_parse_features(
|
|
switch (f) {
|
|
switch (f) {
|
|
case '0'...'9': /* tft screen */
|
|
case '0'...'9': /* tft screen */
|
|
if (features->done & FEATURE_SCREEN) {
|
|
if (features->done & FEATURE_SCREEN) {
|
|
- printk(KERN_INFO "MINI2440: '%c' ignored, "
|
|
|
|
- "screen type already set\n", f);
|
|
|
|
|
|
+ pr_info("MINI2440: '%c' ignored, screen type already set\n",
|
|
|
|
+ f);
|
|
} else {
|
|
} else {
|
|
int li = f - '0';
|
|
int li = f - '0';
|
|
|
|
+
|
|
if (li >= ARRAY_SIZE(mini2440_lcd_cfg))
|
|
if (li >= ARRAY_SIZE(mini2440_lcd_cfg))
|
|
- printk(KERN_INFO "MINI2440: "
|
|
|
|
- "'%c' out of range LCD mode\n", f);
|
|
|
|
|
|
+ pr_info("MINI2440: '%c' out of range LCD mode\n",
|
|
|
|
+ f);
|
|
else {
|
|
else {
|
|
features->optional[features->count++] =
|
|
features->optional[features->count++] =
|
|
&s3c_device_lcd;
|
|
&s3c_device_lcd;
|
|
@@ -615,8 +622,8 @@ static void __init mini2440_parse_features(
|
|
break;
|
|
break;
|
|
case 'b':
|
|
case 'b':
|
|
if (features->done & FEATURE_BACKLIGHT)
|
|
if (features->done & FEATURE_BACKLIGHT)
|
|
- printk(KERN_INFO "MINI2440: '%c' ignored, "
|
|
|
|
- "backlight already set\n", f);
|
|
|
|
|
|
+ pr_info("MINI2440: '%c' ignored, backlight already set\n",
|
|
|
|
+ f);
|
|
else {
|
|
else {
|
|
features->optional[features->count++] =
|
|
features->optional[features->count++] =
|
|
&mini2440_led_backlight;
|
|
&mini2440_led_backlight;
|
|
@@ -624,13 +631,13 @@ static void __init mini2440_parse_features(
|
|
features->done |= FEATURE_BACKLIGHT;
|
|
features->done |= FEATURE_BACKLIGHT;
|
|
break;
|
|
break;
|
|
case 't':
|
|
case 't':
|
|
- printk(KERN_INFO "MINI2440: '%c' ignored, "
|
|
|
|
- "touchscreen not compiled in\n", f);
|
|
|
|
|
|
+ pr_info("MINI2440: '%c' ignored, touchscreen not compiled in\n",
|
|
|
|
+ f);
|
|
break;
|
|
break;
|
|
case 'c':
|
|
case 'c':
|
|
if (features->done & FEATURE_CAMERA)
|
|
if (features->done & FEATURE_CAMERA)
|
|
- printk(KERN_INFO "MINI2440: '%c' ignored, "
|
|
|
|
- "camera already registered\n", f);
|
|
|
|
|
|
+ pr_info("MINI2440: '%c' ignored, camera already registered\n",
|
|
|
|
+ f);
|
|
else
|
|
else
|
|
features->optional[features->count++] =
|
|
features->optional[features->count++] =
|
|
&s3c_device_camif;
|
|
&s3c_device_camif;
|
|
@@ -645,7 +652,7 @@ static void __init mini2440_init(void)
|
|
struct mini2440_features_t features = { 0 };
|
|
struct mini2440_features_t features = { 0 };
|
|
int i;
|
|
int i;
|
|
|
|
|
|
- printk(KERN_INFO "MINI2440: Option string mini2440=%s\n",
|
|
|
|
|
|
+ pr_info("MINI2440: Option string mini2440=%s\n",
|
|
mini2440_features_str);
|
|
mini2440_features_str);
|
|
|
|
|
|
/* Parse the feature string */
|
|
/* Parse the feature string */
|
|
@@ -674,17 +681,17 @@ static void __init mini2440_init(void)
|
|
mini2440_fb_info.displays =
|
|
mini2440_fb_info.displays =
|
|
&mini2440_lcd_cfg[features.lcd_index];
|
|
&mini2440_lcd_cfg[features.lcd_index];
|
|
|
|
|
|
- printk(KERN_INFO "MINI2440: LCD");
|
|
|
|
|
|
+ pr_info("MINI2440: LCD");
|
|
for (li = 0; li < ARRAY_SIZE(mini2440_lcd_cfg); li++)
|
|
for (li = 0; li < ARRAY_SIZE(mini2440_lcd_cfg); li++)
|
|
if (li == features.lcd_index)
|
|
if (li == features.lcd_index)
|
|
- printk(" [%d:%dx%d]", li,
|
|
|
|
|
|
+ pr_cont(" [%d:%dx%d]", li,
|
|
mini2440_lcd_cfg[li].width,
|
|
mini2440_lcd_cfg[li].width,
|
|
mini2440_lcd_cfg[li].height);
|
|
mini2440_lcd_cfg[li].height);
|
|
else
|
|
else
|
|
- printk(" %d:%dx%d", li,
|
|
|
|
|
|
+ pr_cont(" %d:%dx%d", li,
|
|
mini2440_lcd_cfg[li].width,
|
|
mini2440_lcd_cfg[li].width,
|
|
mini2440_lcd_cfg[li].height);
|
|
mini2440_lcd_cfg[li].height);
|
|
- printk("\n");
|
|
|
|
|
|
+ pr_cont("\n");
|
|
s3c24xx_fb_set_platdata(&mini2440_fb_info);
|
|
s3c24xx_fb_set_platdata(&mini2440_fb_info);
|
|
}
|
|
}
|
|
|
|
|