From: Binbin Zhou <zhoubb@lemote.com>
To: Ralf Baechle <ralf@linux-mips.org>
Cc: John Crispin <john@phrozen.org>,
"Steven J. Hill" <Steven.Hill@imgtec.com>,
linux-mips@linux-mips.org, Fuxin Zhang <zhangfx@lemote.com>,
Zhangjin Wu <wuzhangjin@gmail.com>,
Kelvin Cheung <keguang.zhang@gmail.com>,
Binbin Zhou <zhoubb@lemote.com>, Chunbo Cui <cuichboo@163.com>,
Huacai Chen <chenhc@lemote.com>
Subject: [PATCH RESEND v4 4/9] MIPS: Loongson: Add loongson-1A board support
Date: Thu, 19 May 2016 09:38:29 +0800 [thread overview]
Message-ID: <1463621912-9883-5-git-send-email-zhoubb@lemote.com> (raw)
In-Reply-To: <1463621912-9883-1-git-send-email-zhoubb@lemote.com>
Loongson 1A's platform devices register.
Specially, Loongson 1A use ACPI to control restart/poweroff/halt.
Signed-off-by: Chunbo Cui <cuichboo@163.com>
Signed-off-by: Binbin Zhou <zhoubb@lemote.com>
Signed-off-by: Huacai Chen <chenhc@lemote.com>
---
arch/mips/include/asm/mach-loongson32/loongson1.h | 11 +++
arch/mips/loongson32/Makefile | 6 ++
arch/mips/loongson32/common/prom.c | 6 ++
arch/mips/loongson32/common/reset.c | 6 ++
arch/mips/loongson32/common/setup.c | 42 +++++++++
arch/mips/loongson32/ls1a/Makefile | 5 ++
arch/mips/loongson32/ls1a/board.c | 105 ++++++++++++++++++++++
7 files changed, 181 insertions(+)
create mode 100644 arch/mips/loongson32/ls1a/Makefile
create mode 100644 arch/mips/loongson32/ls1a/board.c
diff --git a/arch/mips/include/asm/mach-loongson32/loongson1.h b/arch/mips/include/asm/mach-loongson32/loongson1.h
index 8ba34f9..67ca11c 100644
--- a/arch/mips/include/asm/mach-loongson32/loongson1.h
+++ b/arch/mips/include/asm/mach-loongson32/loongson1.h
@@ -158,6 +158,17 @@
#define LS1X_LPC_CFG2_REG (LS1X_LPC_REG_BASE + 0x8)
#define LS1X_LPC_CFG3_REG (LS1X_LPC_REG_BASE + 0xc)
+#define LS1X_PCIIO_BASE 0x1c000000
+#define LS1X_PCIIO_SIZE 0x00100000 /* 1M */
+
+/* reg access */
+#define ls1x_readb(addr) (*(volatile u8 *)CKSEG1ADDR(addr))
+#define ls1x_readw(addr) (*(volatile u16 *)CKSEG1ADDR(addr))
+#define ls1x_readl(addr) (*(volatile u32 *)CKSEG1ADDR(addr))
+#define ls1x_writeb(val, addr) (*(volatile u8 *)CKSEG1ADDR(addr) = (val))
+#define ls1x_writew(val, addr) (*(volatile u16 *)CKSEG1ADDR(addr) = (val))
+#define ls1x_writel(val, addr) (*(volatile u32 *)CKSEG1ADDR(addr) = (val))
+
#include <regs-clk.h>
#include <regs-mux.h>
#include <regs-pwm.h>
diff --git a/arch/mips/loongson32/Makefile b/arch/mips/loongson32/Makefile
index 5f4bd6e..c2a6559 100644
--- a/arch/mips/loongson32/Makefile
+++ b/arch/mips/loongson32/Makefile
@@ -5,6 +5,12 @@
obj-$(CONFIG_MACH_LOONGSON32) += common/
#
+# Loongson LS1A board
+#
+
+obj-$(CONFIG_LOONGSON1_LS1A) += ls1a/
+
+#
# Loongson LS1B board
#
diff --git a/arch/mips/loongson32/common/prom.c b/arch/mips/loongson32/common/prom.c
index 6860098..e07e473 100644
--- a/arch/mips/loongson32/common/prom.c
+++ b/arch/mips/loongson32/common/prom.c
@@ -64,6 +64,12 @@ void __init prom_init(void)
prom_init_cmdline();
+#ifdef CONFIG_CPU_LOONGSON1A
+ /* init base address of io space */
+ set_io_port_base((unsigned long)
+ ioremap(LS1X_PCIIO_BASE, LS1X_PCIIO_SIZE));
+#endif
+
memsize = env_or_default("memsize", DEFAULT_MEMSIZE);
highmemsize = env_or_default("highmemsize", 0x0);
diff --git a/arch/mips/loongson32/common/reset.c b/arch/mips/loongson32/common/reset.c
index 8a1d9cc..0b653eb 100644
--- a/arch/mips/loongson32/common/reset.c
+++ b/arch/mips/loongson32/common/reset.c
@@ -19,10 +19,16 @@ static void __iomem *wdt_reg_base;
static void ls1x_halt(void)
{
+#ifdef CONFIG_CPU_LOONGSON1A
+ u32 tmp;
+ tmp = ls1x_readl(LS1X_PM1_CNT_REG);
+ ls1x_writel(tmp | 0x3d00, LS1X_PM1_CNT_REG);
+#else
while (1) {
if (cpu_wait)
cpu_wait();
}
+#endif
}
static void ls1x_restart(char *command)
diff --git a/arch/mips/loongson32/common/setup.c b/arch/mips/loongson32/common/setup.c
index c3d2036..95b0155 100644
--- a/arch/mips/loongson32/common/setup.c
+++ b/arch/mips/loongson32/common/setup.c
@@ -7,13 +7,55 @@
* option) any later version.
*/
+#include <linux/ioport.h>
+#include <linux/screen_info.h>
#include <asm/bootinfo.h>
#include <prom.h>
+#define IO_MEM_RESOURCE_START 0UL
+#define IO_MEM_RESOURCE_END 0xffffffffUL
+
+#ifdef CONFIG_CPU_LOONGSON1A
+void (*__wbflush)(void);
+static void wbflush_ls1x(void)
+{
+ asm(".set\tpush\n\t"
+ ".set\tnoreorder\n\t"
+ ".set mips3\n\t"
+ "sync\n\t"
+ "nop\n\t"
+ ".set\tpop\n\t"
+ ".set mips0\n\t");
+}
+
+static void __init iomem_resource_init(void)
+{
+ iomem_resource.start = IO_MEM_RESOURCE_START;
+ iomem_resource.end = IO_MEM_RESOURCE_END;
+}
+#endif
+
void __init plat_mem_setup(void)
{
add_memory_region(0x0, (memsize << 20), BOOT_MEM_RAM);
+
+#ifdef CONFIG_CPU_LOONGSON1A
+ iomem_resource_init();
+ __wbflush = wbflush_ls1x;
+
+#if defined(CONFIG_VGA_CONSOLE)
+ screen_info = (struct screen_info) {
+ .orig_x = 0,
+ .orig_y = 25,
+ .orig_video_cols = 80,
+ .orig_video_lines = 25,
+ .orig_video_isVGA = VIDEO_TYPE_VGAC,
+ .orig_video_points = 16,
+ };
+#endif
+ add_memory_region(0x20000000, 0x30000000, BOOT_MEM_RESERVED);
+#endif
}
const char *get_system_type(void)
diff --git a/arch/mips/loongson32/ls1a/Makefile b/arch/mips/loongson32/ls1a/Makefile
new file mode 100644
index 0000000..7f2baf3
--- /dev/null
+++ b/arch/mips/loongson32/ls1a/Makefile
@@ -0,0 +1,5 @@
+#
+# Makefile for Loongson 1A based machines.
+#
+
+obj-y += board.o
diff --git a/arch/mips/loongson32/ls1a/board.c b/arch/mips/loongson32/ls1a/board.c
new file mode 100644
index 0000000..56c0dbb
--- /dev/null
+++ b/arch/mips/loongson32/ls1a/board.c
@@ -0,0 +1,105 @@
+/*
+ * Platform device support for GS232 SoCs.
+ *
+ * Copyright 2009, Su Wen <suwen@ict.ac.cn>
+ *
+ * base on Au1xxx Socs drivers by Matt Porter <mporter@kernel.crashing.org>
+ *
+ * This file is licensed under the terms of the GNU General Public
+ * License version 2. This program is licensed "as is" without any
+ * warranty of any kind, whether express or implied.
+ */
+
+#include <linux/delay.h>
+#include <linux/i2c.h>
+#include <linux/spi/spi.h>
+#include <linux/spi/flash.h>
+
+#include <irq.h>
+#include <platform.h>
+#include <loongson1.h>
+
+static struct platform_device *ls1a_platform_devices[] __initdata = {
+ &ls1x_nand_pdev,
+ &ls1x_uart_pdev,
+ &ls1x_ahci_pdev,
+ &ls1x_ohci_pdev,
+ &ls1x_ehci_pdev,
+ &ls1x_eth0_pdev,
+ &ls1x_eth1_pdev,
+ &ls1x_wat_pdev,
+ &ls1x_rtc_pdev,
+ &ls1x_audio_pdev,
+ &ls1x_fb_pdev,
+ &ls1x_i2c0_pdev,
+ &ls1x_i2c1_pdev,
+ &ls1x_i2c2_pdev,
+ &ls1x_spi0_pdev,
+ &ls1x_spi1_pdev,
+};
+
+struct i2c_board_info ls1a_pcf8563 __initdata = {
+ I2C_BOARD_INFO("pcf8563", 0x51),
+};
+
+struct flash_platform_data ls1a_spiflash_data = {
+ .name = "m25p80",
+ .parts = NULL,
+ .nr_parts = 0,
+ .type = "m25p80",
+};
+
+struct spi_board_info ls1a_spi_info[] __initdata = {
+ {
+ .modalias = "m25p80",
+ .max_speed_hz = 1000000,
+ .bus_num = 0,
+ .chip_select = 1,
+ .platform_data = &ls1a_spiflash_data,
+ },
+};
+
+void ls1a_route_setting(void)
+{
+ /*set gpio 48-61 as normal pin*/
+ ls1x_writel(ls1x_readl(LS1X_GPIO_CFG1_REG) & 0xc000ffff,
+ LS1X_GPIO_CFG1_REG);
+
+ /*set gpio mux : gmac1 to use uart0, uart1 pins*/
+ ls1x_writel((ls1x_readl(LS1X_MUX_REG_BASE) & 0x00fff5ff) | 0x0a0000c0,
+ LS1X_GPIO_CFG1_REG);
+
+ /*multiplex int0 as gpio0 */
+ ls1x_writel(ls1x_readl(LS1X_GPIO_CFG0_REG) | 0x00000001,
+ LS1X_GPIO_CFG0_REG);
+ ls1x_writel(ls1x_readl(LS1X_GPIO_OE0_REG) | 0x00000001,
+ LS1X_GPIO_OE0_REG);
+ ls1x_writel(ls1x_readl(LS1X_GPIO_IN0_REG) & 0xfffffffe,
+ LS1X_GPIO_IN0_REG);
+
+ /*i2c gpio configuartion gpio64 scl and gpio65 sda*/
+ ls1x_writel(ls1x_readl(LS1X_GPIO_CFG2_REG) & 0xfffffffd,
+ LS1X_GPIO_CFG2_REG);
+
+ mdelay(1);
+
+ /*ls1a usb reset stop*/
+ ls1x_writel(0x40000000, LS1X_LPC_CFG1_REG);
+
+ /* Reset GMAC0/1 to avoid DMA error */
+ ls1x_writel(ls1x_readl(LS1X_GMAC0_DMA_REG) | 1, LS1X_GMAC0_DMA_REG);
+ ls1x_writel(ls1x_readl(LS1X_GMAC1_DMA_REG) | 1, LS1X_GMAC1_DMA_REG);
+}
+
+int __init ls1a_platform_init(void)
+{
+ ls1a_route_setting();
+
+ i2c_register_board_info(1, &ls1a_pcf8563, 1);
+ spi_register_board_info(ls1a_spi_info, ARRAY_SIZE(ls1a_spi_info));
+
+ return platform_add_devices(ls1a_platform_devices,
+ ARRAY_SIZE(ls1a_platform_devices));
+}
+
+arch_initcall(ls1a_platform_init);
--
1.9.1
next prev parent reply other threads:[~2016-05-19 1:43 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-19 1:38 [PATCH RESEND v4 0/9] MIPS: Loongson: Add the Loongson-1A processor support Binbin Zhou
2016-05-19 1:38 ` [PATCH RESEND v4 1/9] MIPS: Loongson: Add basic Loongson-1A CPU support Binbin Zhou
2016-08-02 8:32 ` Ralf Baechle
2016-05-19 1:38 ` [PATCH RESEND v4 2/9] MIPS: Loongson: Add Loongson-1A Kconfig options Binbin Zhou
2016-05-19 1:38 ` [PATCH RESEND v4 3/9] MIPS: Loongson: Add platform devices for Loongson-1A/1B Binbin Zhou
2016-05-19 1:38 ` Binbin Zhou [this message]
2016-05-19 1:38 ` [PATCH RESEND v4 7/9] MIPS: Loongson-1A: Enable SPARSEMEN and HIGHMEM Binbin Zhou
2016-08-02 8:29 ` Ralf Baechle
2016-08-02 9:47 ` James Hogan
2016-08-02 9:47 ` James Hogan
2016-05-19 1:38 ` [PATCH RESEND v4 8/9] MIPS: Loongson-1B: Update config file Binbin Zhou
2016-05-19 1:38 ` [PATCH RESEND v4 9/9] MIPS: Loongson: Add a Loongson-1A default " Binbin Zhou
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1463621912-9883-5-git-send-email-zhoubb@lemote.com \
--to=zhoubb@lemote.com \
--cc=Steven.Hill@imgtec.com \
--cc=chenhc@lemote.com \
--cc=cuichboo@163.com \
--cc=john@phrozen.org \
--cc=keguang.zhang@gmail.com \
--cc=linux-mips@linux-mips.org \
--cc=ralf@linux-mips.org \
--cc=wuzhangjin@gmail.com \
--cc=zhangfx@lemote.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox