mach-nexcoder.c 3.9 KB
Newer Older
1
/* linux/arch/arm/mach-s3c2440/mach-nexcoder.c
Linus Torvalds's avatar
Linus Torvalds committed
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>
Linus Torvalds's avatar
Linus Torvalds committed
22
#include <linux/string.h>
23
#include <linux/serial_core.h>
24
#include <linux/platform_device.h>
25
#include <linux/io.h>
Linus Torvalds's avatar
Linus Torvalds committed
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>
Linus Torvalds's avatar
Linus Torvalds committed
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 <mach/gpio-samsung.h>
41
#include <plat/regs-serial.h>
42
#include <linux/platform_data/i2c-s3c2410.h>
Linus Torvalds's avatar
Linus Torvalds committed
43

44
#include <plat/gpio-cfg.h>
45
#include <plat/clock.h>
46 47
#include <plat/devs.h>
#include <plat/cpu.h>
48
#include <plat/samsung-time.h>
Linus Torvalds's avatar
Linus Torvalds committed
49

50 51
#include "common.h"

Linus Torvalds's avatar
Linus Torvalds committed
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 = {
Linus Torvalds's avatar
Linus Torvalds committed
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
	[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[] = {
87
	[0] = DEFINE_RES_MEM(S3C2410_CS0, SZ_8M),
Linus Torvalds's avatar
Linus Torvalds committed
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
};

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 = {
108
	&s3c_device_ohci,
Linus Torvalds's avatar
Linus Torvalds committed
109 110
	&s3c_device_lcd,
	&s3c_device_wdt,
111
	&s3c_device_i2c0,
Linus Torvalds's avatar
Linus Torvalds committed
112 113 114 115 116 117 118 119 120 121
	&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)
{
122 123 124 125 126 127 128 129 130 131 132
	/* Initialize SCCB bus */
	gpio_request_one(S3C2410_GPE(14), GPIOF_OUT_INIT_HIGH, NULL);
	gpio_free(S3C2410_GPE(14)); /* IICSCL */
	gpio_request_one(S3C2410_GPE(15), GPIOF_OUT_INIT_HIGH, NULL);
	gpio_free(S3C2410_GPE(15)); /* IICSDA */

	/* Power up the sensor board */
	gpio_request_one(S3C2410_GPF(1), GPIOF_OUT_INIT_HIGH, NULL);
	gpio_free(S3C2410_GPF(1)); /* CAM_GPIO7 => nLDO_PWRDN */
	gpio_request_one(S3C2410_GPF(2), GPIOF_OUT_INIT_LOW, NULL);
	gpio_free(S3C2410_GPF(2)); /* CAM_GPIO6 => CAM_PWRDN */
Linus Torvalds's avatar
Linus Torvalds committed
133 134
}

135
static void __init nexcoder_map_io(void)
Linus Torvalds's avatar
Linus Torvalds committed
136 137 138 139
{
	s3c24xx_init_io(nexcoder_iodesc, ARRAY_SIZE(nexcoder_iodesc));
	s3c24xx_init_clocks(0);
	s3c24xx_init_uarts(nexcoder_uartcfgs, ARRAY_SIZE(nexcoder_uartcfgs));
140
	samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4);
141

Linus Torvalds's avatar
Linus Torvalds committed
142 143 144
	nexcoder_sensorboard_init();
}

145 146
static void __init nexcoder_init(void)
{
147
	s3c_i2c0_set_platdata(NULL);
148 149
	platform_add_devices(nexcoder_devices, ARRAY_SIZE(nexcoder_devices));
};
Linus Torvalds's avatar
Linus Torvalds committed
150 151

MACHINE_START(NEXCODER_2440, "NexVision - Nexcoder 2440")
152
	/* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */
153
	.atag_offset	= 0x100,
Linus Torvalds's avatar
Linus Torvalds committed
154
	.map_io		= nexcoder_map_io,
155
	.init_machine	= nexcoder_init,
156
	.init_irq	= s3c2440_init_irq,
157
	.init_time	= samsung_timer_init,
158
	.restart	= s3c244x_restart,
Linus Torvalds's avatar
Linus Torvalds committed
159
MACHINE_END