Received: by 10.223.164.202 with SMTP id h10csp1192838wrb; Tue, 7 Nov 2017 23:50:45 -0800 (PST) X-Google-Smtp-Source: ABhQp+QzzxaAhDTKX8NHe20VW/eFVfL1gTbIOJv5euX08u6OEWkoGzciazJ9yWX9dAENgy71yVWZ X-Received: by 10.159.254.12 with SMTP id r12mr1305262pls.49.1510127445294; Tue, 07 Nov 2017 23:50:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510127445; cv=none; d=google.com; s=arc-20160816; b=z5Nx6FHotcanHNxryk/pLeaTsYaaDRySk7/PnFf583eTdFHi+gX5L54/dgVAtOjNlL lwD6NIrlF16n54JsGMGZpjip8e8CIk9myrbT65HcZjkryJZ53nHQ2j1u0FVzHp3yDVK0 XVO57b2tBdSsIM4cCc2WDS8cgtdaCpan0m9Z45GBxrEsSViX8oyrFoSpRxH1/qeSq5L6 gnql91rTjrvgQY+Co6uukAqPz3meYeyxPQiD+L0bXeUtojz/nVbzcG7uJv/Fq/01sJxO s0RRJO8AmhVNYtTp7YkYwXb7iBCXFpIKds+tdowZMumrkHbjYmxi4LB2b7JWnNmn0VIr a8pQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=Vj8h6axVq03dz52m2yXMRE7RcD/UZbpYo5W/WoTSRnY=; b=SutsxM9bw79BPJi0q798BPGo24Mc6WTf0seL99ERf+xEoPUXGwS9+XLlAU5OyEqhH6 VHHp6ZUILP8TB+e5KClNqFgo5sJiut9t9B0lq1XYTPvoNvIXOQW6RJYN+1YU0zyE/RWr DSVbbIhlrpbdoMwo7QjdhTLHWaZ2CA+MrLVw6s159cxx2aP3QY0VY8s0yeGr9WxJqeH+ kEzEqUA2Aspj6fT7Duii88A0i4raIjuJ95saBV0q2u5WGPk9OBPsSRb8AsaKaVAEqN54 jz+sH+qMClZILUgMnIzzQ6xRwMkY0HMW6e01d/BYovK6UuzBK6Hyv9tBTCkblqerlDC0 d82Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=t5EWIEC4; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t17si3198379plo.215.2017.11.07.23.50.32; Tue, 07 Nov 2017 23:50:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=t5EWIEC4; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932078AbdKHGY2 (ORCPT + 91 others); Wed, 8 Nov 2017 01:24:28 -0500 Received: from mail-pl0-f66.google.com ([209.85.160.66]:49461 "EHLO mail-pl0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754213AbdKHGUz (ORCPT ); Wed, 8 Nov 2017 01:20:55 -0500 Received: by mail-pl0-f66.google.com with SMTP id f2so666664plj.6; Tue, 07 Nov 2017 22:20:55 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :in-reply-to:references; bh=Vj8h6axVq03dz52m2yXMRE7RcD/UZbpYo5W/WoTSRnY=; b=t5EWIEC4eYSazocqqzhyv+BQGDll8bMDIGCk5HXQmoyDs3z5iaDLxEm7HdFsMMpECi 4zZw6Z9v0FSFMVUmBOpAEbR3XH63PpDlPFPuifMO+q+oHL4H62jeULQRMVgO0RitSKal A3j0zrPPEHsvljBHx9cPOWnhuA6lGhv/jzroteiT8j92cX8zO3E0HVEwwQpIA8orKsJj pHbmdf9CbVhaC4uTzUilZq6hxP7Y1fryY/sBvdIZTBvB56KqdGPMcFPz+A1FeVS+gIun TC67hsgqRIngkXmizurF4drQgOzTXSeoc8s4Fm3A2VUzm8FN8yDBB1Y+C/CpfKgnrD4d y0iw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:in-reply-to:references; bh=Vj8h6axVq03dz52m2yXMRE7RcD/UZbpYo5W/WoTSRnY=; b=gEtvJ0eWZRM0nlcO5X9A1HcnXznx925hZNyxVPUScB8M+4zuknvL/cmTFYlYZgX6wc Hiw0V7AdIQU6Igfm/y50lG5H1I+7lG5+lltQ+CvKvfUaWwp5Xq7RdU2P94Xudbd2Adgu AUtk/+vnqsV4HOdkHuOFWMbHzAzvS7lSd109cZig0ch7xrPewHBH0Jatm8iJkpw6S9EK prues2DJxlMLQOvoSXququMXvOcqEKcf4hUI6FppJFOJ9XKqkpFRBpA86nTyy5JjlaaH o7TFQtw0mgk73ql10v+vxITxCH3emyjK8LuHn71O5U9BGg8NZMqVTIdPabMWDbNKak6H HlJw== X-Gm-Message-State: AJaThX72jYjuaAfoqONSorpXGQdYbMtV0bz4MmuLjcUee/TAtrkj2xKG Cu0sPM0T9z2kC7xsXmkiXwc= X-Received: by 10.159.206.193 with SMTP id x1mr1251162plo.319.1510122054868; Tue, 07 Nov 2017 22:20:54 -0800 (PST) Received: from app09.andestech.com ([118.163.51.199]) by smtp.gmail.com with ESMTPSA id a4sm6581339pfj.72.2017.11.07.22.20.52 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 07 Nov 2017 22:20:54 -0800 (PST) From: Greentime Hu To: greentime@andestech.com, linux-kernel@vger.kernel.org, arnd@arndb.de, linux-arch@vger.kernel.org, tglx@linutronix.de, jason@lakedaemon.net, marc.zyngier@arm.com, robh+dt@kernel.org, netdev@vger.kernel.org Cc: green.hu@gmail.com, Vincent Chen Subject: [PATCH 23/31] nds32: Device tree support Date: Wed, 8 Nov 2017 13:55:11 +0800 Message-Id: X-Mailer: git-send-email 1.7.9.5 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greentime Hu Signed-off-by: Vincent Chen Signed-off-by: Greentime Hu --- arch/nds32/boot/dts/Makefile | 8 ++++++ arch/nds32/boot/dts/ae3xx.dts | 55 ++++++++++++++++++++++++++++++++++++ arch/nds32/boot/dts/ag101p.dts | 60 ++++++++++++++++++++++++++++++++++++++++ arch/nds32/kernel/devtree.c | 45 ++++++++++++++++++++++++++++++ 4 files changed, 168 insertions(+) create mode 100644 arch/nds32/boot/dts/Makefile create mode 100644 arch/nds32/boot/dts/ae3xx.dts create mode 100644 arch/nds32/boot/dts/ag101p.dts create mode 100644 arch/nds32/kernel/devtree.c diff --git a/arch/nds32/boot/dts/Makefile b/arch/nds32/boot/dts/Makefile new file mode 100644 index 0000000..d31faa8 --- /dev/null +++ b/arch/nds32/boot/dts/Makefile @@ -0,0 +1,8 @@ +ifneq '$(CONFIG_NDS32_BUILTIN_DTB)' '""' +BUILTIN_DTB := $(patsubst "%",%,$(CONFIG_NDS32_BUILTIN_DTB)).dtb.o +else +BUILTIN_DTB := +endif +obj-$(CONFIG_OF) += $(BUILTIN_DTB) + +clean-files := *.dtb *.dtb.S diff --git a/arch/nds32/boot/dts/ae3xx.dts b/arch/nds32/boot/dts/ae3xx.dts new file mode 100644 index 0000000..b6c85dc --- /dev/null +++ b/arch/nds32/boot/dts/ae3xx.dts @@ -0,0 +1,55 @@ +/dts-v1/; +/ { + compatible = "nds32 ae3xx"; + #address-cells = <1>; + #size-cells = <1>; + interrupt-parent = <&intc>; + + chosen { + bootargs = "console=ttyS0,38400n8 earlyprintk=uart8250-32bit,0xf0300000 debug loglevel=7"; + }; + + memory@0 { + device_type = "memory"; + reg = <0x00000000 0x40000000>; + }; + + cpus { + cpu@0 { + device_type = "cpu"; + compatible = "andestech,n13", "andestech,n15"; + }; + }; + + intc: interrupt-controller { + compatible = "andestech,ativic32"; + #interrupt-cells = <2>; + interrupt-controller; + }; + + serial0: serial@f0300000 { + compatible = "andestech,uart16550", "ns16550a"; + reg = <0xf0300000 0x1000>; + interrupts = <8 4>; + clock-frequency = <14745600>; + reg-shift = <2>; + reg-offset = <32>; + no-loopback-test = <1>; + }; + + timer0: timer@f0400000 { + compatible = "andestech,atcpit100"; + reg = <0xf0400000 0x1000>; + interrupts = <2 4>; + clock-frequency = <30000000>; + cycle-count-offset = <0x38>; + cycle-count-down; + }; + + mac0: mac@e0100000 { + compatible = "andestech,atmac100"; + reg = <0xe0100000 0x1000>; + interrupts = <18 4>; + }; + +}; diff --git a/arch/nds32/boot/dts/ag101p.dts b/arch/nds32/boot/dts/ag101p.dts new file mode 100644 index 0000000..b34760b --- /dev/null +++ b/arch/nds32/boot/dts/ag101p.dts @@ -0,0 +1,60 @@ +/dts-v1/; +/ { + compatible = "nds32 ag101p"; + #address-cells = <1>; + #size-cells = <1>; + interrupt-parent = <&intc>; + + chosen { + bootargs = "console=ttyS0,38400n8 earlyprintk=uart8250-32bit,0x99600000 debug loglevel=7"; + }; + + memory@0 { + device_type = "memory"; + reg = <0x00000000 0x40000000>; + }; + + cpus { + cpu@0 { + device_type = "cpu"; + compatible = "andestech,n13"; + next-level-cache = <&L2>; + }; + }; + + intc: interrupt-controller { + compatible = "andestech,atnointc010"; + #interrupt-cells = <2>; + interrupt-controller; + }; + + serial0: serial@99600000 { + compatible = "andestech,uart16550", "ns16550a"; + reg = <0x99600000 0x1000>; + interrupts = <7 4>; + clock-frequency = <14745600>; + reg-shift = <2>; + no-loopback-test = <1>; + }; + + timer0: timer@98400000 { + compatible = "andestech,atftmr010"; + reg = <0x98400000 0x1000>; + interrupts = <19 4>; + clock-frequency = <15000000>; + cycle-count-offset = <0x20>; + }; + + mac0: mac@90900000 { + compatible = "andestech,atmac100"; + reg = <0x90900000 0x1000>; + interrupts = <25 4>; + }; + + L2: l2-cache { + compatible = "andestech,atl2c"; + reg = <0x90f00000 0x1000>; + cache-unified; + cache-level = <2>; + }; +}; diff --git a/arch/nds32/kernel/devtree.c b/arch/nds32/kernel/devtree.c new file mode 100644 index 0000000..2af0f1c --- /dev/null +++ b/arch/nds32/kernel/devtree.c @@ -0,0 +1,45 @@ +/* + * Copyright (C) 2005-2017 Andes Technology Corporation + * + * 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. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#include +#include +#include + +void __init early_init_dt_add_memory_arch(u64 base, u64 size) +{ + size &= PAGE_MASK; + memblock_add_node(base, size, 0); +} + +void *__init early_init_dt_alloc_memory_arch(u64 size, u64 align) +{ + return alloc_bootmem_align(size, align); +} + +void __init early_init_devtree(void *params) +{ + if (!params || !early_init_dt_scan(params)) { + pr_crit("\n" + "Error: invalid device tree blob at (virtual address 0x%p)\n" + "The dtb must be 8-byte aligned and must not exceed 8 KB in size\n" + "\nPlease check your bootloader.", params); + + while (true) + cpu_relax(); + } + + dump_stack_set_arch_desc("%s (DT)", of_flat_dt_get_machine_name()); +} -- 1.7.9.5 From 1588585795091640290@xxx Wed Jan 03 15:31:12 +0000 2018 X-GM-THRID: 1585902465120736004 X-Gmail-Labels: Inbox,Category Forums,Downloaded_2018-01