initial working version of DT overlays
This commit is contained in:
parent
214538f913
commit
dd8f6c48b9
15 changed files with 4843 additions and 357256 deletions
|
@ -0,0 +1,9 @@
|
||||||
|
verbosity=1
|
||||||
|
console=serial
|
||||||
|
overlay_prefix=sun8i-h3
|
||||||
|
rootfstype=ext4
|
||||||
|
overlays=w1-gpio uart1 i2c0 spi-spidev
|
||||||
|
param_w1_pin=PA20
|
||||||
|
param_w1_pin_int_pullup=1
|
||||||
|
param_uart1_rtscts=1
|
||||||
|
param_spidev_spi_bus=0
|
|
@ -10,4 +10,9 @@ SRC_URI_append = " \
|
||||||
file://h3-set-safe-axi_apb-clock-dividers.patch \
|
file://h3-set-safe-axi_apb-clock-dividers.patch \
|
||||||
file://h3-adjust-dram-frequency.patch \
|
file://h3-adjust-dram-frequency.patch \
|
||||||
file://enable-DT-overlays-support.patch \
|
file://enable-DT-overlays-support.patch \
|
||||||
"
|
file://armbianEnv.txt \
|
||||||
|
"
|
||||||
|
|
||||||
|
do_deploy_append() {
|
||||||
|
install -m 0644 ${WORKDIR}/armbianEnv.txt ${DEPLOYDIR}/armbianEnv.txt
|
||||||
|
}
|
|
@ -27,11 +27,49 @@ IMAGE_FSTYPES_append_orange-pi-lite = " resinos-img"
|
||||||
RESIN_IMAGE_BOOTLOADER_orange-pi-lite = "u-boot"
|
RESIN_IMAGE_BOOTLOADER_orange-pi-lite = "u-boot"
|
||||||
RESIN_BOOT_PARTITION_FILES_orange-pi-lite = " \
|
RESIN_BOOT_PARTITION_FILES_orange-pi-lite = " \
|
||||||
${KERNEL_IMAGETYPE}${KERNEL_INITRAMFS}-${MACHINE}.bin:/${KERNEL_IMAGETYPE} \
|
${KERNEL_IMAGETYPE}${KERNEL_INITRAMFS}-${MACHINE}.bin:/${KERNEL_IMAGETYPE} \
|
||||||
uImage-sun8i-h3-orangepi-lite.dtb:/sun8i-h3-orangepi-lite.dtb \
|
uImage-sun8i-h3-orangepi-lite.dtb:/dtb/sun8i-h3-orangepi-lite.dtb \
|
||||||
|
uImage-sun8i-h3-fixup.scr:/dtb/overlay/sun8i-h3-fixup.scr \
|
||||||
|
uImage-sun8i-h3-cir.dtbo:/dtb/overlay/sun8i-h3-cir.dtbo \
|
||||||
|
uImage-sun8i-h3-i2c0.dtbo:/dtb/overlay/sun8i-h3-i2c0.dtbo \
|
||||||
|
uImage-sun8i-h3-i2c1.dtbo:/dtb/overlay/sun8i-h3-i2c1.dtbo \
|
||||||
|
uImage-sun8i-h3-i2c2.dtbo:/dtb/overlay/sun8i-h3-i2c2.dtbo \
|
||||||
|
uImage-sun8i-h3-pps-gpio.dtbo:/dtb/overlay/sun8i-h3-pps-gpio.dtbo \
|
||||||
|
uImage-sun8i-h3-pwm.dtbo:/dtb/overlay/sun8i-h3-pwm.dtbo \
|
||||||
|
uImage-sun8i-h3-spdif-out.dtbo:/dtb/overlay/sun8i-h3-spdif-out.dtbo \
|
||||||
|
uImage-sun8i-h3-spi-add-cs1.dtbo:/dtb/overlay/sun8i-h3-spi-add-cs1.dtbo \
|
||||||
|
uImage-sun8i-h3-spi-jedec-nor.dtbo:/dtb/overlay/sun8i-h3-spi-jedec-nor.dtbo \
|
||||||
|
uImage-sun8i-h3-spi-spidev.dtbo:/dtb/overlay/sun8i-h3-spi-spidev.dtbo \
|
||||||
|
uImage-sun8i-h3-uart1.dtbo:/dtb/overlay/sun8i-h3-uart1.dtbo \
|
||||||
|
uImage-sun8i-h3-uart2.dtbo:/dtb/overlay/sun8i-h3-uart2.dtbo \
|
||||||
|
uImage-sun8i-h3-uart3.dtbo:/dtb/overlay/sun8i-h3-uart3.dtbo \
|
||||||
|
uImage-sun8i-h3-usbhost0.dtbo:/dtb/overlay/sun8i-h3-usbhost0.dtbo \
|
||||||
|
uImage-sun8i-h3-usbhost2.dtbo:/dtb/overlay/sun8i-h3-usbhost1.dtbo \
|
||||||
|
uImage-sun8i-h3-usbhost3.dtbo:/dtb/overlay/sun8i-h3-usbhost2.dtbo \
|
||||||
|
uImage-sun8i-h3-w1-gpio.dtbo:/dtb/overlay/sun8i-h3-w1-gpio.dtbo \
|
||||||
boot.scr:/boot.scr \
|
boot.scr:/boot.scr \
|
||||||
|
armbianEnv.txt:/ \
|
||||||
"
|
"
|
||||||
|
|
||||||
IMAGE_CMD_resinos-img_append_orange-pi-lite () {
|
IMAGE_CMD_resinos-img_append_orange-pi-lite () {
|
||||||
# orange-pi-one needs uboot written at a specific location
|
# orange-pi-lite needs uboot written at a specific location
|
||||||
|
dd if=${DEPLOY_DIR_IMAGE}/u-boot-sunxi-with-spl.bin of=${RESIN_RAW_IMG} conv=notrunc seek=8 bs=1024
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# orange-pi-plus2e
|
||||||
|
#
|
||||||
|
|
||||||
|
IMAGE_FSTYPES_append_orange-pi-plus2e = " resinos-img"
|
||||||
|
|
||||||
|
# Customize resinos-img
|
||||||
|
RESIN_IMAGE_BOOTLOADER_orange-pi-plus2e = "u-boot"
|
||||||
|
RESIN_BOOT_PARTITION_FILES_orange-pi-plus2e = " \
|
||||||
|
${KERNEL_IMAGETYPE}${KERNEL_INITRAMFS}-${MACHINE}.bin:/${KERNEL_IMAGETYPE} \
|
||||||
|
uImage-sun8i-h3-orangepi-plus2e.dtb:/sun8i-h3-orangepi-plus2e.dtb \
|
||||||
|
boot.scr:/boot.scr \
|
||||||
|
"
|
||||||
|
|
||||||
|
IMAGE_CMD_resinos-img_append_orange-pi-plus2e () {
|
||||||
|
# orange-pi-plus2e needs uboot written at a specific location
|
||||||
dd if=${DEPLOY_DIR_IMAGE}/u-boot-sunxi-with-spl.bin of=${RESIN_RAW_IMG} conv=notrunc seek=8 bs=1024
|
dd if=${DEPLOY_DIR_IMAGE}/u-boot-sunxi-with-spl.bin of=${RESIN_RAW_IMG} conv=notrunc seek=8 bs=1024
|
||||||
}
|
}
|
|
@ -0,0 +1,174 @@
|
||||||
|
diff --git a/drivers/staging/iio/frequency/ad9834.c b/drivers/staging/iio/frequency/ad9834.c
|
||||||
|
index 19216af1..e839d23a 100644
|
||||||
|
--- a/drivers/staging/iio/frequency/ad9834.c
|
||||||
|
+++ b/drivers/staging/iio/frequency/ad9834.c
|
||||||
|
@@ -13,11 +13,14 @@
|
||||||
|
#include <linux/slab.h>
|
||||||
|
#include <linux/sysfs.h>
|
||||||
|
#include <linux/list.h>
|
||||||
|
+#include <linux/of.h>
|
||||||
|
+#include <linux/of_device.h>
|
||||||
|
#include <linux/spi/spi.h>
|
||||||
|
#include <linux/regulator/consumer.h>
|
||||||
|
#include <linux/err.h>
|
||||||
|
#include <linux/module.h>
|
||||||
|
#include <asm/div64.h>
|
||||||
|
+#include <linux/clk.h>
|
||||||
|
|
||||||
|
#include <linux/iio/iio.h>
|
||||||
|
#include <linux/iio/sysfs.h>
|
||||||
|
@@ -316,14 +319,81 @@ static const struct iio_info ad9833_info = {
|
||||||
|
.driver_module = THIS_MODULE,
|
||||||
|
};
|
||||||
|
|
||||||
|
+#if defined(CONFIG_OF)
|
||||||
|
+static struct ad9834_platform_data *ad9834_parse_dt(struct spi_device *spi)
|
||||||
|
+{
|
||||||
|
+ struct ad9834_platform_data *pdata;
|
||||||
|
+ struct device_node *np = spi->dev.of_node;
|
||||||
|
+
|
||||||
|
+ pdata = devm_kzalloc(&spi->dev, sizeof(*pdata), GFP_KERNEL);
|
||||||
|
+ if (!pdata)
|
||||||
|
+ return ERR_PTR(-ENOMEM);
|
||||||
|
+
|
||||||
|
+ pdata->freq0 = 134000;
|
||||||
|
+ of_property_read_u32(np, "freq0", &pdata->freq0);
|
||||||
|
+
|
||||||
|
+ pdata->freq1 = 134000;
|
||||||
|
+ of_property_read_u32(np, "freq1", &pdata->freq1);
|
||||||
|
+
|
||||||
|
+ pdata->phase0 = 0;
|
||||||
|
+ of_property_read_u16(np, "phase0", &pdata->phase0);
|
||||||
|
+
|
||||||
|
+ pdata->phase1 = 0;
|
||||||
|
+ of_property_read_u16(np, "phase1", &pdata->phase1);
|
||||||
|
+
|
||||||
|
+ pdata->en_div2 = of_property_read_bool(np, "en_div2");
|
||||||
|
+ pdata->en_signbit_msb_out = of_property_read_bool(np,
|
||||||
|
+ "en_signbit_msb_out");
|
||||||
|
+
|
||||||
|
+ return pdata;
|
||||||
|
+}
|
||||||
|
+#else
|
||||||
|
+static struct ad9834_platform_data *ad9834_parse_dt(struct spi_device *spi)
|
||||||
|
+{
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+static const struct of_device_id ad9834_of_match[] = {
|
||||||
|
+ {
|
||||||
|
+ .compatible = "adi,ad9833",
|
||||||
|
+ .data = (void *)ID_AD9833,
|
||||||
|
+ },
|
||||||
|
+ {
|
||||||
|
+ .compatible = "adi,ad9834",
|
||||||
|
+ .data = (void *)ID_AD9834,
|
||||||
|
+ },
|
||||||
|
+ {
|
||||||
|
+ .compatible = "adi,ad9837",
|
||||||
|
+ .data = (void *)ID_AD9837,
|
||||||
|
+ },
|
||||||
|
+ {
|
||||||
|
+ .compatible = "adi,ad9838",
|
||||||
|
+ .data = (void *)ID_AD9838,
|
||||||
|
+ },
|
||||||
|
+ { }
|
||||||
|
+};
|
||||||
|
+MODULE_DEVICE_TABLE(of, ad9834_of_match);
|
||||||
|
+
|
||||||
|
static int ad9834_probe(struct spi_device *spi)
|
||||||
|
{
|
||||||
|
- struct ad9834_platform_data *pdata = dev_get_platdata(&spi->dev);
|
||||||
|
+ const struct of_device_id *of_id = of_match_device(ad9834_of_match,
|
||||||
|
+ &spi->dev);
|
||||||
|
+ struct ad9834_platform_data *pdata;
|
||||||
|
struct ad9834_state *st;
|
||||||
|
struct iio_dev *indio_dev;
|
||||||
|
struct regulator *reg;
|
||||||
|
+ struct clk *clk = NULL;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
+ if (!pdata && spi->dev.of_node) {
|
||||||
|
+ pdata = ad9834_parse_dt(spi);
|
||||||
|
+ if (IS_ERR(pdata))
|
||||||
|
+ return PTR_ERR(pdata);
|
||||||
|
+ } else {
|
||||||
|
+ pdata = spi->dev.platform_data;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (!pdata) {
|
||||||
|
dev_dbg(&spi->dev, "no platform data?\n");
|
||||||
|
return -ENODEV;
|
||||||
|
@@ -346,9 +416,30 @@ static int ad9834_probe(struct spi_device *spi)
|
||||||
|
}
|
||||||
|
spi_set_drvdata(spi, indio_dev);
|
||||||
|
st = iio_priv(indio_dev);
|
||||||
|
- st->mclk = pdata->mclk;
|
||||||
|
+
|
||||||
|
+ if (!pdata->mclk) {
|
||||||
|
+ clk = devm_clk_get(&spi->dev, NULL);
|
||||||
|
+ if (IS_ERR(clk))
|
||||||
|
+ return -EPROBE_DEFER;
|
||||||
|
+
|
||||||
|
+ ret = clk_prepare_enable(clk);
|
||||||
|
+ if (ret < 0)
|
||||||
|
+ return ret;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (clk) {
|
||||||
|
+ st->clk = clk;
|
||||||
|
+ st->mclk = clk_get_rate(clk);
|
||||||
|
+ } else {
|
||||||
|
+ st->mclk = pdata->mclk;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (of_id)
|
||||||
|
+ st->devid = (enum ad9834_supported_device_ids)of_id->data;
|
||||||
|
+ else
|
||||||
|
+ st->devid = spi_get_device_id(spi)->driver_data;
|
||||||
|
+
|
||||||
|
st->spi = spi;
|
||||||
|
- st->devid = spi_get_device_id(spi)->driver_data;
|
||||||
|
st->reg = reg;
|
||||||
|
indio_dev->dev.parent = &spi->dev;
|
||||||
|
indio_dev->name = spi_get_device_id(spi)->name;
|
||||||
|
@@ -421,6 +512,9 @@ static int ad9834_probe(struct spi_device *spi)
|
||||||
|
error_disable_reg:
|
||||||
|
regulator_disable(reg);
|
||||||
|
|
||||||
|
+if (clk)
|
||||||
|
+ clk_disable_unprepare(clk);
|
||||||
|
+
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -431,6 +525,8 @@ static int ad9834_remove(struct spi_device *spi)
|
||||||
|
|
||||||
|
iio_device_unregister(indio_dev);
|
||||||
|
regulator_disable(st->reg);
|
||||||
|
+if (st->clk)
|
||||||
|
+ clk_disable_unprepare(st->clk);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@@ -447,6 +543,7 @@ MODULE_DEVICE_TABLE(spi, ad9834_id);
|
||||||
|
static struct spi_driver ad9834_driver = {
|
||||||
|
.driver = {
|
||||||
|
.name = "ad9834",
|
||||||
|
+ .of_match_table = of_match_ptr(ad9834_of_match),
|
||||||
|
},
|
||||||
|
.probe = ad9834_probe,
|
||||||
|
.remove = ad9834_remove,
|
||||||
|
diff --git a/drivers/staging/iio/frequency/ad9834.h b/drivers/staging/iio/frequency/ad9834.h
|
||||||
|
index 40fdd5da..fd9cccf3 100644
|
||||||
|
--- a/drivers/staging/iio/frequency/ad9834.h
|
||||||
|
+++ b/drivers/staging/iio/frequency/ad9834.h
|
||||||
|
@@ -53,6 +53,7 @@
|
||||||
|
struct ad9834_state {
|
||||||
|
struct spi_device *spi;
|
||||||
|
struct regulator *reg;
|
||||||
|
+ struct clk *clk;
|
||||||
|
unsigned int mclk;
|
||||||
|
unsigned short control;
|
||||||
|
unsigned short devid;
|
|
@ -0,0 +1,360 @@
|
||||||
|
diff --git a/drivers/of/Kconfig b/drivers/of/Kconfig
|
||||||
|
index bc07ad3..e9da9cf 100644
|
||||||
|
--- a/drivers/of/Kconfig
|
||||||
|
+++ b/drivers/of/Kconfig
|
||||||
|
@@ -113,6 +113,13 @@ config OF_OVERLAY
|
||||||
|
While this option is selected automatically when needed, you can
|
||||||
|
enable it manually to improve device tree unit test coverage.
|
||||||
|
|
||||||
|
+config OF_CONFIGFS
|
||||||
|
+ bool "Device Tree Overlay ConfigFS interface"
|
||||||
|
+ select CONFIGFS_FS
|
||||||
|
+ depends on OF_OVERLAY
|
||||||
|
+ help
|
||||||
|
+ Enable a simple user-space driven DT overlay interface.
|
||||||
|
+
|
||||||
|
config OF_NUMA
|
||||||
|
bool
|
||||||
|
|
||||||
|
diff --git a/drivers/of/Makefile b/drivers/of/Makefile
|
||||||
|
index d7efd9d..a06cc35 100644
|
||||||
|
--- a/drivers/of/Makefile
|
||||||
|
+++ b/drivers/of/Makefile
|
||||||
|
@@ -13,6 +13,7 @@ obj-$(CONFIG_OF_PCI_IRQ) += of_pci_irq.o
|
||||||
|
obj-$(CONFIG_OF_RESERVED_MEM) += of_reserved_mem.o
|
||||||
|
obj-$(CONFIG_OF_RESOLVE) += resolver.o
|
||||||
|
obj-$(CONFIG_OF_OVERLAY) += overlay.o
|
||||||
|
+obj-$(CONFIG_OF_CONFIGFS) += configfs.o
|
||||||
|
obj-$(CONFIG_OF_NUMA) += of_numa.o
|
||||||
|
|
||||||
|
obj-$(CONFIG_OF_UNITTEST) += unittest-data/
|
||||||
|
diff --git a/drivers/of/configfs.c b/drivers/of/configfs.c
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..68f889d
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/drivers/of/configfs.c
|
||||||
|
@@ -0,0 +1,311 @@
|
||||||
|
+/*
|
||||||
|
+ * Configfs entries for device-tree
|
||||||
|
+ *
|
||||||
|
+ * Copyright (C) 2013 - Pantelis Antoniou <panto@antoniou-consulting.com>
|
||||||
|
+ *
|
||||||
|
+ * This program 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.
|
||||||
|
+ */
|
||||||
|
+#include <linux/ctype.h>
|
||||||
|
+#include <linux/cpu.h>
|
||||||
|
+#include <linux/module.h>
|
||||||
|
+#include <linux/of.h>
|
||||||
|
+#include <linux/of_fdt.h>
|
||||||
|
+#include <linux/spinlock.h>
|
||||||
|
+#include <linux/slab.h>
|
||||||
|
+#include <linux/proc_fs.h>
|
||||||
|
+#include <linux/configfs.h>
|
||||||
|
+#include <linux/types.h>
|
||||||
|
+#include <linux/stat.h>
|
||||||
|
+#include <linux/limits.h>
|
||||||
|
+#include <linux/file.h>
|
||||||
|
+#include <linux/vmalloc.h>
|
||||||
|
+#include <linux/firmware.h>
|
||||||
|
+#include <linux/sizes.h>
|
||||||
|
+
|
||||||
|
+#include "of_private.h"
|
||||||
|
+
|
||||||
|
+struct cfs_overlay_item {
|
||||||
|
+ struct config_item item;
|
||||||
|
+
|
||||||
|
+ char path[PATH_MAX];
|
||||||
|
+
|
||||||
|
+ const struct firmware *fw;
|
||||||
|
+ struct device_node *overlay;
|
||||||
|
+ int ov_id;
|
||||||
|
+
|
||||||
|
+ void *dtbo;
|
||||||
|
+ int dtbo_size;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static int create_overlay(struct cfs_overlay_item *overlay, void *blob)
|
||||||
|
+{
|
||||||
|
+ int err;
|
||||||
|
+
|
||||||
|
+ /* unflatten the tree */
|
||||||
|
+ of_fdt_unflatten_tree(blob, NULL, &overlay->overlay);
|
||||||
|
+ if (overlay->overlay == NULL) {
|
||||||
|
+ pr_err("%s: failed to unflatten tree\n", __func__);
|
||||||
|
+ err = -EINVAL;
|
||||||
|
+ goto out_err;
|
||||||
|
+ }
|
||||||
|
+ pr_debug("%s: unflattened OK\n", __func__);
|
||||||
|
+
|
||||||
|
+ /* mark it as detached */
|
||||||
|
+ of_node_set_flag(overlay->overlay, OF_DETACHED);
|
||||||
|
+
|
||||||
|
+ /* perform resolution */
|
||||||
|
+ err = of_resolve_phandles(overlay->overlay);
|
||||||
|
+ if (err != 0) {
|
||||||
|
+ pr_err("%s: Failed to resolve tree\n", __func__);
|
||||||
|
+ goto out_err;
|
||||||
|
+ }
|
||||||
|
+ pr_debug("%s: resolved OK\n", __func__);
|
||||||
|
+
|
||||||
|
+ err = of_overlay_create(overlay->overlay);
|
||||||
|
+ if (err < 0) {
|
||||||
|
+ pr_err("%s: Failed to create overlay (err=%d)\n",
|
||||||
|
+ __func__, err);
|
||||||
|
+ goto out_err;
|
||||||
|
+ }
|
||||||
|
+ overlay->ov_id = err;
|
||||||
|
+
|
||||||
|
+out_err:
|
||||||
|
+ return err;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static inline struct cfs_overlay_item *to_cfs_overlay_item(
|
||||||
|
+ struct config_item *item)
|
||||||
|
+{
|
||||||
|
+ return item ? container_of(item, struct cfs_overlay_item, item) : NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static ssize_t cfs_overlay_item_path_show(struct config_item *item,
|
||||||
|
+ char *page)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+ return sprintf(page, "%s\n", overlay->path);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static ssize_t cfs_overlay_item_path_store(struct config_item *item,
|
||||||
|
+ const char *page, size_t count)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+ const char *p = page;
|
||||||
|
+ char *s;
|
||||||
|
+ int err;
|
||||||
|
+
|
||||||
|
+ /* if it's set do not allow changes */
|
||||||
|
+ if (overlay->path[0] != '\0' || overlay->dtbo_size > 0)
|
||||||
|
+ return -EPERM;
|
||||||
|
+
|
||||||
|
+ /* copy to path buffer (and make sure it's always zero terminated */
|
||||||
|
+ count = snprintf(overlay->path, sizeof(overlay->path) - 1, "%s", p);
|
||||||
|
+ overlay->path[sizeof(overlay->path) - 1] = '\0';
|
||||||
|
+
|
||||||
|
+ /* strip trailing newlines */
|
||||||
|
+ s = overlay->path + strlen(overlay->path);
|
||||||
|
+ while (s > overlay->path && *--s == '\n')
|
||||||
|
+ *s = '\0';
|
||||||
|
+
|
||||||
|
+ pr_debug("%s: path is '%s'\n", __func__, overlay->path);
|
||||||
|
+
|
||||||
|
+ err = request_firmware(&overlay->fw, overlay->path, NULL);
|
||||||
|
+ if (err != 0)
|
||||||
|
+ goto out_err;
|
||||||
|
+
|
||||||
|
+ err = create_overlay(overlay, (void *)overlay->fw->data);
|
||||||
|
+ if (err != 0)
|
||||||
|
+ goto out_err;
|
||||||
|
+
|
||||||
|
+ return count;
|
||||||
|
+
|
||||||
|
+out_err:
|
||||||
|
+
|
||||||
|
+ release_firmware(overlay->fw);
|
||||||
|
+ overlay->fw = NULL;
|
||||||
|
+
|
||||||
|
+ overlay->path[0] = '\0';
|
||||||
|
+ return err;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static ssize_t cfs_overlay_item_status_show(struct config_item *item,
|
||||||
|
+ char *page)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+
|
||||||
|
+ return sprintf(page, "%s\n",
|
||||||
|
+ overlay->ov_id >= 0 ? "applied" : "unapplied");
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+CONFIGFS_ATTR(cfs_overlay_item_, path);
|
||||||
|
+CONFIGFS_ATTR_RO(cfs_overlay_item_, status);
|
||||||
|
+
|
||||||
|
+static struct configfs_attribute *cfs_overlay_attrs[] = {
|
||||||
|
+ &cfs_overlay_item_attr_path,
|
||||||
|
+ &cfs_overlay_item_attr_status,
|
||||||
|
+ NULL,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+ssize_t cfs_overlay_item_dtbo_read(struct config_item *item,
|
||||||
|
+ void *buf, size_t max_count)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+
|
||||||
|
+ pr_debug("%s: buf=%p max_count=%zu\n", __func__,
|
||||||
|
+ buf, max_count);
|
||||||
|
+
|
||||||
|
+ if (overlay->dtbo == NULL)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
+ /* copy if buffer provided */
|
||||||
|
+ if (buf != NULL) {
|
||||||
|
+ /* the buffer must be large enough */
|
||||||
|
+ if (overlay->dtbo_size > max_count)
|
||||||
|
+ return -ENOSPC;
|
||||||
|
+
|
||||||
|
+ memcpy(buf, overlay->dtbo, overlay->dtbo_size);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return overlay->dtbo_size;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+ssize_t cfs_overlay_item_dtbo_write(struct config_item *item,
|
||||||
|
+ const void *buf, size_t count)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+ int err;
|
||||||
|
+
|
||||||
|
+ /* if it's set do not allow changes */
|
||||||
|
+ if (overlay->path[0] != '\0' || overlay->dtbo_size > 0)
|
||||||
|
+ return -EPERM;
|
||||||
|
+
|
||||||
|
+ /* copy the contents */
|
||||||
|
+ overlay->dtbo = kmemdup(buf, count, GFP_KERNEL);
|
||||||
|
+ if (overlay->dtbo == NULL)
|
||||||
|
+ return -ENOMEM;
|
||||||
|
+
|
||||||
|
+ overlay->dtbo_size = count;
|
||||||
|
+
|
||||||
|
+ err = create_overlay(overlay, overlay->dtbo);
|
||||||
|
+ if (err != 0)
|
||||||
|
+ goto out_err;
|
||||||
|
+
|
||||||
|
+ return count;
|
||||||
|
+
|
||||||
|
+out_err:
|
||||||
|
+ kfree(overlay->dtbo);
|
||||||
|
+ overlay->dtbo = NULL;
|
||||||
|
+ overlay->dtbo_size = 0;
|
||||||
|
+
|
||||||
|
+ return err;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+CONFIGFS_BIN_ATTR(cfs_overlay_item_, dtbo, NULL, SZ_1M);
|
||||||
|
+
|
||||||
|
+static struct configfs_bin_attribute *cfs_overlay_bin_attrs[] = {
|
||||||
|
+ &cfs_overlay_item_attr_dtbo,
|
||||||
|
+ NULL,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static void cfs_overlay_release(struct config_item *item)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+
|
||||||
|
+ if (overlay->ov_id >= 0)
|
||||||
|
+ of_overlay_destroy(overlay->ov_id);
|
||||||
|
+ if (overlay->fw)
|
||||||
|
+ release_firmware(overlay->fw);
|
||||||
|
+ /* kfree with NULL is safe */
|
||||||
|
+ kfree(overlay->dtbo);
|
||||||
|
+ kfree(overlay);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static struct configfs_item_operations cfs_overlay_item_ops = {
|
||||||
|
+ .release = cfs_overlay_release,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static struct config_item_type cfs_overlay_type = {
|
||||||
|
+ .ct_item_ops = &cfs_overlay_item_ops,
|
||||||
|
+ .ct_attrs = cfs_overlay_attrs,
|
||||||
|
+ .ct_bin_attrs = cfs_overlay_bin_attrs,
|
||||||
|
+ .ct_owner = THIS_MODULE,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static struct config_item *cfs_overlay_group_make_item(
|
||||||
|
+ struct config_group *group, const char *name)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay;
|
||||||
|
+
|
||||||
|
+ overlay = kzalloc(sizeof(*overlay), GFP_KERNEL);
|
||||||
|
+ if (!overlay)
|
||||||
|
+ return ERR_PTR(-ENOMEM);
|
||||||
|
+ overlay->ov_id = -1;
|
||||||
|
+
|
||||||
|
+ config_item_init_type_name(&overlay->item, name, &cfs_overlay_type);
|
||||||
|
+ return &overlay->item;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void cfs_overlay_group_drop_item(struct config_group *group,
|
||||||
|
+ struct config_item *item)
|
||||||
|
+{
|
||||||
|
+ struct cfs_overlay_item *overlay = to_cfs_overlay_item(item);
|
||||||
|
+
|
||||||
|
+ config_item_put(&overlay->item);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static struct configfs_group_operations overlays_ops = {
|
||||||
|
+ .make_item = cfs_overlay_group_make_item,
|
||||||
|
+ .drop_item = cfs_overlay_group_drop_item,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static struct config_item_type overlays_type = {
|
||||||
|
+ .ct_group_ops = &overlays_ops,
|
||||||
|
+ .ct_owner = THIS_MODULE,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static struct configfs_group_operations of_cfs_ops = {
|
||||||
|
+ /* empty - we don't allow anything to be created */
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static struct config_item_type of_cfs_type = {
|
||||||
|
+ .ct_group_ops = &of_cfs_ops,
|
||||||
|
+ .ct_owner = THIS_MODULE,
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+struct config_group of_cfs_overlay_group;
|
||||||
|
+
|
||||||
|
+static struct configfs_subsystem of_cfs_subsys = {
|
||||||
|
+ .su_group = {
|
||||||
|
+ .cg_item = {
|
||||||
|
+ .ci_namebuf = "device-tree",
|
||||||
|
+ .ci_type = &of_cfs_type,
|
||||||
|
+ },
|
||||||
|
+ },
|
||||||
|
+ .su_mutex = __MUTEX_INITIALIZER(of_cfs_subsys.su_mutex),
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static int __init of_cfs_init(void)
|
||||||
|
+{
|
||||||
|
+ int ret;
|
||||||
|
+
|
||||||
|
+ pr_info("%s\n", __func__);
|
||||||
|
+
|
||||||
|
+ config_group_init(&of_cfs_subsys.su_group);
|
||||||
|
+ config_group_init_type_name(&of_cfs_overlay_group, "overlays",
|
||||||
|
+ &overlays_type);
|
||||||
|
+ configfs_add_default_group(&of_cfs_overlay_group,
|
||||||
|
+ &of_cfs_subsys.su_group);
|
||||||
|
+
|
||||||
|
+ ret = configfs_register_subsystem(&of_cfs_subsys);
|
||||||
|
+ if (ret != 0) {
|
||||||
|
+ pr_err("%s: failed to register subsys\n", __func__);
|
||||||
|
+ goto out;
|
||||||
|
+ }
|
||||||
|
+ pr_info("%s: OK\n", __func__);
|
||||||
|
+out:
|
||||||
|
+ return ret;
|
||||||
|
+}
|
||||||
|
+late_initcall(of_cfs_init);
|
||||||
|
diff --git a/drivers/of/fdt_address.c b/drivers/of/fdt_address.c
|
||||||
|
index dca8f9b..ec7e167 100644
|
||||||
|
--- a/drivers/of/fdt_address.c
|
||||||
|
+++ b/drivers/of/fdt_address.c
|
||||||
|
@@ -161,7 +161,7 @@ static int __init fdt_translate_one(const void *blob, int parent,
|
||||||
|
* that can be mapped to a cpu physical address). This is not really specified
|
||||||
|
* that way, but this is traditionally the way IBM at least do things
|
||||||
|
*/
|
||||||
|
-static u64 __init fdt_translate_address(const void *blob, int node_offset)
|
||||||
|
+u64 __init fdt_translate_address(const void *blob, int node_offset)
|
||||||
|
{
|
||||||
|
int parent, len;
|
||||||
|
const struct of_bus *bus, *pbus;
|
|
@ -0,0 +1,36 @@
|
||||||
|
diff --git a/arch/arm/boot/dts/sun8i-h3-orangepi-plus2e.dts b/arch/arm/boot/dts/sun8i-h3-orangepi-plus2e.dts
|
||||||
|
index 5851a47a..c2f1baa2 100644
|
||||||
|
--- a/arch/arm/boot/dts/sun8i-h3-orangepi-plus2e.dts
|
||||||
|
+++ b/arch/arm/boot/dts/sun8i-h3-orangepi-plus2e.dts
|
||||||
|
@@ -50,4 +50,31 @@
|
||||||
|
/ {
|
||||||
|
model = "Xunlong Orange Pi Plus 2E";
|
||||||
|
compatible = "xunlong,orangepi-plus2e", "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ reg_gmac_3v3: gmac-3v3 {
|
||||||
|
+ compatible = "regulator-fixed";
|
||||||
|
+ regulator-name = "gmac-3v3";
|
||||||
|
+ regulator-min-microvolt = <3300000>;
|
||||||
|
+ regulator-max-microvolt = <3300000>;
|
||||||
|
+ startup-delay-us = <100000>;
|
||||||
|
+ enable-active-high;
|
||||||
|
+ gpio = <&pio 3 6 GPIO_ACTIVE_HIGH>;
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+&mdio {
|
||||||
|
+ ext_rgmii_phy: ethernet-phy@1 {
|
||||||
|
+ reg = <0>;
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+&emac {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&emac_rgmii_pins>;
|
||||||
|
+ phy-supply = <®_gmac_3v3>;
|
||||||
|
+ phy-handle = <&ext_rgmii_phy>;
|
||||||
|
+ phy-mode = "rgmii";
|
||||||
|
+
|
||||||
|
+ allwinner,leds-active-low;
|
||||||
|
+ status = "okay";
|
||||||
|
};
|
|
@ -0,0 +1,999 @@
|
||||||
|
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
|
||||||
|
index 01180849..81523d5a 100644
|
||||||
|
--- a/arch/arm/boot/dts/Makefile
|
||||||
|
+++ b/arch/arm/boot/dts/Makefile
|
||||||
|
@@ -1016,4 +1017,7 @@ dtstree := $(srctree)/$(src)
|
||||||
|
dtb-$(CONFIG_OF_ALL_DTBS) := $(patsubst $(dtstree)/%.dts,%.dtb, $(wildcard $(dtstree)/*.dts))
|
||||||
|
|
||||||
|
always := $(dtb-y)
|
||||||
|
+subdir-y := overlay
|
||||||
|
clean-files := *.dtb
|
||||||
|
+
|
||||||
|
+dts-dirs += overlay
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/Makefile b/arch/arm/boot/dts/overlay/Makefile
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..f9ca2574
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/Makefile
|
||||||
|
@@ -0,0 +1,28 @@
|
||||||
|
+dtbo-$(CONFIG_MACH_SUN8I) += \
|
||||||
|
+ sun8i-h3-analog-codec.dtbo \
|
||||||
|
+ sun8i-h3-cir.dtbo \
|
||||||
|
+ sun8i-h3-i2c0.dtbo \
|
||||||
|
+ sun8i-h3-i2c1.dtbo \
|
||||||
|
+ sun8i-h3-i2c2.dtbo \
|
||||||
|
+ sun8i-h3-pps-gpio.dtbo \
|
||||||
|
+ sun8i-h3-pwm.dtbo \
|
||||||
|
+ sun8i-h3-spdif-out.dtbo \
|
||||||
|
+ sun8i-h3-spi-add-cs1.dtbo \
|
||||||
|
+ sun8i-h3-spi-jedec-nor.dtbo \
|
||||||
|
+ sun8i-h3-spi-spidev.dtbo \
|
||||||
|
+ sun8i-h3-uart1.dtbo \
|
||||||
|
+ sun8i-h3-uart2.dtbo \
|
||||||
|
+ sun8i-h3-uart3.dtbo \
|
||||||
|
+ sun8i-h3-usbhost0.dtbo \
|
||||||
|
+ sun8i-h3-usbhost2.dtbo \
|
||||||
|
+ sun8i-h3-usbhost3.dtbo \
|
||||||
|
+ sun8i-h3-w1-gpio.dtbo
|
||||||
|
+
|
||||||
|
+scr-$(CONFIG_MACH_SUN8I) += sun8i-h3-fixup.scr
|
||||||
|
+
|
||||||
|
+dtbotxt-$(CONFIG_MACH_SUN8I) += README.sun8i-h3-overlays
|
||||||
|
+
|
||||||
|
+targets += $(dtbo-y) $(scr-y) $(dtbotxt-y)
|
||||||
|
+
|
||||||
|
+always := $(dtbo-y) $(scr-y) $(dtbotxt-y)
|
||||||
|
+clean-files := *.dtbo *.scr
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/README.sun8i-h3-overlays b/arch/arm/boot/dts/overlay/README.sun8i-h3-overlays
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..0ae207a1
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/README.sun8i-h3-overlays
|
||||||
|
@@ -0,0 +1,245 @@
|
||||||
|
+This document describes overlays provided in the kernel packages
|
||||||
|
+For generic Armbian overlays documentation please see
|
||||||
|
+https://docs.armbian.com/User-Guide_Allwinner_overlays/
|
||||||
|
+
|
||||||
|
+### Platform:
|
||||||
|
+
|
||||||
|
+sun8i-h3 (Allwinner H3)
|
||||||
|
+
|
||||||
|
+### Platform details:
|
||||||
|
+
|
||||||
|
+Supported pin banks: PA, PC, PD, PG
|
||||||
|
+
|
||||||
|
+Both SPI controllers have only one hardware CS pin exposed,
|
||||||
|
+adding fixed software (GPIO) chip selects is possible with a separate overlay
|
||||||
|
+
|
||||||
|
+### Provided overlays:
|
||||||
|
+
|
||||||
|
+- analog-codec
|
||||||
|
+- cir
|
||||||
|
+- i2c0
|
||||||
|
+- i2c1
|
||||||
|
+- i2c2
|
||||||
|
+- pps-gpio
|
||||||
|
+- pwm
|
||||||
|
+- spdif-out
|
||||||
|
+- spi-add-cs1
|
||||||
|
+- spi-jedec-nor
|
||||||
|
+- spi-spidev
|
||||||
|
+- uart1
|
||||||
|
+- uart2
|
||||||
|
+- uart3
|
||||||
|
+- usbhost0
|
||||||
|
+- usbhost2
|
||||||
|
+- usbhost3
|
||||||
|
+- w1-gpio
|
||||||
|
+
|
||||||
|
+### Overlay details:
|
||||||
|
+
|
||||||
|
+### analog-codec
|
||||||
|
+
|
||||||
|
+Activates SoC analog codec driver that provides Line Out and Mic In
|
||||||
|
+functionality
|
||||||
|
+
|
||||||
|
+### cir
|
||||||
|
+
|
||||||
|
+Activates CIR (Infrared remote) receiver
|
||||||
|
+
|
||||||
|
+CIR pin: PL11
|
||||||
|
+
|
||||||
|
+### i2c0
|
||||||
|
+
|
||||||
|
+Activates TWI/I2C bus 0
|
||||||
|
+
|
||||||
|
+I2C0 pins (SCL, SDA): PA11, PA12
|
||||||
|
+
|
||||||
|
+### i2c1
|
||||||
|
+
|
||||||
|
+Activates TWI/I2C bus 1
|
||||||
|
+
|
||||||
|
+I2C1 pins (SCL, SDA): PA18, PA19
|
||||||
|
+
|
||||||
|
+### i2c2
|
||||||
|
+
|
||||||
|
+Activates TWI/I2C bus 2
|
||||||
|
+
|
||||||
|
+I2C2 pins (SCL, SDA): PE12, PE13
|
||||||
|
+
|
||||||
|
+On most board this bus is wired to Camera (CSI) socket
|
||||||
|
+
|
||||||
|
+### pps-gpio
|
||||||
|
+
|
||||||
|
+Activates pulse-per-second GPIO client
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_pps_pin (pin)
|
||||||
|
+ Pin PPS source is connected to
|
||||||
|
+ Optional
|
||||||
|
+ Default: PD14
|
||||||
|
+
|
||||||
|
+param_pps_falling_edge (bool)
|
||||||
|
+ Assert by falling edge
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ When set (to 1), assert is indicated by a falling edge
|
||||||
|
+ (instead of by a rising edge)
|
||||||
|
+
|
||||||
|
+### pwm
|
||||||
|
+
|
||||||
|
+Activates hardware PWM controller
|
||||||
|
+
|
||||||
|
+PWM pin: PA5
|
||||||
|
+
|
||||||
|
+Pin PA5 is used as UART0 RX by default, so if this overlay is activated,
|
||||||
|
+UART0 and kernel console on ttyS0 will be disabled
|
||||||
|
+
|
||||||
|
+### spdif-out
|
||||||
|
+
|
||||||
|
+Activates SPDIF/Toslink audio output
|
||||||
|
+
|
||||||
|
+SPDIF pin: PA17
|
||||||
|
+
|
||||||
|
+### spi-add-cs1
|
||||||
|
+
|
||||||
|
+Adds support for using SPI chip select 1 with GPIO for both SPI controllers
|
||||||
|
+Respective GPIO will be claimed only if controller is enabled by another
|
||||||
|
+overlay
|
||||||
|
+This overlay is required for using chip select 1 with other SPI overlays
|
||||||
|
+Due to the u-boot limitations CS1 pin can't be customized by a parameter, but
|
||||||
|
+it can be changed by using an edited copy of this overlay
|
||||||
|
+A total of 4 chip selects can be used with custom overlays (1 HW + 3 GPIO)
|
||||||
|
+
|
||||||
|
+SPI 0 pins (CS1): PA21
|
||||||
|
+SPI 1 pins (CS1): PA10
|
||||||
|
+
|
||||||
|
+### spi-jedec-nor
|
||||||
|
+
|
||||||
|
+Activates MTD support for JEDEC compatible SPI NOR flash chips on SPI bus
|
||||||
|
+supported by the kernel SPI NOR driver
|
||||||
|
+
|
||||||
|
+SPI 0 pins (MOSI, MISO, SCK, CS): PC0, PC1, PC2, PC3
|
||||||
|
+SPI 1 pins (MOSI, MISO, SCK, CS): PA15, PA16, PA14, PA13
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_spinor_spi_bus (int)
|
||||||
|
+ SPI bus to activate SPI NOR flash support on
|
||||||
|
+ Required
|
||||||
|
+ Supported values: 0, 1
|
||||||
|
+
|
||||||
|
+param_spinor_spi_cs (int)
|
||||||
|
+ SPI chip select number
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ Supported values: 0, 1
|
||||||
|
+ Using chip select 1 requires using "spi-add-cs1" overlay
|
||||||
|
+
|
||||||
|
+param_spinor_max_freq (int)
|
||||||
|
+ Maximum SPI frequency
|
||||||
|
+ Optional
|
||||||
|
+ Default: 1000000
|
||||||
|
+ Range: 3000 - 100000000
|
||||||
|
+
|
||||||
|
+### spi-spidev
|
||||||
|
+
|
||||||
|
+Activates SPIdev device node (/dev/spidevX.Y) for userspace SPI access,
|
||||||
|
+where X is the bus number and Y is the CS number
|
||||||
|
+
|
||||||
|
+SPI 0 pins (MOSI, MISO, SCK, CS): PC0, PC1, PC2, PC3
|
||||||
|
+SPI 1 pins (MOSI, MISO, SCK, CS): PA15, PA16, PA14, PA13
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_spidev_spi_bus (int)
|
||||||
|
+ SPI bus to activate SPIdev support on
|
||||||
|
+ Required
|
||||||
|
+ Supported values: 0, 1
|
||||||
|
+
|
||||||
|
+param_spidev_spi_cs (int)
|
||||||
|
+ SPI chip select number
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ Supported values: 0, 1
|
||||||
|
+ Using chip select 1 requires using "spi-add-cs1" overlay
|
||||||
|
+
|
||||||
|
+param_spidev_max_freq (int)
|
||||||
|
+ Maximum SPIdev frequency
|
||||||
|
+ Optional
|
||||||
|
+ Default: 1000000
|
||||||
|
+ Range: 3000 - 100000000
|
||||||
|
+
|
||||||
|
+### uart1
|
||||||
|
+
|
||||||
|
+Activates serial port 1 (/dev/ttyS1)
|
||||||
|
+
|
||||||
|
+UART 1 pins (TX, RX, RTS, CTS): PG6, PG7, PG8, PG9
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_uart1_rtscts (bool)
|
||||||
|
+ Enable RTS and CTS pins
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ Set to 1 to enable
|
||||||
|
+
|
||||||
|
+### uart2
|
||||||
|
+
|
||||||
|
+Activates serial port 2 (/dev/ttyS2)
|
||||||
|
+
|
||||||
|
+UART 2 pins (TX, RX, RTS, CTS): PA0, PA1, PA2, PA3
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_uart2_rtscts (bool)
|
||||||
|
+ Enable RTS and CTS pins
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ Set to 1 to enable CTS and RTS pins
|
||||||
|
+
|
||||||
|
+### uart3
|
||||||
|
+
|
||||||
|
+Activates serial port 3 (/dev/ttyS3)
|
||||||
|
+
|
||||||
|
+UART 3 pins (TX, RX, RTS, CTS): PA13, PA14, PA15, PA16
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_uart3_rtscts (bool)
|
||||||
|
+ Enable RTS and CTS pins
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ Set to 1 to enable CTS and RTS pins
|
||||||
|
+
|
||||||
|
+### usbhost0
|
||||||
|
+
|
||||||
|
+Activates USB host controller 0
|
||||||
|
+
|
||||||
|
+### usbhost2
|
||||||
|
+
|
||||||
|
+Activates USB host controller 2
|
||||||
|
+
|
||||||
|
+### usbhost3
|
||||||
|
+
|
||||||
|
+Activates USB host controller 3
|
||||||
|
+
|
||||||
|
+### w1-gpio
|
||||||
|
+
|
||||||
|
+Activates 1-Wire GPIO master
|
||||||
|
+Requires an external pull-up resistor on the data pin
|
||||||
|
+or enabling the internal pull-up
|
||||||
|
+
|
||||||
|
+Parameters:
|
||||||
|
+
|
||||||
|
+param_w1_pin (pin)
|
||||||
|
+ Data pin for 1-Wire master
|
||||||
|
+ Optional
|
||||||
|
+ Default: PD14
|
||||||
|
+
|
||||||
|
+param_w1_pin_int_pullup (bool)
|
||||||
|
+ Enable internal pull-up for the data pin
|
||||||
|
+ Optional
|
||||||
|
+ Default: 0
|
||||||
|
+ Set to 1 to enable the pull-up
|
||||||
|
+ This option should not be used with multiple devices, parasite power setup
|
||||||
|
+ or long wires - please use external pull-up resistor instead
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-analog-codec.dts b/arch/arm/boot/dts/overlay/sun8i-h3-analog-codec.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..36dbc31a
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-analog-codec.dts
|
||||||
|
@@ -0,0 +1,17 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&codec>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ allwinner,audio-routing =
|
||||||
|
+ "Line Out", "LINEOUT",
|
||||||
|
+ "MIC1", "Mic",
|
||||||
|
+ "Mic", "MBIAS";
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-cir.dts b/arch/arm/boot/dts/overlay/sun8i-h3-cir.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..9b62fd2b
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-cir.dts
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&ir>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&ir_pins_a>;
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-fixup.scr-cmd b/arch/arm/boot/dts/overlay/sun8i-h3-fixup.scr-cmd
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..744889c6
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-fixup.scr-cmd
|
||||||
|
@@ -0,0 +1,110 @@
|
||||||
|
+# overlays fixup script
|
||||||
|
+# implements (or rather substitutes) overlay arguments functionality
|
||||||
|
+# using u-boot scripting, environment variables and "fdt" command
|
||||||
|
+
|
||||||
|
+# setexpr test_var ${tmp_bank} - A
|
||||||
|
+# works only for hex numbers (A-F)
|
||||||
|
+
|
||||||
|
+setenv decompose_pin 'setexpr tmp_bank sub "P(A|C|D|G)\\d+" "\\1";
|
||||||
|
+setexpr tmp_pin sub "P\\S(\\d+)" "\\1";
|
||||||
|
+test "${tmp_bank}" = "A" && setenv tmp_bank 0;
|
||||||
|
+test "${tmp_bank}" = "C" && setenv tmp_bank 2;
|
||||||
|
+test "${tmp_bank}" = "D" && setenv tmp_bank 3;
|
||||||
|
+test "${tmp_bank}" = "G" && setenv tmp_bank 6'
|
||||||
|
+
|
||||||
|
+if test -n "${param_spinor_spi_bus}"; then
|
||||||
|
+ test "${param_spinor_spi_bus}" = "0" && setenv tmp_spi_path "spi@01c68000"
|
||||||
|
+ test "${param_spinor_spi_bus}" = "1" && setenv tmp_spi_path "spi@01c69000"
|
||||||
|
+ fdt set /soc/${tmp_spi_path} status "okay"
|
||||||
|
+ fdt set /soc/${tmp_spi_path}/spiflash status "okay"
|
||||||
|
+ if test -n "${param_spinor_max_freq}"; then
|
||||||
|
+ fdt set /soc/${tmp_spi_path}/spiflash spi-max-frequency "<${param_spinor_max_freq}>"
|
||||||
|
+ fi
|
||||||
|
+ if test "${param_spinor_spi_cs}" = "1"; then
|
||||||
|
+ fdt set /soc/${tmp_spi_path}/spiflash reg "<1>"
|
||||||
|
+ fi
|
||||||
|
+ env delete tmp_spi_path
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test -n "${param_spidev_spi_bus}"; then
|
||||||
|
+ test "${param_spidev_spi_bus}" = "0" && setenv tmp_spi_path "spi@01c68000"
|
||||||
|
+ test "${param_spidev_spi_bus}" = "1" && setenv tmp_spi_path "spi@01c69000"
|
||||||
|
+ fdt set /soc/${tmp_spi_path} status "okay"
|
||||||
|
+ fdt set /soc/${tmp_spi_path}/spidev status "okay"
|
||||||
|
+ if test -n "${param_spidev_max_freq}"; then
|
||||||
|
+ fdt set /soc/${tmp_spi_path}/spidev spi-max-frequency "<${param_spidev_max_freq}>"
|
||||||
|
+ fi
|
||||||
|
+ if test "${param_spidev_spi_cs}" = "1"; then
|
||||||
|
+ fdt set /soc/${tmp_spi_path}/spidev reg "<1>"
|
||||||
|
+ fi
|
||||||
|
+ env delete tmp_spi_path
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test -n "${param_pps_pin}"; then
|
||||||
|
+ setenv tmp_bank "${param_pps_pin}"
|
||||||
|
+ setenv tmp_pin "${param_pps_pin}"
|
||||||
|
+ run decompose_pin
|
||||||
|
+ fdt set /soc/pinctrl@01c20800/pps_pins pins "${param_pps_pin}"
|
||||||
|
+ fdt get value tmp_phandle /soc/pinctrl@01c20800 phandle
|
||||||
|
+ fdt set /pps@0 gpios "<${tmp_phandle} ${tmp_bank} ${tmp_pin} 0>"
|
||||||
|
+ env delete tmp_pin tmp_bank tmp_phandle
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test "${param_pps_falling_edge}" = "1"; then
|
||||||
|
+ fdt set /pps@0 assert-falling-edge
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+for f in ${overlays}; do
|
||||||
|
+ if test "${f}" = "pwm"; then
|
||||||
|
+ setenv bootargs_new ""
|
||||||
|
+ for arg in ${bootargs}; do
|
||||||
|
+ if test "${arg}" = "console=ttyS0,115200"; then
|
||||||
|
+ echo "Warning: Disabling ttyS0 console due to enabled PWM overlay"
|
||||||
|
+ else
|
||||||
|
+ setenv bootargs_new "${bootargs_new} ${arg}"
|
||||||
|
+ fi
|
||||||
|
+ done
|
||||||
|
+ setenv bootargs "${bootargs_new}"
|
||||||
|
+ fi
|
||||||
|
+done
|
||||||
|
+
|
||||||
|
+if test -n "${param_w1_pin}"; then
|
||||||
|
+ setenv tmp_bank "${param_w1_pin}"
|
||||||
|
+ setenv tmp_pin "${param_w1_pin}"
|
||||||
|
+ run decompose_pin
|
||||||
|
+ fdt set /soc/pinctrl@01c20800/w1_pins pins "${param_w1_pin}"
|
||||||
|
+ fdt get value tmp_phandle /soc/pinctrl@01c20800 phandle
|
||||||
|
+ fdt set /onewire@0 gpios "<${tmp_phandle} ${tmp_bank} ${tmp_pin} 0>"
|
||||||
|
+ env delete tmp_pin tmp_bank tmp_phandle
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test "${param_w1_pin_int_pullup}" = "1"; then
|
||||||
|
+ fdt set /soc/pinctrl@01c20800/w1_pins bias-pull-up
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test "${param_uart1_rtscts}" = "1"; then
|
||||||
|
+ fdt get value tmp_phandle1 /soc/pinctrl@01c20800/uart1 phandle
|
||||||
|
+ fdt get value tmp_phandle2 /soc/pinctrl@01c20800/uart1_rts_cts phandle
|
||||||
|
+ fdt set /soc/serial@01c28400 pinctrl-names "default" "default"
|
||||||
|
+ fdt set /soc/serial@01c28400 pinctrl-0 "<${tmp_phandle1}>"
|
||||||
|
+ fdt set /soc/serial@01c28400 pinctrl-1 "<${tmp_phandle2}>"
|
||||||
|
+ env delete tmp_phandle1 tmp_phandle2
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test "${param_uart2_rtscts}" = "1"; then
|
||||||
|
+ fdt get value tmp_phandle1 /soc/pinctrl@01c20800/uart2 phandle
|
||||||
|
+ fdt get value tmp_phandle2 /soc/pinctrl@01c20800/uart2_rts_cts phandle
|
||||||
|
+ fdt set /soc/serial@01c28800 pinctrl-names "default" "default"
|
||||||
|
+ fdt set /soc/serial@01c28800 pinctrl-0 "<${tmp_phandle1}>"
|
||||||
|
+ fdt set /soc/serial@01c28800 pinctrl-1 "<${tmp_phandle2}>"
|
||||||
|
+ env delete tmp_phandle1 tmp_phandle2
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if test "${param_uart3_rtscts}" = "1"; then
|
||||||
|
+ fdt get value tmp_phandle1 /soc/pinctrl@01c20800/uart3 phandle
|
||||||
|
+ fdt get value tmp_phandle2 /soc/pinctrl@01c20800/uart3_rts_cts phandle
|
||||||
|
+ fdt set /soc/serial@01c28c00 pinctrl-names "default" "default"
|
||||||
|
+ fdt set /soc/serial@01c28c00 pinctrl-0 "<${tmp_phandle1}>"
|
||||||
|
+ fdt set /soc/serial@01c28c00 pinctrl-1 "<${tmp_phandle2}>"
|
||||||
|
+ env delete tmp_phandle1 tmp_phandle2
|
||||||
|
+fi
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-i2c0.dts b/arch/arm/boot/dts/overlay/sun8i-h3-i2c0.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..b457ac71
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-i2c0.dts
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ i2c0 = "/soc/i2c@01c2ac00";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&i2c0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-i2c1.dts b/arch/arm/boot/dts/overlay/sun8i-h3-i2c1.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..fd0928a1
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-i2c1.dts
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ i2c1 = "/soc/i2c@01c2b000";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&i2c1>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-i2c2.dts b/arch/arm/boot/dts/overlay/sun8i-h3-i2c2.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..25b75b71
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-i2c2.dts
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ i2c2 = "/soc/i2c@01c2b400";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&i2c2>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-pps-gpio.dts b/arch/arm/boot/dts/overlay/sun8i-h3-pps-gpio.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..16a737b0
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-pps-gpio.dts
|
||||||
|
@@ -0,0 +1,29 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&pio>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pps_pins: pps_pins {
|
||||||
|
+ pins = "PD14";
|
||||||
|
+ function = "gpio_in";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target-path = "/";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pps@0 {
|
||||||
|
+ compatible = "pps-gpio";
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&pps_pins>;
|
||||||
|
+ gpios = <&pio 3 14 0>; /* PD14 */
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-pwm.dts b/arch/arm/boot/dts/overlay/sun8i-h3-pwm.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..ed3b8e60
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-pwm.dts
|
||||||
|
@@ -0,0 +1,39 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/chosen";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ /delete-property/ stdout-path;
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&uart0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "disabled";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@2 {
|
||||||
|
+ target = <&pio>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pwm0_pin: pwm0 {
|
||||||
|
+ pins = "PA5";
|
||||||
|
+ function = "pwm0";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@3 {
|
||||||
|
+ target = <&pwm>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&pwm0_pin>;
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-spdif-out.dts b/arch/arm/boot/dts/overlay/sun8i-h3-spdif-out.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..c7c01411
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-spdif-out.dts
|
||||||
|
@@ -0,0 +1,38 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&spdif>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&spdif_tx_pins_a>;
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target-path = "/";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ sound {
|
||||||
|
+ compatible = "simple-audio-card";
|
||||||
|
+ simple-audio-card,name = "On-board SPDIF";
|
||||||
|
+
|
||||||
|
+ simple-audio-card,cpu {
|
||||||
|
+ sound-dai = <&spdif>;
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ simple-audio-card,codec {
|
||||||
|
+ sound-dai = <&spdif_out>;
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ spdif_out: spdif-out {
|
||||||
|
+ #sound-dai-cells = <0>;
|
||||||
|
+ compatible = "linux,spdif-dit";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-spi-add-cs1.dts b/arch/arm/boot/dts/overlay/sun8i-h3-spi-add-cs1.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..bd8e2561
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-spi-add-cs1.dts
|
||||||
|
@@ -0,0 +1,41 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&pio>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ spi0_cs1: spi0_cs1 {
|
||||||
|
+ pins = "PA21";
|
||||||
|
+ function = "gpio_out";
|
||||||
|
+ output-high;
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ spi1_cs1: spi1_cs1 {
|
||||||
|
+ pins = "PA10";
|
||||||
|
+ function = "gpio_out";
|
||||||
|
+ output-high;
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&spi0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default", "default";
|
||||||
|
+ pinctrl-1 = <&spi0_cs1>;
|
||||||
|
+ cs-gpios = <0>, <&pio 0 21 0>; /* PA21 */
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@2 {
|
||||||
|
+ target = <&spi1>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default", "default";
|
||||||
|
+ pinctrl-1 = <&spi1_cs1>;
|
||||||
|
+ cs-gpios = <0>, <&pio 0 10 0>; /* PA10 */
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-spi-jedec-nor.dts b/arch/arm/boot/dts/overlay/sun8i-h3-spi-jedec-nor.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..ad22a71a
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-spi-jedec-nor.dts
|
||||||
|
@@ -0,0 +1,42 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ spi0 = "/soc/spi@01c68000";
|
||||||
|
+ spi1 = "/soc/spi@01c69000";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&spi0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ #address-cells = <1>;
|
||||||
|
+ #size-cells = <0>;
|
||||||
|
+ spiflash {
|
||||||
|
+ compatible = "jedec,spi-nor";
|
||||||
|
+ reg = <0>;
|
||||||
|
+ spi-max-frequency = <1000000>;
|
||||||
|
+ status = "disabled";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@2 {
|
||||||
|
+ target = <&spi1>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ #address-cells = <1>;
|
||||||
|
+ #size-cells = <0>;
|
||||||
|
+ spiflash {
|
||||||
|
+ compatible = "jedec,spi-nor";
|
||||||
|
+ reg = <0>;
|
||||||
|
+ spi-max-frequency = <1000000>;
|
||||||
|
+ status = "disabled";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-spi-spidev.dts b/arch/arm/boot/dts/overlay/sun8i-h3-spi-spidev.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..180979e0
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-spi-spidev.dts
|
||||||
|
@@ -0,0 +1,42 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ spi0 = "/soc/spi@01c68000";
|
||||||
|
+ spi1 = "/soc/spi@01c69000";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&spi0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ #address-cells = <1>;
|
||||||
|
+ #size-cells = <0>;
|
||||||
|
+ spidev {
|
||||||
|
+ compatible = "spidev";
|
||||||
|
+ status = "disabled";
|
||||||
|
+ reg = <0>;
|
||||||
|
+ spi-max-frequency = <1000000>;
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@2 {
|
||||||
|
+ target = <&spi1>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ #address-cells = <1>;
|
||||||
|
+ #size-cells = <0>;
|
||||||
|
+ spidev {
|
||||||
|
+ compatible = "spidev";
|
||||||
|
+ status = "disabled";
|
||||||
|
+ reg = <0>;
|
||||||
|
+ spi-max-frequency = <1000000>;
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-uart1.dts b/arch/arm/boot/dts/overlay/sun8i-h3-uart1.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..8a4f7e49
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-uart1.dts
|
||||||
|
@@ -0,0 +1,22 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ serial1 = "/soc/serial@01c28400";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&uart1>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&uart1_pins>;
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-uart2.dts b/arch/arm/boot/dts/overlay/sun8i-h3-uart2.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..499a1b49
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-uart2.dts
|
||||||
|
@@ -0,0 +1,22 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ serial2 = "/soc/serial@01c28800";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&uart2>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&uart2_pins>;
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-uart3.dts b/arch/arm/boot/dts/overlay/sun8i-h3-uart3.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..b5734c5b
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-uart3.dts
|
||||||
|
@@ -0,0 +1,22 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target-path = "/aliases";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ serial3 = "/soc/serial@01c28c00";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&uart3>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&uart3_pins>;
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-usbhost0.dts b/arch/arm/boot/dts/overlay/sun8i-h3-usbhost0.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..ff1d82fd
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-usbhost0.dts
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&ehci0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&ohci0>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-usbhost2.dts b/arch/arm/boot/dts/overlay/sun8i-h3-usbhost2.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..bf0c4f59
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-usbhost2.dts
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&ehci2>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&ohci2>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-usbhost3.dts b/arch/arm/boot/dts/overlay/sun8i-h3-usbhost3.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..f737075b
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-usbhost3.dts
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&ehci3>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target = <&ohci3>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
||||||
|
diff --git a/arch/arm/boot/dts/overlay/sun8i-h3-w1-gpio.dts b/arch/arm/boot/dts/overlay/sun8i-h3-w1-gpio.dts
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..f4ccb7fb
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/arch/arm/boot/dts/overlay/sun8i-h3-w1-gpio.dts
|
||||||
|
@@ -0,0 +1,29 @@
|
||||||
|
+/dts-v1/;
|
||||||
|
+/plugin/;
|
||||||
|
+
|
||||||
|
+/ {
|
||||||
|
+ compatible = "allwinner,sun8i-h3";
|
||||||
|
+
|
||||||
|
+ fragment@0 {
|
||||||
|
+ target = <&pio>;
|
||||||
|
+ __overlay__ {
|
||||||
|
+ w1_pins: w1_pins {
|
||||||
|
+ pins = "PD14";
|
||||||
|
+ function = "gpio_in";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+ fragment@1 {
|
||||||
|
+ target-path = "/";
|
||||||
|
+ __overlay__ {
|
||||||
|
+ onewire@0 {
|
||||||
|
+ compatible = "w1-gpio";
|
||||||
|
+ pinctrl-names = "default";
|
||||||
|
+ pinctrl-0 = <&w1_pins>;
|
||||||
|
+ gpios = <&pio 3 14 0>; /* PD14 */
|
||||||
|
+ status = "okay";
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+ };
|
||||||
|
+};
|
|
@ -0,0 +1,133 @@
|
||||||
|
diff --git a/arch/arm/Makefile b/arch/arm/Makefile
|
||||||
|
index ab30cc63..cc176797 100644
|
||||||
|
--- a/arch/arm/Makefile
|
||||||
|
+++ b/arch/arm/Makefile
|
||||||
|
@@ -339,6 +339,12 @@ $(INSTALL_TARGETS):
|
||||||
|
%.dtb: | scripts
|
||||||
|
$(Q)$(MAKE) $(build)=$(boot)/dts MACHINE=$(MACHINE) $(boot)/dts/$@
|
||||||
|
|
||||||
|
+%.dtbo: | scripts
|
||||||
|
+ $(Q)$(MAKE) $(build)=$(boot)/dts MACHINE=$(MACHINE) $(boot)/dts/$@
|
||||||
|
+
|
||||||
|
+%.scr: | scripts
|
||||||
|
+ $(Q)$(MAKE) $(build)=$(boot)/dts ARCH=$(ARCH) $(boot)/dts/$@
|
||||||
|
+
|
||||||
|
PHONY += dtbs dtbs_install
|
||||||
|
|
||||||
|
dtbs: prepare scripts
|
||||||
|
diff --git a/arch/arm/boot/.gitignore b/arch/arm/boot/.gitignore
|
||||||
|
index 3c79f859..eaaeb17e 100644
|
||||||
|
--- a/arch/arm/boot/.gitignore
|
||||||
|
+++ b/arch/arm/boot/.gitignore
|
||||||
|
@@ -3,4 +3,5 @@ zImage
|
||||||
|
xipImage
|
||||||
|
bootpImage
|
||||||
|
uImage
|
||||||
|
-*.dtb
|
||||||
|
+*.dtb*
|
||||||
|
+*.scr
|
||||||
|
diff --git a/arch/arm64/Makefile b/arch/arm64/Makefile
|
||||||
|
index b9a4a934..54e3c38d 100644
|
||||||
|
--- a/arch/arm64/Makefile
|
||||||
|
+++ b/arch/arm64/Makefile
|
||||||
|
@@ -119,6 +119,12 @@ zinstall install:
|
||||||
|
%.dtb: scripts
|
||||||
|
$(Q)$(MAKE) $(build)=$(boot)/dts $(boot)/dts/$@
|
||||||
|
|
||||||
|
+%.dtbo: | scripts
|
||||||
|
+ $(Q)$(MAKE) $(build)=$(boot)/dts MACHINE=$(MACHINE) $(boot)/dts/$@
|
||||||
|
+
|
||||||
|
+%.scr: | scripts
|
||||||
|
+ $(Q)$(MAKE) $(build)=$(boot)/dts ARCH=$(ARCH) $(boot)/dts/$@
|
||||||
|
+
|
||||||
|
PHONY += dtbs dtbs_install
|
||||||
|
|
||||||
|
dtbs: prepare scripts
|
||||||
|
diff --git a/arch/arm64/boot/dts/.gitignore b/arch/arm64/boot/dts/.gitignore
|
||||||
|
index b60ed208..5d65b54b 100644
|
||||||
|
--- a/arch/arm64/boot/dts/.gitignore
|
||||||
|
+++ b/arch/arm64/boot/dts/.gitignore
|
||||||
|
@@ -1 +1,2 @@
|
||||||
|
-*.dtb
|
||||||
|
+*.dtb*
|
||||||
|
+*.scr
|
||||||
|
diff --git a/scripts/Makefile.dtbinst b/scripts/Makefile.dtbinst
|
||||||
|
index a1be75d0..ad8dc1c9 100644
|
||||||
|
--- a/scripts/Makefile.dtbinst
|
||||||
|
+++ b/scripts/Makefile.dtbinst
|
||||||
|
@@ -27,6 +27,9 @@ ifeq ("$(dtbinst-root)", "$(obj)")
|
||||||
|
endif
|
||||||
|
|
||||||
|
dtbinst-files := $(dtb-y)
|
||||||
|
+dtboinst-files := $(dtbo-y)
|
||||||
|
+script-files := $(scr-y)
|
||||||
|
+readme-files := $(dtbotxt-y)
|
||||||
|
dtbinst-dirs := $(dts-dirs)
|
||||||
|
|
||||||
|
# Helper targets for Installing DTBs into the boot directory
|
||||||
|
@@ -35,15 +38,24 @@ quiet_cmd_dtb_install = INSTALL $<
|
||||||
|
|
||||||
|
install-dir = $(patsubst $(dtbinst-root)%,$(INSTALL_DTBS_PATH)%,$(obj))
|
||||||
|
|
||||||
|
-$(dtbinst-files) $(dtbinst-dirs): | __dtbs_install_prep
|
||||||
|
+$(dtbinst-files) $(dtboinst-files) $(readme-files) $(script-files) $(dtbinst-dirs): | __dtbs_install_prep
|
||||||
|
|
||||||
|
$(dtbinst-files): %.dtb: $(obj)/%.dtb
|
||||||
|
$(call cmd,dtb_install,$(install-dir))
|
||||||
|
|
||||||
|
+$(dtboinst-files): %.dtbo: $(obj)/%.dtbo
|
||||||
|
+ $(call cmd,dtb_install,$(install-dir))
|
||||||
|
+
|
||||||
|
+$(script-files): %.scr: $(obj)/%.scr
|
||||||
|
+ $(call cmd,dtb_install,$(install-dir))
|
||||||
|
+
|
||||||
|
+$(readme-files): %: $(src)/%
|
||||||
|
+ $(call cmd,dtb_install,$(install-dir))
|
||||||
|
+
|
||||||
|
$(dtbinst-dirs):
|
||||||
|
$(Q)$(MAKE) $(dtbinst)=$(obj)/$@
|
||||||
|
|
||||||
|
-PHONY += $(dtbinst-files) $(dtbinst-dirs)
|
||||||
|
-__dtbs_install: $(dtbinst-files) $(dtbinst-dirs)
|
||||||
|
+PHONY += $(dtbinst-files) $(dtboinst-files) $(script-files) $(readme-files) $(dtbinst-dirs)
|
||||||
|
+__dtbs_install: $(dtbinst-files) $(dtboinst-files) $(script-files) $(readme-files) $(dtbinst-dirs)
|
||||||
|
|
||||||
|
.PHONY: $(PHONY)
|
||||||
|
diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib
|
||||||
|
index 0a07f901..5ccd3490 100644
|
||||||
|
--- a/scripts/Makefile.lib
|
||||||
|
+++ b/scripts/Makefile.lib
|
||||||
|
@@ -278,6 +278,9 @@ cmd_gzip = (cat $(filter-out FORCE,$^) | gzip -n -f -9 > $@) || \
|
||||||
|
# ---------------------------------------------------------------------------
|
||||||
|
DTC ?= $(objtree)/scripts/dtc/dtc
|
||||||
|
|
||||||
|
+# Overlay support
|
||||||
|
+DTC_FLAGS += -@ -Wno-unit_address_format -Wno-simple_bus_reg
|
||||||
|
+
|
||||||
|
# Disable noisy checks by default
|
||||||
|
ifeq ($(KBUILD_ENABLE_EXTRA_GCC_CHECKS),)
|
||||||
|
DTC_FLAGS += -Wno-unit_address_vs_reg
|
||||||
|
@@ -312,6 +315,23 @@ cmd_dtc = mkdir -p $(dir ${dtc-tmp}) ; \
|
||||||
|
$(obj)/%.dtb: $(src)/%.dts FORCE
|
||||||
|
$(call if_changed_dep,dtc)
|
||||||
|
|
||||||
|
+quiet_cmd_dtco = DTCO $@
|
||||||
|
+cmd_dtco = mkdir -p $(dir ${dtc-tmp}) ; \
|
||||||
|
+ $(CPP) $(dtc_cpp_flags) -x assembler-with-cpp -o $(dtc-tmp) $< ; \
|
||||||
|
+ $(DTC) -O dtb -o $@ -b 0 \
|
||||||
|
+ -i $(dir $<) $(DTC_FLAGS) \
|
||||||
|
+ -d $(depfile).dtc.tmp $(dtc-tmp) ; \
|
||||||
|
+ cat $(depfile).pre.tmp $(depfile).dtc.tmp > $(depfile)
|
||||||
|
+
|
||||||
|
+$(obj)/%.dtbo: $(src)/%.dts FORCE
|
||||||
|
+ $(call if_changed_dep,dtco)
|
||||||
|
+
|
||||||
|
+quiet_cmd_scr = MKIMAGE $@
|
||||||
|
+cmd_scr = mkimage -C none -A $(ARCH) -T script -d $< $@
|
||||||
|
+
|
||||||
|
+$(obj)/%.scr: $(src)/%.scr-cmd FORCE
|
||||||
|
+ $(call if_changed,scr)
|
||||||
|
+
|
||||||
|
dtc-tmp = $(subst $(comma),_,$(dot-target).dts.tmp)
|
||||||
|
|
||||||
|
# Bzip2
|
|
@ -0,0 +1,23 @@
|
||||||
|
diff --git a/arch/arm/boot/dts/sun8i-h3-orangepi-pc-plus.dts b/arch/arm/boot/dts/sun8i-h3-orangepi-pc-plus.dts
|
||||||
|
index 8b93f5c7..db8c3fb4 100644
|
||||||
|
--- a/arch/arm/boot/dts/sun8i-h3-orangepi-pc-plus.dts
|
||||||
|
+++ b/arch/arm/boot/dts/sun8i-h3-orangepi-pc-plus.dts
|
||||||
|
@@ -51,12 +51,18 @@
|
||||||
|
/* ethernet0 is the H3 emac, defined in sun8i-h3.dtsi */
|
||||||
|
ethernet1 = &rtl8189ftv;
|
||||||
|
};
|
||||||
|
+
|
||||||
|
+ wifi_pwrseq: wifi_pwrseq {
|
||||||
|
+ compatible = "mmc-pwrseq-simple";
|
||||||
|
+ reset-gpios = <&r_pio 0 7 GPIO_ACTIVE_LOW>; /* PL7 WIFI_EN */
|
||||||
|
+ };
|
||||||
|
};
|
||||||
|
|
||||||
|
&mmc1 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&mmc1_pins_a>;
|
||||||
|
vmmc-supply = <®_vcc3v3>;
|
||||||
|
+ mmc-pwrseq = <&wifi_pwrseq>;
|
||||||
|
bus-width = <4>;
|
||||||
|
non-removable;
|
||||||
|
status = "okay";
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -1,182 +0,0 @@
|
||||||
diff --git a/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts b/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts
|
|
||||||
index 1550fee1..63c54989 100644
|
|
||||||
--- a/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts
|
|
||||||
+++ b/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts
|
|
||||||
@@ -47,6 +47,7 @@
|
|
||||||
#include <dt-bindings/gpio/gpio.h>
|
|
||||||
#include <dt-bindings/input/input.h>
|
|
||||||
#include <dt-bindings/pinctrl/sun4i-a10.h>
|
|
||||||
+#include <dt-bindings/thermal/thermal.h>
|
|
||||||
|
|
||||||
/ {
|
|
||||||
model = "Xunlong Orange Pi Lite";
|
|
||||||
@@ -90,6 +91,89 @@
|
|
||||||
gpios = <&r_pio 0 3 GPIO_ACTIVE_LOW>;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
+
|
|
||||||
+ wifi_pwrseq: wifi_pwrseq {
|
|
||||||
+ compatible = "mmc-pwrseq-simple";
|
|
||||||
+ pinctrl-names = "default";
|
|
||||||
+ pinctrl-0 = <&wifi_pwrseq_pin_orangepi>;
|
|
||||||
+ reset-gpios = <&r_pio 0 7 GPIO_ACTIVE_LOW>; /* PL7 WIFI_EN */
|
|
||||||
+ };
|
|
||||||
+
|
|
||||||
+ vdd_cpux: gpio-regulator {
|
|
||||||
+ compatible = "regulator-gpio";
|
|
||||||
+
|
|
||||||
+ pinctrl-names = "default";
|
|
||||||
+ pinctrl-0 = <&vdd_cpux_r_opc>;
|
|
||||||
+
|
|
||||||
+ regulator-name = "vdd-cpux";
|
|
||||||
+ regulator-type = "voltage";
|
|
||||||
+ regulator-boot-on;
|
|
||||||
+ regulator-always-on;
|
|
||||||
+ regulator-min-microvolt = <1100000>;
|
|
||||||
+ regulator-max-microvolt = <1300000>;
|
|
||||||
+ regulator-ramp-delay = <50>; /* 4ms */
|
|
||||||
+
|
|
||||||
+ gpios = <&r_pio 0 6 GPIO_ACTIVE_HIGH>;
|
|
||||||
+ gpios-states = <0x1>;
|
|
||||||
+ states = <1100000 0x0
|
|
||||||
+ 1300000 0x1>;
|
|
||||||
+ };
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
+&cpu0 {
|
|
||||||
+ operating-points = <
|
|
||||||
+ 1008000 1300000
|
|
||||||
+ 816000 1100000
|
|
||||||
+ 624000 1100000
|
|
||||||
+ 480000 1100000
|
|
||||||
+ 312000 1100000
|
|
||||||
+ 240000 1100000
|
|
||||||
+ 120000 1100000
|
|
||||||
+ >;
|
|
||||||
+ #cooling-cells = <2>;
|
|
||||||
+ cooling-min-level = <0>;
|
|
||||||
+ cooling-max-level = <6>;
|
|
||||||
+ cpu0-supply = <&vdd_cpux>;
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
+&cpu_thermal {
|
|
||||||
+ trips {
|
|
||||||
+ cpu_warm: cpu_warm {
|
|
||||||
+ temperature = <65000>;
|
|
||||||
+ hysteresis = <2000>;
|
|
||||||
+ type = "passive";
|
|
||||||
+ };
|
|
||||||
+ cpu_hot: cpu_hot {
|
|
||||||
+ temperature = <75000>;
|
|
||||||
+ hysteresis = <2000>;
|
|
||||||
+ type = "passive";
|
|
||||||
+ };
|
|
||||||
+ cpu_very_hot: cpu_very_hot {
|
|
||||||
+ temperature = <90000>;
|
|
||||||
+ hysteresis = <2000>;
|
|
||||||
+ type = "passive";
|
|
||||||
+ };
|
|
||||||
+ cpu_crit: cpu_crit {
|
|
||||||
+ temperature = <105000>;
|
|
||||||
+ hysteresis = <2000>;
|
|
||||||
+ type = "critical";
|
|
||||||
+ };
|
|
||||||
+ };
|
|
||||||
+
|
|
||||||
+ cooling-maps {
|
|
||||||
+ cpu_warm_limit_cpu {
|
|
||||||
+ trip = <&cpu_warm>;
|
|
||||||
+ cooling-device = <&cpu0 THERMAL_NO_LIMIT 1>;
|
|
||||||
+ };
|
|
||||||
+ cpu_hot_limit_cpu {
|
|
||||||
+ trip = <&cpu_hot>;
|
|
||||||
+ cooling-device = <&cpu0 2 3>;
|
|
||||||
+ };
|
|
||||||
+ cpu_very_hot_limit_cpu {
|
|
||||||
+ trip = <&cpu_very_hot>;
|
|
||||||
+ cooling-device = <&cpu0 5 THERMAL_NO_LIMIT>;
|
|
||||||
+ };
|
|
||||||
+ };
|
|
||||||
};
|
|
||||||
|
|
||||||
&ehci1 {
|
|
||||||
@@ -120,6 +204,7 @@
|
|
||||||
pinctrl-names = "default";
|
|
||||||
pinctrl-0 = <&mmc1_pins_a>;
|
|
||||||
vmmc-supply = <®_vcc3v3>;
|
|
||||||
+ mmc-pwrseq = <&wifi_pwrseq>;
|
|
||||||
bus-width = <4>;
|
|
||||||
non-removable;
|
|
||||||
status = "okay";
|
|
||||||
@@ -148,6 +233,13 @@
|
|
||||||
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
|
|
||||||
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
};
|
|
||||||
+
|
|
||||||
+ usb0_id_detect_pin: usb0_id_detect_pin@0 {
|
|
||||||
+ allwinner,pins = "PG12";
|
|
||||||
+ allwinner,function = "gpio_in";
|
|
||||||
+ allwinner,drive = <SUN4I_PINCTRL_10_MA>;
|
|
||||||
+ allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
+ };
|
|
||||||
};
|
|
||||||
|
|
||||||
&r_pio {
|
|
||||||
@@ -158,12 +250,39 @@
|
|
||||||
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
};
|
|
||||||
|
|
||||||
+ wifi_pwrseq_pin_orangepi: wifi_pwrseq_pin@0 {
|
|
||||||
+ allwinner,pins = "PL7";
|
|
||||||
+ allwinner,function = "gpio_out";
|
|
||||||
+ allwinner,drive = <SUN4I_PINCTRL_10_MA>;
|
|
||||||
+ allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
+ };
|
|
||||||
+
|
|
||||||
sw_r_opc: key_pins@0 {
|
|
||||||
allwinner,pins = "PL3";
|
|
||||||
allwinner,function = "gpio_in";
|
|
||||||
allwinner,drive = <SUN4I_PINCTRL_10_MA>;
|
|
||||||
allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
};
|
|
||||||
+
|
|
||||||
+ vdd_cpux_r_opc: regulator_pins@0 {
|
|
||||||
+ allwinner,pins = "PL6";
|
|
||||||
+ allwinner,function = "gpio_out";
|
|
||||||
+ allwinner,drive = <SUN4I_PINCTRL_10_MA>;
|
|
||||||
+ allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
+ };
|
|
||||||
+
|
|
||||||
+ usb0_vbus_pin_opipc: usb0_vbus_pin@0 {
|
|
||||||
+ allwinner,pins = "PL2";
|
|
||||||
+ allwinner,function = "gpio_out";
|
|
||||||
+ allwinner,drive = <SUN4I_PINCTRL_10_MA>;
|
|
||||||
+ allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
|
|
||||||
+ };
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
+®_usb0_vbus {
|
|
||||||
+ pinctrl-0 = <&usb0_vbus_pin_opipc>;
|
|
||||||
+ gpio = <&r_pio 0 2 GPIO_ACTIVE_HIGH>; /* PL2 */
|
|
||||||
+ status = "okay";
|
|
||||||
};
|
|
||||||
|
|
||||||
&uart0 {
|
|
||||||
@@ -172,7 +291,16 @@
|
|
||||||
status = "okay";
|
|
||||||
};
|
|
||||||
|
|
||||||
+&usb_otg {
|
|
||||||
+ dr_mode = "otg";
|
|
||||||
+ status = "okay";
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
&usbphy {
|
|
||||||
- /* USB VBUS is always on */
|
|
||||||
+ /* USB VBUS is always on except for the OTG port */
|
|
||||||
status = "okay";
|
|
||||||
+ pinctrl-names = "default";
|
|
||||||
+ pinctrl-0 = <&usb0_id_detect_pin>;
|
|
||||||
+ usb0_id_det-gpios = <&pio 6 12 GPIO_ACTIVE_HIGH>; /* PG12 */
|
|
||||||
+ usb0_vbus-supply = <®_usb0_vbus>;
|
|
||||||
};
|
|
|
@ -1,26 +0,0 @@
|
||||||
diff --git a/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts b/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts
|
|
||||||
index 63c5498..c585618 100644
|
|
||||||
--- a/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts
|
|
||||||
+++ b/arch/arm/boot/dts/sun8i-h3-orangepi-lite.dts
|
|
||||||
@@ -122,7 +122,7 @@
|
|
||||||
|
|
||||||
&cpu0 {
|
|
||||||
operating-points = <
|
|
||||||
- 1008000 1300000
|
|
||||||
+ 1200000 1300000
|
|
||||||
816000 1100000
|
|
||||||
624000 1100000
|
|
||||||
480000 1100000
|
|
||||||
diff --git a/arch/arm/boot/dts/sun8i-h3-orangepi-one.dts b/arch/arm/boot/dts/sun8i-h3-orangepi-one.dts
|
|
||||||
index 87e495f..fb85217 100644
|
|
||||||
--- a/arch/arm/boot/dts/sun8i-h3-orangepi-one.dts
|
|
||||||
+++ b/arch/arm/boot/dts/sun8i-h3-orangepi-one.dts
|
|
||||||
@@ -115,7 +115,7 @@
|
|
||||||
|
|
||||||
&cpu0 {
|
|
||||||
operating-points = <
|
|
||||||
- 1008000 1300000
|
|
||||||
+ 1200000 1300000
|
|
||||||
816000 1100000
|
|
||||||
624000 1100000
|
|
||||||
480000 1100000
|
|
|
@ -7,19 +7,30 @@ FILESEXTRAPATHS_prepend := "${THISDIR}/${PN}:"
|
||||||
PV = "4.11.0+git${SRCPV}"
|
PV = "4.11.0+git${SRCPV}"
|
||||||
SRCREV_pn-${PN} = "22521549cdcd4d701cf3079c3a822bda5324df9c"
|
SRCREV_pn-${PN} = "22521549cdcd4d701cf3079c3a822bda5324df9c"
|
||||||
SRC_URI_append = "git://github.com/megous/linux.git;protocol=git;branch=orange-pi-4.11 \
|
SRC_URI_append = "git://github.com/megous/linux.git;protocol=git;branch=orange-pi-4.11 \
|
||||||
file://fix-i2c2-reg-property.patch \
|
file://411-fix-i2c2-reg-property.patch \
|
||||||
file://411-add-thermal-otg-wireless-opi-lite.patch \
|
file://411-add-thermal-otg-wireless-opi-lite.patch \
|
||||||
file://411-enable-1200mhz-on-small-orangepis.patch \
|
file://411-enable-1200mhz-on-small-orangepis.patch \
|
||||||
file://411-add-spi-aliases.patch \
|
file://411-add-spi-aliases.patch \
|
||||||
file://411-add-uart-rts-cts-pins.patch \
|
file://411-add-uart-rts-cts-pins.patch \
|
||||||
|
file://411-add-configfs-overlay-for-v4.11.x.patch \
|
||||||
|
file://411-add-h3-overlays.patch \
|
||||||
|
file://411-add-overlay-compilation-support.patch \
|
||||||
|
file://411-scripts-dtc-import-updates.patch \
|
||||||
|
file://411-add-ad9834-dt-bindings.patch \
|
||||||
"
|
"
|
||||||
|
|
||||||
SRC_URI_append_orange-pi-lite = " \
|
SRC_URI_append_orange-pi-lite = " \
|
||||||
file://411-add-realtek-8189fs-driver.patch \
|
file://411-add-realtek-8189fs-driver.patch \
|
||||||
"
|
"
|
||||||
|
|
||||||
## Add these patches once moved to linux 4.11 or 4.12
|
RESIN_CONFIGS_append = " \
|
||||||
## file://fix-i2c2-reg-property.patch \
|
configfs \
|
||||||
## 4.10 patches:
|
"
|
||||||
## file://add-thermal-otg-wireless-opi-lite.patch \
|
|
||||||
## file://enable-1200mhz-on-small-orangepis.patch \
|
RESIN_CONFIGS[configfs] ?= " \
|
||||||
|
CONFIG_OF_CONFIGFS=y \
|
||||||
|
"
|
||||||
|
|
||||||
|
RESIN_CONFIGS_DEPS[configfs] ?= " \
|
||||||
|
CONFIG_OF_OVERLAY=y \
|
||||||
|
"
|
Loading…
Add table
Reference in a new issue