From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753463AbeCUUEt (ORCPT ); Wed, 21 Mar 2018 16:04:49 -0400 Received: from mail.micronovasrl.com ([212.103.203.10]:45548 "EHLO mail.micronovasrl.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753271AbeCUUED (ORCPT ); Wed, 21 Mar 2018 16:04:03 -0400 Authentication-Results: mail.micronovasrl.com (amavisd-new); dkim=pass reason="pass (just generated, assumed good)" header.d=micronovasrl.com X-Spam-Flag: NO X-Spam-Score: -2.9 From: Giulio Benetti To: Thierry Reding Cc: David Airlie , Maxime Ripard , Chen-Yu Tsai , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, Giulio Benetti Subject: [PATCH 6/7] ARM: dts: sun7i: Add dts file for the A20-linova1-4_3 HMI Date: Wed, 21 Mar 2018 21:03:12 +0100 Message-Id: <1521662593-25468-6-git-send-email-giulio.benetti@micronovasrl.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1521662593-25468-1-git-send-email-giulio.benetti@micronovasrl.com> References: <1521662593-25468-1-git-send-email-giulio.benetti@micronovasrl.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The A20-Linova1-4_3 HMI, also called Q027_2_A which is printed on production label, is an industrial Human Machine Interface. It features: - 512MB DDR RAM - 1 Sd-card >= 4GB - 1 Usb otg(programmable via software) with A-Usb Connector - 1 Usb host - 1 Buzzer - 1 Input for LiPo - 1 Relay to signal absence of power supply - 1 External Rtc with 56 bytes of ram + CR2032 battery - 1 4.3" 24-bits Tft 480x272 with PCap on - 1 Mono audio 1-watt amplifier - 1 RS485 port - 1 Power On Line through +12Vdc reaching 57.600baud, from where it can be supplied and placed in a network of 50 units - exposed jtag pins HMI is supplied from +12Vdc. Ethernet is absent, so for debugging, need to enable rndis on Usb otg port through an A-A usb cable. It comes in different flavours for connector types and can be found with umounted features as requested by customers. Signed-off-by: Giulio Benetti --- .../devicetree/bindings/arm/micronova.txt | 6 + arch/arm/boot/dts/Makefile | 1 + arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts | 192 +++++++++++++++++++++ 3 files changed, 199 insertions(+) create mode 100644 Documentation/devicetree/bindings/arm/micronova.txt create mode 100644 arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts diff --git a/Documentation/devicetree/bindings/arm/micronova.txt b/Documentation/devicetree/bindings/arm/micronova.txt new file mode 100644 index 0000000..35c4127 --- /dev/null +++ b/Documentation/devicetree/bindings/arm/micronova.txt @@ -0,0 +1,6 @@ +Micronova Device Tree Bindings +--------------------------- + +A20-LiNova1-4_3 HMI +Required root node properties: + - compatible = "micronova,a20-linova1-ctp-4_3i", "allwinner,sun7i-a20"; diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile index ade7a38..c45a4f25 100644 --- a/arch/arm/boot/dts/Makefile +++ b/arch/arm/boot/dts/Makefile @@ -941,6 +941,7 @@ dtb-$(CONFIG_MACH_SUN7I) += \ sun7i-a20-lamobo-r1.dtb \ sun7i-a20-m3.dtb \ sun7i-a20-mk808c.dtb \ + sun7i-a20-linova1-ctp-4_3i.dtb\ sun7i-a20-olimex-som-evb.dtb \ sun7i-a20-olinuxino-lime.dtb \ sun7i-a20-olinuxino-lime2.dtb \ diff --git a/arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts b/arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts new file mode 100644 index 0000000..cd4ac73 --- /dev/null +++ b/arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts @@ -0,0 +1,192 @@ +/* + * This is based on sun7i-a20-linova1-ctp-4_3i.dts + * + * Copyright 2014 - Hans de Goede + * Copyright (c) 2014 FUKAUMI Naoki + * Copyright (c) 2018 Giulio Benetti + * + * This file is dual-licensed: you can use it either under the terms + * of the GPL or the X11 license, at your option. Note that this dual + * licensing only applies to this file, and not this project as a + * whole. + * + * a) This file is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of the + * License, or (at your option) any later version. + * + * This file 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. + * + * Or, alternatively, + * + * b) Permission is hereby granted, free of charge, to any person + * obtaining a copy of this software and associated documentation + * files (the "Software"), to deal in the Software without + * restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, sublicense, and/or + * sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following + * conditions: + * + * The above copyright notice and this permission notice shall be + * included in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES + * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT + * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, + * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR + * OTHER DEALINGS IN THE SOFTWARE. + */ + +/dts-v1/; +#include "sun7i-a20.dtsi" +#include "sunxi-common-regulators.dtsi" + +#include +#include + +/ { + model = "Micronova srl LiNova1 CTP 4.3i"; + compatible = "micronova,a20-linova1-ctp-4_3i", "allwinner,sun7i-a20"; + + aliases { + serial0 = &uart0; + }; + + chosen { + stdout-path = "serial0:115200n8"; + }; + + panel: panel { + compatible = "cdtech,s043wq26h-ct7", "simple-panel"; + power-supply = <®_vcc3v3>; + #address-cells = <1>; + #size-cells = <0>; + + port@0 { + reg = <0>; + #address-cells = <1>; + #size-cells = <0>; + + panel_input: endpoint@0 { + reg = <0>; + remote-endpoint = <&tcon0_out_panel>; + }; + }; + }; +}; + +&ehci0 { + status = "okay"; +}; + +&ehci1 { + status = "okay"; +}; + +&i2c0 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c0_pins_a>; + status = "okay"; + + axp209: pmic@34 { + compatible = "x-powers,axp209"; + reg = <0x34>; + interrupt-parent = <&nmi_intc>; + interrupts = <0 IRQ_TYPE_LEVEL_LOW>; + + interrupt-controller; + #interrupt-cells = <1>; + }; +}; + +&i2c2 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c2_pins_a>; + status = "okay"; + + ft5x: touchscreen@38 { + compatible = "edt,edt-ft5306"; + reg = <0x38>; + interrupt-parent = <&pio>; + interrupts = <7 2 IRQ_TYPE_EDGE_FALLING>; /* PH2 */ + reset-gpios = <&pio 7 3 GPIO_ACTIVE_LOW>; /* PH3 */ + touchscreen-size-x = <480>; + touchscreen-size-y = <272>; + }; +}; + +&mmc0 { + pinctrl-names = "default"; + pinctrl-0 = <&mmc0_pins_a>; + vmmc-supply = <®_vcc3v3>; + bus-width = <4>; + cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */ + cd-inverted; + status = "okay"; +}; + +&ohci0 { + status = "okay"; +}; + +&ohci1 { + status = "okay"; +}; + +&otg_sram { + status = "okay"; +}; + +®_usb0_vbus { + status = "okay"; +}; + +®_usb1_vbus { + status = "okay"; +}; + +&uart0 { + pinctrl-names = "default"; + pinctrl-0 = <&uart0_pins_a>; + status = "okay"; +}; + +&usb_otg { + dr_mode = "otg"; + status = "okay"; +}; + +&usbphy { + pinctrl-names = "default"; + usb0_vbus-supply = <®_usb0_vbus>; + usb1_vbus-supply = <®_usb1_vbus>; + status = "okay"; +}; + +&be0 { + status = "okay"; +}; + +&de { + status = "okay"; +}; + +&tcon0 { + pinctrl-names = "default"; + pinctrl-0 = <&lcd0_rgb888_pins>; + status = "okay"; +}; + +&tcon0_out { + tcon0_out_panel: endpoint@0 { + reg = <0>; + remote-endpoint = <&panel_input>; + }; +}; -- 2.7.4 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Giulio Benetti Subject: [PATCH 6/7] ARM: dts: sun7i: Add dts file for the A20-linova1-4_3 HMI Date: Wed, 21 Mar 2018 21:03:12 +0100 Message-ID: <1521662593-25468-6-git-send-email-giulio.benetti@micronovasrl.com> References: <1521662593-25468-1-git-send-email-giulio.benetti@micronovasrl.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: <1521662593-25468-1-git-send-email-giulio.benetti@micronovasrl.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: Thierry Reding Cc: devicetree@vger.kernel.org, David Airlie , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Chen-Yu Tsai , Maxime Ripard , Giulio Benetti , linux-arm-kernel@lists.infradead.org List-Id: devicetree@vger.kernel.org VGhlIEEyMC1MaW5vdmExLTRfMyBITUksIGFsc28gY2FsbGVkIFEwMjdfMl9BIHdoaWNoIGlzIHBy aW50ZWQgb24KcHJvZHVjdGlvbiBsYWJlbCwgaXMgYW4gaW5kdXN0cmlhbCBIdW1hbiBNYWNoaW5l IEludGVyZmFjZS4KSXQgZmVhdHVyZXM6Ci0gNTEyTUIgRERSIFJBTQotIDEgU2QtY2FyZCA+PSA0 R0IKLSAxIFVzYiBvdGcocHJvZ3JhbW1hYmxlIHZpYSBzb2Z0d2FyZSkgd2l0aCBBLVVzYiBDb25u ZWN0b3IKLSAxIFVzYiBob3N0Ci0gMSBCdXp6ZXIKLSAxIElucHV0IGZvciBMaVBvCi0gMSBSZWxh eSB0byBzaWduYWwgYWJzZW5jZSBvZiBwb3dlciBzdXBwbHkKLSAxIEV4dGVybmFsIFJ0YyB3aXRo IDU2IGJ5dGVzIG9mIHJhbSArIENSMjAzMiBiYXR0ZXJ5Ci0gMSA0LjMiIDI0LWJpdHMgVGZ0IDQ4 MHgyNzIgd2l0aCBQQ2FwIG9uCi0gMSBNb25vIGF1ZGlvIDEtd2F0dCBhbXBsaWZpZXIKLSAxIFJT NDg1IHBvcnQKLSAxIFBvd2VyIE9uIExpbmUgdGhyb3VnaCArMTJWZGMgcmVhY2hpbmcgNTcuNjAw YmF1ZCwKICBmcm9tIHdoZXJlIGl0IGNhbiBiZSBzdXBwbGllZCBhbmQgcGxhY2VkIGluIGEgbmV0 d29yayBvZiA1MCB1bml0cwotIGV4cG9zZWQganRhZyBwaW5zCgpITUkgaXMgc3VwcGxpZWQgZnJv bSArMTJWZGMuCkV0aGVybmV0IGlzIGFic2VudCwgc28gZm9yIGRlYnVnZ2luZywgbmVlZCB0byBl bmFibGUgcm5kaXMgb24gVXNiIG90Zwpwb3J0IHRocm91Z2ggYW4gQS1BIHVzYiBjYWJsZS4KSXQg Y29tZXMgaW4gZGlmZmVyZW50IGZsYXZvdXJzIGZvciBjb25uZWN0b3IgdHlwZXMgYW5kIGNhbiBi ZSBmb3VuZCB3aXRoCnVtb3VudGVkIGZlYXR1cmVzIGFzIHJlcXVlc3RlZCBieSBjdXN0b21lcnMu CgpTaWduZWQtb2ZmLWJ5OiBHaXVsaW8gQmVuZXR0aSA8Z2l1bGlvLmJlbmV0dGlAbWljcm9ub3Zh c3JsLmNvbT4KLS0tCiAuLi4vZGV2aWNldHJlZS9iaW5kaW5ncy9hcm0vbWljcm9ub3ZhLnR4dCAg ICAgICAgICB8ICAgNiArCiBhcmNoL2FybS9ib290L2R0cy9NYWtlZmlsZSAgICAgICAgICAgICAg ICAgICAgICAgICB8ICAgMSArCiBhcmNoL2FybS9ib290L2R0cy9zdW43aS1hMjAtbGlub3ZhMS1j dHAtNF8zaS5kdHMgICB8IDE5MiArKysrKysrKysrKysrKysrKysrKysKIDMgZmlsZXMgY2hhbmdl ZCwgMTk5IGluc2VydGlvbnMoKykKIGNyZWF0ZSBtb2RlIDEwMDY0NCBEb2N1bWVudGF0aW9uL2Rl dmljZXRyZWUvYmluZGluZ3MvYXJtL21pY3Jvbm92YS50eHQKIGNyZWF0ZSBtb2RlIDEwMDY0NCBh cmNoL2FybS9ib290L2R0cy9zdW43aS1hMjAtbGlub3ZhMS1jdHAtNF8zaS5kdHMKCmRpZmYgLS1n aXQgYS9Eb2N1bWVudGF0aW9uL2RldmljZXRyZWUvYmluZGluZ3MvYXJtL21pY3Jvbm92YS50eHQg Yi9Eb2N1bWVudGF0aW9uL2RldmljZXRyZWUvYmluZGluZ3MvYXJtL21pY3Jvbm92YS50eHQKbmV3 IGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMDAwMDAwMC4uMzVjNDEyNwotLS0gL2Rldi9udWxsCisr KyBiL0RvY3VtZW50YXRpb24vZGV2aWNldHJlZS9iaW5kaW5ncy9hcm0vbWljcm9ub3ZhLnR4dApA QCAtMCwwICsxLDYgQEAKK01pY3Jvbm92YSBEZXZpY2UgVHJlZSBCaW5kaW5ncworLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tCisKK0EyMC1MaU5vdmExLTRfMyBITUkKK1JlcXVpcmVkIHJvb3Qg bm9kZSBwcm9wZXJ0aWVzOgorICAgIC0gY29tcGF0aWJsZSA9ICJtaWNyb25vdmEsYTIwLWxpbm92 YTEtY3RwLTRfM2kiLCAiYWxsd2lubmVyLHN1bjdpLWEyMCI7CmRpZmYgLS1naXQgYS9hcmNoL2Fy bS9ib290L2R0cy9NYWtlZmlsZSBiL2FyY2gvYXJtL2Jvb3QvZHRzL01ha2VmaWxlCmluZGV4IGFk ZTdhMzguLmM0NWE0ZjI1IDEwMDY0NAotLS0gYS9hcmNoL2FybS9ib290L2R0cy9NYWtlZmlsZQor KysgYi9hcmNoL2FybS9ib290L2R0cy9NYWtlZmlsZQpAQCAtOTQxLDYgKzk0MSw3IEBAIGR0Yi0k KENPTkZJR19NQUNIX1NVTjdJKSArPSBcCiAJc3VuN2ktYTIwLWxhbW9iby1yMS5kdGIgXAogCXN1 bjdpLWEyMC1tMy5kdGIgXAogCXN1bjdpLWEyMC1tazgwOGMuZHRiIFwKKwlzdW43aS1hMjAtbGlu b3ZhMS1jdHAtNF8zaS5kdGJcCiAJc3VuN2ktYTIwLW9saW1leC1zb20tZXZiLmR0YiBcCiAJc3Vu N2ktYTIwLW9saW51eGluby1saW1lLmR0YiBcCiAJc3VuN2ktYTIwLW9saW51eGluby1saW1lMi5k dGIgXApkaWZmIC0tZ2l0IGEvYXJjaC9hcm0vYm9vdC9kdHMvc3VuN2ktYTIwLWxpbm92YTEtY3Rw LTRfM2kuZHRzIGIvYXJjaC9hcm0vYm9vdC9kdHMvc3VuN2ktYTIwLWxpbm92YTEtY3RwLTRfM2ku ZHRzCm5ldyBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDAwMDAwMDAuLmNkNGFjNzMKLS0tIC9kZXYv bnVsbAorKysgYi9hcmNoL2FybS9ib290L2R0cy9zdW43aS1hMjAtbGlub3ZhMS1jdHAtNF8zaS5k dHMKQEAgLTAsMCArMSwxOTIgQEAKKy8qCisgKiBUaGlzIGlzIGJhc2VkIG9uIHN1bjdpLWEyMC1s aW5vdmExLWN0cC00XzNpLmR0cworICoKKyAqIENvcHlyaWdodCAyMDE0IC0gSGFucyBkZSBHb2Vk ZSA8aGRlZ29lZGVAcmVkaGF0LmNvbT4KKyAqIENvcHlyaWdodCAoYykgMjAxNCBGVUtBVU1JIE5h b2tpIDxuYW9ic2RAZ21haWwuY29tPgorICogQ29weXJpZ2h0IChjKSAyMDE4IEdpdWxpbyBCZW5l dHRpIDxnaXVsaW8uYmVuZXR0aUBtaWNyb25vdmFzcmwuY29tPgorICoKKyAqIFRoaXMgZmlsZSBp cyBkdWFsLWxpY2Vuc2VkOiB5b3UgY2FuIHVzZSBpdCBlaXRoZXIgdW5kZXIgdGhlIHRlcm1zCisg KiBvZiB0aGUgR1BMIG9yIHRoZSBYMTEgbGljZW5zZSwgYXQgeW91ciBvcHRpb24uIE5vdGUgdGhh dCB0aGlzIGR1YWwKKyAqIGxpY2Vuc2luZyBvbmx5IGFwcGxpZXMgdG8gdGhpcyBmaWxlLCBhbmQg bm90IHRoaXMgcHJvamVjdCBhcyBhCisgKiB3aG9sZS4KKyAqCisgKiAgYSkgVGhpcyBmaWxlIGlz IGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vcgorICogICAgIG1v ZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNl IGFzCisgKiAgICAgcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVp dGhlciB2ZXJzaW9uIDIgb2YgdGhlCisgKiAgICAgTGljZW5zZSwgb3IgKGF0IHlvdXIgb3B0aW9u KSBhbnkgbGF0ZXIgdmVyc2lvbi4KKyAqCisgKiAgICAgVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVk IGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsCisgKiAgICAgYnV0IFdJVEhPVVQg QU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKKyAqICAg ICBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBT ZWUgdGhlCisgKiAgICAgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWls cy4KKyAqCisgKiBPciwgYWx0ZXJuYXRpdmVseSwKKyAqCisgKiAgYikgUGVybWlzc2lvbiBpcyBo ZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24KKyAqICAgICBvYnRh aW5pbmcgYSBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlv bgorICogICAgIGZpbGVzICh0aGUgIlNvZnR3YXJlIiksIHRvIGRlYWwgaW4gdGhlIFNvZnR3YXJl IHdpdGhvdXQKKyAqICAgICByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlv biB0aGUgcmlnaHRzIHRvIHVzZSwKKyAqICAgICBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNo LCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3IKKyAqICAgICBzZWxsIGNvcGllcyBvZiB0 aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZQorICogICAgIFNv ZnR3YXJlIGlzIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nCisg KiAgICAgY29uZGl0aW9uczoKKyAqCisgKiAgICAgVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2Ug YW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUKKyAqICAgICBpbmNsdWRlZCBpbiBh bGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS4KKyAqCisg KiAgICAgVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEICJBUyBJUyIsIFdJVEhPVVQgV0FSUkFOVFkg T0YgQU5ZIEtJTkQsCisgKiAgICAgRVhQUkVTUyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5P VCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTCisgKiAgICAgT0YgTUVSQ0hBTlRBQklMSVRZLCBG SVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQKKyAqICAgICBOT05JTkZSSU5HRU1F TlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVAorICogICAgIEhP TERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVIgTElBQklMSVRZ LAorICogICAgIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVS V0lTRSwgQVJJU0lORworICogICAgIEZST00sIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEgg VEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IKKyAqICAgICBPVEhFUiBERUFMSU5HUyBJTiBUSEUg U09GVFdBUkUuCisgKi8KKworL2R0cy12MS87CisjaW5jbHVkZSAic3VuN2ktYTIwLmR0c2kiCisj aW5jbHVkZSAic3VueGktY29tbW9uLXJlZ3VsYXRvcnMuZHRzaSIKKworI2luY2x1ZGUgPGR0LWJp bmRpbmdzL2dwaW8vZ3Bpby5oPgorI2luY2x1ZGUgPGR0LWJpbmRpbmdzL2ludGVycnVwdC1jb250 cm9sbGVyL2lycS5oPgorCisvIHsKKwltb2RlbCA9ICJNaWNyb25vdmEgc3JsIExpTm92YTEgQ1RQ IDQuM2kiOworCWNvbXBhdGlibGUgPSAibWljcm9ub3ZhLGEyMC1saW5vdmExLWN0cC00XzNpIiwg ImFsbHdpbm5lcixzdW43aS1hMjAiOworCisJYWxpYXNlcyB7CisJCXNlcmlhbDAgPSAmdWFydDA7 CisJfTsKKworCWNob3NlbiB7CisJCXN0ZG91dC1wYXRoID0gInNlcmlhbDA6MTE1MjAwbjgiOwor CX07CisKKwlwYW5lbDogcGFuZWwgeworCQljb21wYXRpYmxlID0gImNkdGVjaCxzMDQzd3EyNmgt Y3Q3IiwgInNpbXBsZS1wYW5lbCI7CisJCXBvd2VyLXN1cHBseSA9IDwmcmVnX3ZjYzN2Mz47CisJ CSNhZGRyZXNzLWNlbGxzID0gPDE+OworCQkjc2l6ZS1jZWxscyA9IDwwPjsKKworCQlwb3J0QDAg eworCQkJcmVnID0gPDA+OworCQkJI2FkZHJlc3MtY2VsbHMgPSA8MT47CisJCQkjc2l6ZS1jZWxs cyA9IDwwPjsKKworCQkJcGFuZWxfaW5wdXQ6IGVuZHBvaW50QDAgeworCQkJCXJlZyA9IDwwPjsK KwkJCQlyZW1vdGUtZW5kcG9pbnQgPSA8JnRjb24wX291dF9wYW5lbD47CisJCQl9OworCQl9Owor CX07Cit9OworCismZWhjaTAgeworCXN0YXR1cyA9ICJva2F5IjsKK307CisKKyZlaGNpMSB7CisJ c3RhdHVzID0gIm9rYXkiOworfTsKKworJmkyYzAgeworCXBpbmN0cmwtbmFtZXMgPSAiZGVmYXVs dCI7CisJcGluY3RybC0wID0gPCZpMmMwX3BpbnNfYT47CisJc3RhdHVzID0gIm9rYXkiOworCisJ YXhwMjA5OiBwbWljQDM0IHsKKwkJY29tcGF0aWJsZSA9ICJ4LXBvd2VycyxheHAyMDkiOworCQly ZWcgPSA8MHgzND47CisJCWludGVycnVwdC1wYXJlbnQgPSA8Jm5taV9pbnRjPjsKKwkJaW50ZXJy dXB0cyA9IDwwIElSUV9UWVBFX0xFVkVMX0xPVz47CisKKwkJaW50ZXJydXB0LWNvbnRyb2xsZXI7 CisJCSNpbnRlcnJ1cHQtY2VsbHMgPSA8MT47CisJfTsKK307CisKKyZpMmMyIHsKKwlwaW5jdHJs LW5hbWVzID0gImRlZmF1bHQiOworCXBpbmN0cmwtMCA9IDwmaTJjMl9waW5zX2E+OworCXN0YXR1 cyA9ICJva2F5IjsKKworCWZ0NXg6IHRvdWNoc2NyZWVuQDM4IHsKKwkJY29tcGF0aWJsZSA9ICJl ZHQsZWR0LWZ0NTMwNiI7CisJCXJlZyA9IDwweDM4PjsKKwkJaW50ZXJydXB0LXBhcmVudCA9IDwm cGlvPjsKKwkJaW50ZXJydXB0cyA9IDw3IDIgSVJRX1RZUEVfRURHRV9GQUxMSU5HPjsgLyogUEgy ICovCisJCXJlc2V0LWdwaW9zID0gPCZwaW8gNyAzIEdQSU9fQUNUSVZFX0xPVz47IC8qIFBIMyAq LworCQl0b3VjaHNjcmVlbi1zaXplLXggPSA8NDgwPjsKKwkJdG91Y2hzY3JlZW4tc2l6ZS15ID0g PDI3Mj47CisJfTsKK307CisKKyZtbWMwIHsKKwlwaW5jdHJsLW5hbWVzID0gImRlZmF1bHQiOwor CXBpbmN0cmwtMCA9IDwmbW1jMF9waW5zX2E+OworCXZtbWMtc3VwcGx5ID0gPCZyZWdfdmNjM3Yz PjsKKwlidXMtd2lkdGggPSA8ND47CisJY2QtZ3Bpb3MgPSA8JnBpbyA3IDEgR1BJT19BQ1RJVkVf SElHSD47IC8qIFBIMSAqLworCWNkLWludmVydGVkOworCXN0YXR1cyA9ICJva2F5IjsKK307CisK KyZvaGNpMCB7CisJc3RhdHVzID0gIm9rYXkiOworfTsKKworJm9oY2kxIHsKKwlzdGF0dXMgPSAi b2theSI7Cit9OworCismb3RnX3NyYW0geworCXN0YXR1cyA9ICJva2F5IjsKK307CisKKyZyZWdf dXNiMF92YnVzIHsKKwlzdGF0dXMgPSAib2theSI7Cit9OworCismcmVnX3VzYjFfdmJ1cyB7CisJ c3RhdHVzID0gIm9rYXkiOworfTsKKworJnVhcnQwIHsKKwlwaW5jdHJsLW5hbWVzID0gImRlZmF1 bHQiOworCXBpbmN0cmwtMCA9IDwmdWFydDBfcGluc19hPjsKKwlzdGF0dXMgPSAib2theSI7Cit9 OworCismdXNiX290ZyB7CisJZHJfbW9kZSA9ICJvdGciOworCXN0YXR1cyA9ICJva2F5IjsKK307 CisKKyZ1c2JwaHkgeworCXBpbmN0cmwtbmFtZXMgPSAiZGVmYXVsdCI7CisJdXNiMF92YnVzLXN1 cHBseSA9IDwmcmVnX3VzYjBfdmJ1cz47CisJdXNiMV92YnVzLXN1cHBseSA9IDwmcmVnX3VzYjFf dmJ1cz47CisJc3RhdHVzID0gIm9rYXkiOworfTsKKworJmJlMCB7CisJc3RhdHVzID0gIm9rYXki OworfTsKKworJmRlIHsKKwlzdGF0dXMgPSAib2theSI7Cit9OworCismdGNvbjAgeworCXBpbmN0 cmwtbmFtZXMgPSAiZGVmYXVsdCI7CisJcGluY3RybC0wID0gPCZsY2QwX3JnYjg4OF9waW5zPjsK KwlzdGF0dXMgPSAib2theSI7Cit9OworCismdGNvbjBfb3V0IHsKKwl0Y29uMF9vdXRfcGFuZWw6 IGVuZHBvaW50QDAgeworCQlyZWcgPSA8MD47CisJCXJlbW90ZS1lbmRwb2ludCA9IDwmcGFuZWxf aW5wdXQ+OworCX07Cit9OwotLSAKMi43LjQKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fCmRyaS1kZXZlbCBtYWlsaW5nIGxpc3QKZHJpLWRldmVsQGxpc3Rz LmZyZWVkZXNrdG9wLm9yZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xp c3RpbmZvL2RyaS1kZXZlbAo= From mboxrd@z Thu Jan 1 00:00:00 1970 From: giulio.benetti@micronovasrl.com (Giulio Benetti) Date: Wed, 21 Mar 2018 21:03:12 +0100 Subject: [PATCH 6/7] ARM: dts: sun7i: Add dts file for the A20-linova1-4_3 HMI In-Reply-To: <1521662593-25468-1-git-send-email-giulio.benetti@micronovasrl.com> References: <1521662593-25468-1-git-send-email-giulio.benetti@micronovasrl.com> Message-ID: <1521662593-25468-6-git-send-email-giulio.benetti@micronovasrl.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org The A20-Linova1-4_3 HMI, also called Q027_2_A which is printed on production label, is an industrial Human Machine Interface. It features: - 512MB DDR RAM - 1 Sd-card >= 4GB - 1 Usb otg(programmable via software) with A-Usb Connector - 1 Usb host - 1 Buzzer - 1 Input for LiPo - 1 Relay to signal absence of power supply - 1 External Rtc with 56 bytes of ram + CR2032 battery - 1 4.3" 24-bits Tft 480x272 with PCap on - 1 Mono audio 1-watt amplifier - 1 RS485 port - 1 Power On Line through +12Vdc reaching 57.600baud, from where it can be supplied and placed in a network of 50 units - exposed jtag pins HMI is supplied from +12Vdc. Ethernet is absent, so for debugging, need to enable rndis on Usb otg port through an A-A usb cable. It comes in different flavours for connector types and can be found with umounted features as requested by customers. Signed-off-by: Giulio Benetti --- .../devicetree/bindings/arm/micronova.txt | 6 + arch/arm/boot/dts/Makefile | 1 + arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts | 192 +++++++++++++++++++++ 3 files changed, 199 insertions(+) create mode 100644 Documentation/devicetree/bindings/arm/micronova.txt create mode 100644 arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts diff --git a/Documentation/devicetree/bindings/arm/micronova.txt b/Documentation/devicetree/bindings/arm/micronova.txt new file mode 100644 index 0000000..35c4127 --- /dev/null +++ b/Documentation/devicetree/bindings/arm/micronova.txt @@ -0,0 +1,6 @@ +Micronova Device Tree Bindings +--------------------------- + +A20-LiNova1-4_3 HMI +Required root node properties: + - compatible = "micronova,a20-linova1-ctp-4_3i", "allwinner,sun7i-a20"; diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile index ade7a38..c45a4f25 100644 --- a/arch/arm/boot/dts/Makefile +++ b/arch/arm/boot/dts/Makefile @@ -941,6 +941,7 @@ dtb-$(CONFIG_MACH_SUN7I) += \ sun7i-a20-lamobo-r1.dtb \ sun7i-a20-m3.dtb \ sun7i-a20-mk808c.dtb \ + sun7i-a20-linova1-ctp-4_3i.dtb\ sun7i-a20-olimex-som-evb.dtb \ sun7i-a20-olinuxino-lime.dtb \ sun7i-a20-olinuxino-lime2.dtb \ diff --git a/arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts b/arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts new file mode 100644 index 0000000..cd4ac73 --- /dev/null +++ b/arch/arm/boot/dts/sun7i-a20-linova1-ctp-4_3i.dts @@ -0,0 +1,192 @@ +/* + * This is based on sun7i-a20-linova1-ctp-4_3i.dts + * + * Copyright 2014 - Hans de Goede + * Copyright (c) 2014 FUKAUMI Naoki + * Copyright (c) 2018 Giulio Benetti + * + * This file is dual-licensed: you can use it either under the terms + * of the GPL or the X11 license, at your option. Note that this dual + * licensing only applies to this file, and not this project as a + * whole. + * + * a) This file is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of the + * License, or (at your option) any later version. + * + * This file 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. + * + * Or, alternatively, + * + * b) Permission is hereby granted, free of charge, to any person + * obtaining a copy of this software and associated documentation + * files (the "Software"), to deal in the Software without + * restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, sublicense, and/or + * sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following + * conditions: + * + * The above copyright notice and this permission notice shall be + * included in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES + * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT + * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, + * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR + * OTHER DEALINGS IN THE SOFTWARE. + */ + +/dts-v1/; +#include "sun7i-a20.dtsi" +#include "sunxi-common-regulators.dtsi" + +#include +#include + +/ { + model = "Micronova srl LiNova1 CTP 4.3i"; + compatible = "micronova,a20-linova1-ctp-4_3i", "allwinner,sun7i-a20"; + + aliases { + serial0 = &uart0; + }; + + chosen { + stdout-path = "serial0:115200n8"; + }; + + panel: panel { + compatible = "cdtech,s043wq26h-ct7", "simple-panel"; + power-supply = <®_vcc3v3>; + #address-cells = <1>; + #size-cells = <0>; + + port at 0 { + reg = <0>; + #address-cells = <1>; + #size-cells = <0>; + + panel_input: endpoint at 0 { + reg = <0>; + remote-endpoint = <&tcon0_out_panel>; + }; + }; + }; +}; + +&ehci0 { + status = "okay"; +}; + +&ehci1 { + status = "okay"; +}; + +&i2c0 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c0_pins_a>; + status = "okay"; + + axp209: pmic at 34 { + compatible = "x-powers,axp209"; + reg = <0x34>; + interrupt-parent = <&nmi_intc>; + interrupts = <0 IRQ_TYPE_LEVEL_LOW>; + + interrupt-controller; + #interrupt-cells = <1>; + }; +}; + +&i2c2 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c2_pins_a>; + status = "okay"; + + ft5x: touchscreen at 38 { + compatible = "edt,edt-ft5306"; + reg = <0x38>; + interrupt-parent = <&pio>; + interrupts = <7 2 IRQ_TYPE_EDGE_FALLING>; /* PH2 */ + reset-gpios = <&pio 7 3 GPIO_ACTIVE_LOW>; /* PH3 */ + touchscreen-size-x = <480>; + touchscreen-size-y = <272>; + }; +}; + +&mmc0 { + pinctrl-names = "default"; + pinctrl-0 = <&mmc0_pins_a>; + vmmc-supply = <®_vcc3v3>; + bus-width = <4>; + cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */ + cd-inverted; + status = "okay"; +}; + +&ohci0 { + status = "okay"; +}; + +&ohci1 { + status = "okay"; +}; + +&otg_sram { + status = "okay"; +}; + +®_usb0_vbus { + status = "okay"; +}; + +®_usb1_vbus { + status = "okay"; +}; + +&uart0 { + pinctrl-names = "default"; + pinctrl-0 = <&uart0_pins_a>; + status = "okay"; +}; + +&usb_otg { + dr_mode = "otg"; + status = "okay"; +}; + +&usbphy { + pinctrl-names = "default"; + usb0_vbus-supply = <®_usb0_vbus>; + usb1_vbus-supply = <®_usb1_vbus>; + status = "okay"; +}; + +&be0 { + status = "okay"; +}; + +&de { + status = "okay"; +}; + +&tcon0 { + pinctrl-names = "default"; + pinctrl-0 = <&lcd0_rgb888_pins>; + status = "okay"; +}; + +&tcon0_out { + tcon0_out_panel: endpoint at 0 { + reg = <0>; + remote-endpoint = <&panel_input>; + }; +}; -- 2.7.4