blob: 01aceaace314d0f57fd8d82cc453eac499f8ca4f [file] [log] [blame]
Kelvin Cheungca585cf2012-07-25 16:17:24 +02001/*
Kelvin Cheung9ec88b62016-04-06 20:34:54 +08002 * Copyright (c) 2011-2016 Zhang, Keguang <keguang.zhang@gmail.com>
Kelvin Cheungca585cf2012-07-25 16:17:24 +02003 *
Yang Ling5e73ad32016-12-04 23:05:40 +08004 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License as published by the
6 * Free Software Foundation; either version 2 of the License, or (at your
Kelvin Cheungca585cf2012-07-25 16:17:24 +02007 * option) any later version.
8 */
9
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080010#include <linux/leds.h>
11#include <linux/mtd/partitions.h>
12#include <linux/sizes.h>
13
14#include <loongson1.h>
15#include <dma.h>
16#include <nand.h>
Kelvin Cheungca585cf2012-07-25 16:17:24 +020017#include <platform.h>
18
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080019struct plat_ls1x_dma ls1x_dma_pdata = {
20 .nr_channels = 3,
21};
22
23static struct mtd_partition ls1x_nand_parts[] = {
24 {
25 .name = "kernel",
26 .offset = 0,
27 .size = SZ_16M,
28 },
29 {
30 .name = "rootfs",
31 .offset = MTDPART_OFS_APPEND,
32 .size = MTDPART_SIZ_FULL,
33 },
34};
35
36struct plat_ls1x_nand ls1x_nand_pdata = {
37 .parts = ls1x_nand_parts,
38 .nr_parts = ARRAY_SIZE(ls1x_nand_parts),
39 .hold_cycle = 0x2,
40 .wait_cycle = 0xc,
41};
42
43static const struct gpio_led ls1x_gpio_leds[] __initconst = {
44 {
45 .name = "LED9",
46 .default_trigger = "heartbeat",
47 .gpio = 38,
48 .active_low = 1,
49 .default_state = LEDS_GPIO_DEFSTATE_OFF,
50 }, {
51 .name = "LED6",
52 .default_trigger = "nand-disk",
53 .gpio = 39,
54 .active_low = 1,
55 .default_state = LEDS_GPIO_DEFSTATE_OFF,
56 },
57};
58
59static const struct gpio_led_platform_data ls1x_led_pdata __initconst = {
60 .num_leds = ARRAY_SIZE(ls1x_gpio_leds),
61 .leds = ls1x_gpio_leds,
62};
63
Kelvin Cheungca585cf2012-07-25 16:17:24 +020064static struct platform_device *ls1b_platform_devices[] __initdata = {
Kelvin Cheungf29ad102014-10-10 11:40:01 +080065 &ls1x_uart_pdev,
66 &ls1x_cpufreq_pdev,
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080067 &ls1x_dma_pdev,
Kelvin Cheungf29ad102014-10-10 11:40:01 +080068 &ls1x_eth0_pdev,
69 &ls1x_eth1_pdev,
70 &ls1x_ehci_pdev,
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080071 &ls1x_gpio0_pdev,
72 &ls1x_gpio1_pdev,
73 &ls1x_nand_pdev,
Kelvin Cheungf29ad102014-10-10 11:40:01 +080074 &ls1x_rtc_pdev,
Yang Ling5e73ad32016-12-04 23:05:40 +080075 &ls1x_wdt_pdev,
Kelvin Cheungca585cf2012-07-25 16:17:24 +020076};
77
78static int __init ls1b_platform_init(void)
79{
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080080 ls1x_serial_set_uartclk(&ls1x_uart_pdev);
81 ls1x_dma_set_platdata(&ls1x_dma_pdata);
82 ls1x_nand_set_platdata(&ls1x_nand_pdata);
Kelvin Cheungca585cf2012-07-25 16:17:24 +020083
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080084 gpio_led_register_device(-1, &ls1x_led_pdata);
Kelvin Cheungca585cf2012-07-25 16:17:24 +020085
Kelvin Cheung9ec88b62016-04-06 20:34:54 +080086 return platform_add_devices(ls1b_platform_devices,
Kelvin Cheungca585cf2012-07-25 16:17:24 +020087 ARRAY_SIZE(ls1b_platform_devices));
Kelvin Cheungca585cf2012-07-25 16:17:24 +020088}
89
90arch_initcall(ls1b_platform_init);