mach-nexcoder.c 3.9 KB
Newer Older
1
/* linux/arch/arm/mach-s3c2440/mach-nexcoder.c
L
Linus Torvalds 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
 *
 * Copyright (c) 2004 Nex Vision
 *   Guillaume GOURAT <guillaume.gourat@nexvision.tv>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * Modifications:
 *     15-10-2004 GG  Created initial version
 *     12-03-2005 BJD Updated for release
 */

#include <linux/kernel.h>
#include <linux/types.h>
#include <linux/interrupt.h>
#include <linux/list.h>
#include <linux/timer.h>
#include <linux/init.h>
21
#include <linux/gpio.h>
L
Linus Torvalds 已提交
22
#include <linux/string.h>
23
#include <linux/serial_core.h>
24
#include <linux/platform_device.h>
25
#include <linux/io.h>
L
Linus Torvalds 已提交
26 27 28 29 30 31 32 33

#include <linux/mtd/map.h>

#include <asm/mach/arch.h>
#include <asm/mach/map.h>
#include <asm/mach/irq.h>

#include <asm/setup.h>
34
#include <mach/hardware.h>
L
Linus Torvalds 已提交
35 36 37 38
#include <asm/irq.h>
#include <asm/mach-types.h>

//#include <asm/debug-ll.h>
39
#include <mach/regs-gpio.h>
40
#include <plat/regs-serial.h>
41
#include <plat/iic.h>
L
Linus Torvalds 已提交
42

43
#include <plat/gpio-cfg.h>
44
#include <plat/s3c2410.h>
45
#include <plat/s3c244x.h>
46
#include <plat/clock.h>
47 48
#include <plat/devs.h>
#include <plat/cpu.h>
L
Linus Torvalds 已提交
49

50 51
#include "common.h"

L
Linus Torvalds 已提交
52 53 54 55 56 57 58 59
static struct map_desc nexcoder_iodesc[] __initdata = {
	/* nothing here yet */
};

#define UCON S3C2410_UCON_DEFAULT
#define ULCON S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB
#define UFCON S3C2410_UFCON_RXTRIG12 | S3C2410_UFCON_FIFOMODE

60
static struct s3c2410_uartcfg nexcoder_uartcfgs[] __initdata = {
L
Linus Torvalds 已提交
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
	[0] = {
		.hwport	     = 0,
		.flags	     = 0,
		.ucon	     = UCON,
		.ulcon	     = ULCON,
		.ufcon	     = UFCON,
	},
	[1] = {
		.hwport	     = 1,
		.flags	     = 0,
		.ucon	     = UCON,
		.ulcon	     = ULCON,
		.ufcon	     = UFCON,
	},
	[2] = {
		.hwport	     = 2,
		.flags	     = 0,
		.ucon	     = UCON,
		.ulcon	     = ULCON,
		.ufcon	     = UFCON,
	}
};

/* NOR Flash on NexVision NexCoder 2440 board */

static struct resource nexcoder_nor_resource[] = {
	[0] = {
		.start = S3C2410_CS0,
		.end   = S3C2410_CS0 + (8*1024*1024) - 1,
		.flags = IORESOURCE_MEM,
	}
};

static struct map_info nexcoder_nor_map = {
	.bankwidth = 2,
};

static struct platform_device nexcoder_device_nor = {
	.name		= "mtd-flash",
	.id		= -1,
	.num_resources	= ARRAY_SIZE(nexcoder_nor_resource),
	.resource	= nexcoder_nor_resource,
	.dev =
	{
		.platform_data = &nexcoder_nor_map,
	}
};

/* Standard Nexcoder devices */

static struct platform_device *nexcoder_devices[] __initdata = {
112
	&s3c_device_ohci,
L
Linus Torvalds 已提交
113 114
	&s3c_device_lcd,
	&s3c_device_wdt,
115
	&s3c_device_i2c0,
L
Linus Torvalds 已提交
116 117 118 119 120 121 122 123 124 125 126
	&s3c_device_iis,
 	&s3c_device_rtc,
	&s3c_device_camif,
	&s3c_device_spi0,
	&s3c_device_spi1,
	&nexcoder_device_nor,
};

static void __init nexcoder_sensorboard_init(void)
{
	// Initialize SCCB bus
127
	s3c2410_gpio_setpin(S3C2410_GPE(14), 1); // IICSCL
128
	s3c_gpio_cfgpin(S3C2410_GPE(14), S3C2410_GPIO_OUTPUT);
129
	s3c2410_gpio_setpin(S3C2410_GPE(15), 1); // IICSDA
130
	s3c_gpio_cfgpin(S3C2410_GPE(15), S3C2410_GPIO_OUTPUT);
L
Linus Torvalds 已提交
131 132

	// Power up the sensor board
133
	s3c2410_gpio_setpin(S3C2410_GPF(1), 1);
134
	s3c_gpio_cfgpin(S3C2410_GPF(1), S3C2410_GPIO_OUTPUT); // CAM_GPIO7 => nLDO_PWRDN
135
	s3c2410_gpio_setpin(S3C2410_GPF(2), 0);
136
	s3c_gpio_cfgpin(S3C2410_GPF(2), S3C2410_GPIO_OUTPUT); // CAM_GPIO6 => CAM_PWRDN
L
Linus Torvalds 已提交
137 138
}

139
static void __init nexcoder_map_io(void)
L
Linus Torvalds 已提交
140 141 142 143
{
	s3c24xx_init_io(nexcoder_iodesc, ARRAY_SIZE(nexcoder_iodesc));
	s3c24xx_init_clocks(0);
	s3c24xx_init_uarts(nexcoder_uartcfgs, ARRAY_SIZE(nexcoder_uartcfgs));
144

L
Linus Torvalds 已提交
145 146 147
	nexcoder_sensorboard_init();
}

148 149
static void __init nexcoder_init(void)
{
150
	s3c_i2c0_set_platdata(NULL);
151 152
	platform_add_devices(nexcoder_devices, ARRAY_SIZE(nexcoder_devices));
};
L
Linus Torvalds 已提交
153 154

MACHINE_START(NEXCODER_2440, "NexVision - Nexcoder 2440")
155
	/* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */
156
	.atag_offset	= 0x100,
L
Linus Torvalds 已提交
157
	.map_io		= nexcoder_map_io,
158
	.init_machine	= nexcoder_init,
L
Linus Torvalds 已提交
159 160
	.init_irq	= s3c24xx_init_irq,
	.timer		= &s3c24xx_timer,
161
	.restart	= s3c244x_restart,
L
Linus Torvalds 已提交
162
MACHINE_END