Received: by 10.223.164.202 with SMTP id h10csp1598686wrb; Mon, 27 Nov 2017 05:03:48 -0800 (PST) X-Google-Smtp-Source: AGs4zMZM6dms2KVFPywp5T3ysuHcElfI2Osx09tnpC4PrKAxJ5/nTDHR4Md3pRKtW/NIYH6TOkOS X-Received: by 10.99.97.76 with SMTP id v73mr35667889pgb.378.1511787828028; Mon, 27 Nov 2017 05:03:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511787828; cv=none; d=google.com; s=arc-20160816; b=NqKH8OKy/7OBQBO+Bdue5doB6XkesNV21G9R3M8e8OiZHrO71/eWVrKffDri2YYcRQ OZYtFJ/PQC/YeGkrBgSQcpuft5xdtNczwSlCh6YRFzqmm8TugXZ7o8+wE+TsBdDlElgm QNX8+AY8+jCwWAwG+WBk1QBaTNxXC63aW7AwRhASiJNIFygOSrNcJsnGQY5UUDQR0Z9i g2ptVurQh1QfHUtyukbjI2hw8CFRFXt0LEVJ6uCKxf5jzG9CHLbsIHCGy8h/I4n8ZMJ/ GIk52D0NNv+35YeB/cJ8C22eayp4rV276G31DplimUWNM3GcxdwK4h6rPjZFlbdPjBu6 F8xQ== 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=e8t8mFKoL6VLehhzjDY54VraKJw3hq+iwhY++eXsq/s=; b=mH+t130zwNlZMum+GxUgrzIdLC9s0vm6RDKdp3+gYxClhv6IMf27TO1Hz26JDk6f2Z YhluV6+iTCni9wgkGMVfPfJhIsqQinG5zaCtXrR7mopgQyBr8KV7RwlcxUT49GP4sQOQ iDMVMxXt2Rvchfr6oYHBt9cBMCGIWKUxF8Nd+NbKAPRg5Y+aoJQtBCghGTEQ1dEXMz/v knma+YNbeDuZ4HmkE4P3GPuxxeud4qvEIiX2KI38iAq0iTQYm5vJufM6dqrFH5ld89OX lkLNIAuQKxnqo2uKW/gE23pjhr1kTuSCp49haCIwtKsDHTntzCRivH9PthxdSo7+R4o5 Q/VQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Z8U9jF2K; 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 g188si23014111pgc.386.2017.11.27.05.03.36; Mon, 27 Nov 2017 05:03:48 -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=Z8U9jF2K; 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 S1752682AbdK0Myp (ORCPT + 77 others); Mon, 27 Nov 2017 07:54:45 -0500 Received: from mail-pf0-f193.google.com ([209.85.192.193]:38445 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752636AbdK0Myl (ORCPT ); Mon, 27 Nov 2017 07:54:41 -0500 Received: by mail-pf0-f193.google.com with SMTP id r62so17330325pfd.5; Mon, 27 Nov 2017 04:54:40 -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=e8t8mFKoL6VLehhzjDY54VraKJw3hq+iwhY++eXsq/s=; b=Z8U9jF2K7MYPML8HkASV8VQE975OYVv2cFnRqNOPeko0eqQceTF6J29udvA1Z9Qzlb Floqzd0YoQgG9/+OdfZosfMbBV6qq3dQLnq79JpjHlL/4JmV3u9BT75ntinLDOhtkFze +cQC+UNhYwvM0D6Ytp4UYwyMpRNQu1nfNQtNbT7iVEIlnG2Dm/CeA1nu+L+C9fA0gzb1 hRkkDsnx6t4vCt7+vqrtJyTXfJfNpJP920U0o5MedCmoUJ0ymZ/Gobvz1s3AeHl5pnpz 6i2bHtSo90xYXvTxabnpOusaoDDTrYSmPlCOenawaLGaUa0ETT5BTrr56S49emj1TKxE Tvaw== 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=e8t8mFKoL6VLehhzjDY54VraKJw3hq+iwhY++eXsq/s=; b=S9fUha7y68CBoJCRy5oKCjZycKm2yZdqfsA7jbBPchaKrGYIXky8c1UBY/8yWZXJtk qSOVWJPpMxDVmKLIYApbDFbFtkqhKZ68WidoAijwwjETWvrlWRY5bxFlnZoAg9gd4HwJ 3Tysop/hBphVImAv+ocnBfGxzH8YPC4Ea3KNw5eRlWJZwBDzdoDatiQflqw1Iv3hqjKx qbR1W1A+iEEqIqRkYFR4+NipziwstioBTkxhxk04Z/IJRFPnjXQ/uyFi2jSAha5swhw6 YUiymFYbn2xgJV+vtWbnNU1U7KW1E5iz4iX9rr3Tn/eOlNPn61WHGM+WmoAp0VshyW/m q8ug== X-Gm-Message-State: AJaThX4TqNdlnGOzS0jzesfgWmA1pqLUVdDNYArIYh3g8+NaJeVkJuy/ CIBE9gj9kfJA3e088AAU8hE= X-Received: by 10.98.196.77 with SMTP id y74mr37058570pff.186.1511787279987; Mon, 27 Nov 2017 04:54:39 -0800 (PST) Received: from app09.andestech.com ([118.163.51.199]) by smtp.gmail.com with ESMTPSA id w64sm55225459pfj.62.2017.11.27.04.54.36 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 27 Nov 2017 04:54:39 -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, deanbo422@gmail.com, devicetree@vger.kernel.org, viro@zeniv.linux.org.uk, dhowells@redhat.com, will.deacon@arm.com, daniel.lezcano@linaro.org, linux-serial@vger.kernel.org Cc: green.hu@gmail.com, Vincent Chen Subject: [PATCH v2 22/35] nds32: Device tree support Date: Mon, 27 Nov 2017 20:28:09 +0800 Message-Id: <1055af0e8b98571b4461d6f899d043fe7f17408b.1511785528.git.green.hu@gmail.com> 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 This patch adds support for device tree. 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..4181060 --- /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 = "earlycon console=ttyS0,38400n8 debug loglevel=7"; + stdout-path = &serial0; + }; + + memory@0 { + device_type = "memory"; + reg = <0x00000000 0x40000000>; + }; + + cpu { + device_type = "cpu"; + compatible = "andestech,n13", "andestech,nds32v3"; + clock-frequency = <60000000>; + }; + + intc: interrupt-controller { + compatible = "andestech,ativic32"; + #interrupt-cells = <1>; + interrupt-controller; + }; + + serial0: serial@f0300000 { + compatible = "andestech,uart16550", "ns16550a"; + reg = <0xf0300000 0x1000>; + interrupts = <8>; + clock-frequency = <14745600>; + reg-shift = <2>; + reg-offset = <32>; + no-loopback-test = <1>; + }; + + timer0: timer@f0400000 { + compatible = "andestech,atcpit100"; + reg = <0xf0400000 0x1000>; + interrupts = <2>; + clock-frequency = <30000000>; + cycle-count-offset = <0x38>; + cycle-count-down; + }; + + mac0: mac@e0100000 { + compatible = "andestech,atmac100"; + reg = <0xe0100000 0x1000>; + interrupts = <18>; + }; + +}; diff --git a/arch/nds32/boot/dts/ag101p.dts b/arch/nds32/boot/dts/ag101p.dts new file mode 100644 index 0000000..f1cb540 --- /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 = "earlycon console=ttyS0,38400n8 debug loglevel=7"; + stdout-path = &serial0; + }; + + memory@0 { + device_type = "memory"; + reg = <0x00000000 0x40000000>; + }; + + cpu@0 { + device_type = "cpu"; + compatible = "andestech,n13"; + clock-frequency = <60000000>; + next-level-cache = <&L2>; + }; + + intc: interrupt-controller { + compatible = "andestech,ativic32"; + #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 1585673826055193074@xxx Sat Dec 02 12:06:42 +0000 2017 X-GM-THRID: 1585335308354949366 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread