Signed-off-by: Stefano Babic <sbabic@denx.de>master
commit
2d221489df
@ -1,15 +0,0 @@ |
||||
#
|
||||
# Copyright 2011 Linaro Limited
|
||||
#
|
||||
# (C) Copyright 2010
|
||||
# Texas Instruments, <www.ti.com>
|
||||
#
|
||||
# Aneesh V <aneesh@ti.com>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
ifdef CONFIG_SPL_BUILD |
||||
ALL-y += MLO
|
||||
else |
||||
ALL-y += u-boot.img
|
||||
endif |
@ -1,15 +0,0 @@ |
||||
#
|
||||
# Copyright 2011 Linaro Limited
|
||||
#
|
||||
# (C) Copyright 2010
|
||||
# Texas Instruments, <www.ti.com>
|
||||
#
|
||||
# Aneesh V <aneesh@ti.com>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
ifdef CONFIG_SPL_BUILD |
||||
ALL-y += MLO
|
||||
else |
||||
ALL-y += u-boot.img
|
||||
endif |
@ -1,22 +0,0 @@ |
||||
#
|
||||
# Copyright 2011 Linaro Limited
|
||||
#
|
||||
# Aneesh V <annesh@ti.com>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
include $(srctree)/$(CPUDIR)/omap-common/config_secure.mk |
||||
|
||||
ifdef CONFIG_SPL_BUILD |
||||
ifeq ($(CONFIG_TI_SECURE_DEVICE),y) |
||||
ALL-y += u-boot-spl_HS_MLO u-boot-spl_HS_X-LOADER
|
||||
else |
||||
ALL-y += MLO
|
||||
endif |
||||
else |
||||
ifeq ($(CONFIG_TI_SECURE_DEVICE),y) |
||||
ALL-$(CONFIG_SPL_LOAD_FIT) += u-boot_HS.img
|
||||
endif |
||||
ALL-y += u-boot.img
|
||||
endif |
@ -0,0 +1,42 @@ |
||||
QSPI Boot source support Overview |
||||
------------------- |
||||
1. LS1043A |
||||
LS1043AQDS |
||||
2. LS2080A |
||||
LS2080AQDS |
||||
3. LS1012A |
||||
LS1012AQDS |
||||
LS1012ARDB |
||||
4. LS1046A |
||||
LS1046AQDS |
||||
LS1046ARDB |
||||
|
||||
Booting from QSPI |
||||
------------------- |
||||
Booting from QSPI requires two images, RCW and u-boot-dtb.bin. |
||||
The difference between QSPI boot RCW image and NOR boot image is the PBI |
||||
command sequence for setting the boot location pointer. It's should point |
||||
to the address for u-boot in QSPI flash. |
||||
|
||||
RCW image should be written to the beginning of QSPI flash device. |
||||
Example of using u-boot command |
||||
|
||||
=> sf probe 0:0 |
||||
SF: Detected S25FL256S_64K with page size 256 Bytes, erase size 64 KiB, total 32 MiB |
||||
=> sf erase 0 +<size of rcw image> |
||||
SF: 65536 bytes @ 0x0 Erased: OK |
||||
=> sf write <rcw image in memory> 0 <size of rcw image> |
||||
SF: 164 bytes @ 0x0 Written: OK |
||||
|
||||
To get the QSPI image, build u-boot with QSPI config, for example, |
||||
<board_name>_qspi_defconfig. The image needed is u-boot-dtb.bin. |
||||
The u-boot image should be written to 0x10000(but 0x1000 for LS1043A, LS2080A). |
||||
|
||||
=> sf probe 0:0 |
||||
SF: Detected S25FL256S_64K with page size 256 Bytes, erase size 64 KiB, total 32 MiB |
||||
=> sf erase 10000 +<size of u-boot image> |
||||
SF: 589824 bytes @ 0x10000 Erased: OK |
||||
=> sf write <u-boot image in memory> 10000 <size of u-boot image> |
||||
SF: 580966 bytes @ 0x10000 Written: OK |
||||
|
||||
With these two images in QSPI flash device, the board can boot from QSPI. |
@ -0,0 +1,16 @@ |
||||
/* |
||||
* Device Tree file for Freescale Layerscape-1046A family SoC. |
||||
* |
||||
* Copyright (C) 2016, Freescale Semiconductor |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
/dts-v1/; |
||||
#include "fsl-ls1046a-qds.dtsi" |
||||
|
||||
/ { |
||||
chosen { |
||||
stdout-path = &lpuart0; |
||||
}; |
||||
}; |
@ -0,0 +1,16 @@ |
||||
/* |
||||
* Freescale ls1021a IOT board device tree source |
||||
* |
||||
* Copyright 2016 Freescale Semiconductor, Inc. |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
/dts-v1/; |
||||
#include "ls1021a-iot.dtsi" |
||||
|
||||
/ { |
||||
chosen { |
||||
stdout-path = &uart0; |
||||
}; |
||||
}; |
@ -0,0 +1,103 @@ |
||||
/* |
||||
* Freescale ls1021a IOT board device tree source |
||||
* |
||||
* Copyright 2016 Freescale Semiconductor, Inc. |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
|
||||
#include "ls1021a.dtsi" |
||||
|
||||
/ { |
||||
model = "LS1021A IOT Board"; |
||||
|
||||
aliases { |
||||
enet2_rgmii_phy = &rgmii_phy1; |
||||
enet0_sgmii_phy = &sgmii_phy2; |
||||
enet1_sgmii_phy = &sgmii_phy0; |
||||
spi0 = &qspi; |
||||
spi1 = &dspi1; |
||||
}; |
||||
}; |
||||
|
||||
&qspi { |
||||
bus-num = <0>; |
||||
status = "okay"; |
||||
|
||||
qflash0: n25q128a13@0 { |
||||
#address-cells = <1>; |
||||
#size-cells = <1>; |
||||
compatible = "spi-flash"; |
||||
spi-max-frequency = <20000000>; |
||||
reg = <0>; |
||||
}; |
||||
}; |
||||
|
||||
&dspi1 { |
||||
bus-num = <0>; |
||||
status = "okay"; |
||||
|
||||
dspiflash: at26df081a@0 { |
||||
#address-cells = <1>; |
||||
#size-cells = <1>; |
||||
compatible = "spi-flash"; |
||||
spi-max-frequency = <16000000>; |
||||
spi-cpol; |
||||
spi-cpha; |
||||
reg = <0>; |
||||
}; |
||||
}; |
||||
|
||||
&i2c0 { |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&i2c1 { |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&ifc { |
||||
#address-cells = <2>; |
||||
#size-cells = <1>; |
||||
/* NOR Flash on board */ |
||||
ranges = <0x0 0x0 0x60000000 0x08000000>; |
||||
status = "okay"; |
||||
|
||||
nor@0,0 { |
||||
#address-cells = <1>; |
||||
#size-cells = <1>; |
||||
compatible = "cfi-flash"; |
||||
reg = <0x0 0x0 0x8000000>; |
||||
bank-width = <2>; |
||||
device-width = <1>; |
||||
}; |
||||
}; |
||||
|
||||
&lpuart0 { |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&mdio0 { |
||||
sgmii_phy0: ethernet-phy@0 { |
||||
reg = <0x0>; |
||||
}; |
||||
rgmii_phy1: ethernet-phy@1 { |
||||
reg = <0x1>; |
||||
}; |
||||
sgmii_phy2: ethernet-phy@2 { |
||||
reg = <0x2>; |
||||
}; |
||||
tbi1: tbi-phy@1f { |
||||
reg = <0x1f>; |
||||
device_type = "tbi-phy"; |
||||
}; |
||||
}; |
||||
|
||||
&uart0 { |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&uart1 { |
||||
status = "okay"; |
||||
}; |
@ -0,0 +1,277 @@ |
||||
/* |
||||
* Google Veyron Mickey Rev 0 board device tree source |
||||
* |
||||
* Copyright 2015 Google, Inc |
||||
* |
||||
* 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 "rk3288-veyron-chromebook.dtsi" |
||||
|
||||
/ { |
||||
model = "Google Mickey"; |
||||
compatible = "google,veyron-mickey-rev8", "google,veyron-mickey-rev7", |
||||
"google,veyron-mickey-rev6", "google,veyron-mickey-rev5", |
||||
"google,veyron-mickey-rev4", "google,veyron-mickey-rev3", |
||||
"google,veyron-mickey-rev2", "google,veyron-mickey-rev1", |
||||
"google,veyron-mickey-rev0", "google,veyron-mickey", |
||||
"google,veyron", "rockchip,rk3288"; |
||||
|
||||
vcc_5v: vcc-5v { |
||||
vin-supply = <&vcc33_sys>; |
||||
}; |
||||
|
||||
vcc33_io: vcc33_io { |
||||
compatible = "regulator-fixed"; |
||||
regulator-name = "vcc33_io"; |
||||
regulator-always-on; |
||||
regulator-boot-on; |
||||
vin-supply = <&vcc33_sys>; |
||||
}; |
||||
}; |
||||
|
||||
&cpu_thermal { |
||||
/delete-node/ trips; |
||||
/delete-node/ cooling-maps; |
||||
|
||||
trips { |
||||
cpu_alert_almost_warm: cpu_alert_almost_warm { |
||||
temperature = <63000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "passive"; |
||||
}; |
||||
cpu_alert_warm: cpu_alert_warm { |
||||
temperature = <65000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "passive"; |
||||
}; |
||||
cpu_alert_almost_hot: cpu_alert_almost_hot { |
||||
temperature = <80000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "passive"; |
||||
}; |
||||
cpu_alert_hot: cpu_alert_hot { |
||||
temperature = <82000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "passive"; |
||||
}; |
||||
cpu_alert_hotter: cpu_alert_hotter { |
||||
temperature = <84000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "passive"; |
||||
}; |
||||
cpu_alert_very_hot: cpu_alert_very_hot { |
||||
temperature = <85000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "passive"; |
||||
}; |
||||
cpu_crit: cpu_crit { |
||||
temperature = <90000>; /* millicelsius */ |
||||
hysteresis = <2000>; /* millicelsius */ |
||||
type = "critical"; |
||||
}; |
||||
}; |
||||
|
||||
cooling-maps { |
||||
/* |
||||
* After 1st level, throttle the CPU down to as low as 1.4 GHz |
||||
* and don't let the GPU go faster than 400 MHz. Note that we |
||||
* won't throttle the GPU lower than 400 MHz due to CPU |
||||
* heat--we'll let the GPU do the rest itself. |
||||
*/ |
||||
cpu_warm_limit_cpu { |
||||
trip = <&cpu_alert_warm>; |
||||
cooling-device = |
||||
<&cpu0 THERMAL_NO_LIMIT 4>; |
||||
}; |
||||
|
||||
/* |
||||
* Add some discrete steps to help throttling system deal |
||||
* with the fact that there are two passive cooling devices: |
||||
* the CPU and the GPU. |
||||
* |
||||
* - 1.2 GHz - 1.0 GHz (almost hot) |
||||
* - 800 MHz (hot) |
||||
* - 800 MHz - 696 MHz (hotter) |
||||
* - 696 MHz - min (very hot) |
||||
* |
||||
* Note: |
||||
* - 800 MHz appears to be a "sweet spot" for me. I can run |
||||
* some pretty serious workload here and be happy. |
||||
* - After 696 MHz we stop lowering voltage, so throttling |
||||
* past there is less effective. |
||||
*/ |
||||
cpu_almost_hot_limit_cpu { |
||||
trip = <&cpu_alert_almost_hot>; |
||||
cooling-device = |
||||
<&cpu0 5 6>; |
||||
}; |
||||
cpu_hot_limit_cpu { |
||||
trip = <&cpu_alert_hot>; |
||||
cooling-device = |
||||
<&cpu0 7 7>; |
||||
}; |
||||
cpu_hotter_limit_cpu { |
||||
trip = <&cpu_alert_hotter>; |
||||
cooling-device = |
||||
<&cpu0 7 8>; |
||||
}; |
||||
cpu_very_hot_limit_cpu { |
||||
trip = <&cpu_alert_very_hot>; |
||||
cooling-device = |
||||
<&cpu0 8 THERMAL_NO_LIMIT>; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&dmc { |
||||
rockchip,pctl-timing = <0x215 0xc8 0x0 0x35 0x26 0x2 0x70 0x2000d |
||||
0x6 0x0 0x8 0x4 0x17 0x24 0xd 0x6 |
||||
0x4 0x8 0x4 0x76 0x4 0x0 0x30 0x0 |
||||
0x1 0x2 0x2 0x4 0x0 0x0 0xc0 0x4 |
||||
0x8 0x1f4>; |
||||
rockchip,phy-timing = <0x48d7dd93 0x187008d8 0x121076 |
||||
0x0 0xc3 0x6 0x2>; |
||||
rockchip,sdram-params = <0x20d266a4 0x5b6 2 533000000 6 9 1>; |
||||
}; |
||||
|
||||
&emmc { |
||||
/delete-property/mmc-hs200-1_8v; |
||||
}; |
||||
|
||||
&i2c2 { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&i2c4 { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&i2s { |
||||
status = "okay"; |
||||
clock-names = "i2s_hclk", "i2s_clk", "i2s_clk_out"; |
||||
clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>, <&cru SCLK_I2S0_OUT>; |
||||
}; |
||||
|
||||
&rk808 { |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&pmic_int_l &dvs_1 &dvs_2>; |
||||
dvs-gpios = <&gpio7 12 GPIO_ACTIVE_HIGH>, |
||||
<&gpio7 15 GPIO_ACTIVE_HIGH>; |
||||
|
||||
/delete-property/ vcc6-supply; |
||||
/delete-property/ vcc12-supply; |
||||
|
||||
vcc11-supply = <&vcc33_sys>; |
||||
|
||||
regulators { |
||||
/* vcc33_io is sourced directly from vcc33_sys */ |
||||
/delete-node/ LDO_REG1; |
||||
/delete-node/ LDO_REG7; |
||||
|
||||
/* This is not a pwren anymore, but the real power supply */ |
||||
vdd10_lcd: LDO_REG7 { |
||||
regulator-always-on; |
||||
regulator-boot-on; |
||||
regulator-min-microvolt = <1000000>; |
||||
regulator-max-microvolt = <1000000>; |
||||
regulator-name = "vdd10_lcd"; |
||||
regulator-suspend-mem-disabled; |
||||
}; |
||||
|
||||
vcc18_lcd: LDO_REG8 { |
||||
regulator-always-on; |
||||
regulator-boot-on; |
||||
regulator-min-microvolt = <1800000>; |
||||
regulator-max-microvolt = <1800000>; |
||||
regulator-name = "vcc18_lcd"; |
||||
regulator-suspend-mem-disabled; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&pinctrl { |
||||
hdmi { |
||||
power_hdmi_on: power-hdmi-on { |
||||
rockchip,pins = <7 11 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
|
||||
pmic { |
||||
dvs_1: dvs-1 { |
||||
rockchip,pins = <7 12 RK_FUNC_GPIO &pcfg_pull_down>; |
||||
}; |
||||
|
||||
dvs_2: dvs-2 { |
||||
rockchip,pins = <7 15 RK_FUNC_GPIO &pcfg_pull_down>; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&sdmmc { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&sdio0 { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&sdmmc { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&spi0 { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&usb_host0_ehci { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&usb_host1 { |
||||
status = "disabled"; |
||||
}; |
||||
|
||||
&vcc50_hdmi { |
||||
enable-active-high; |
||||
gpio = <&gpio7 11 GPIO_ACTIVE_HIGH>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&power_hdmi_on>; |
||||
}; |
@ -0,0 +1,301 @@ |
||||
/* |
||||
* Google Veyron Minnie Rev 0+ board device tree source |
||||
* |
||||
* Copyright 2015 Google, Inc |
||||
* |
||||
* 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 "rk3288-veyron-chromebook.dtsi" |
||||
|
||||
/ { |
||||
model = "Google Minnie"; |
||||
compatible = "google,veyron-minnie-rev4", "google,veyron-minnie-rev3", |
||||
"google,veyron-minnie-rev2", "google,veyron-minnie-rev1", |
||||
"google,veyron-minnie-rev0", "google,veyron-minnie", |
||||
"google,veyron", "rockchip,rk3288"; |
||||
|
||||
backlight_regulator: backlight-regulator { |
||||
compatible = "regulator-fixed"; |
||||
enable-active-high; |
||||
gpio = <&gpio2 12 GPIO_ACTIVE_HIGH>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&bl_pwr_en>; |
||||
regulator-name = "backlight_regulator"; |
||||
vin-supply = <&vcc33_sys>; |
||||
startup-delay-us = <15000>; |
||||
}; |
||||
|
||||
panel_regulator: panel-regulator { |
||||
compatible = "regulator-fixed"; |
||||
enable-active-high; |
||||
gpio = <&gpio7 14 GPIO_ACTIVE_HIGH>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&lcd_enable_h>; |
||||
regulator-name = "panel_regulator"; |
||||
startup-delay-us = <100000>; |
||||
vin-supply = <&vcc33_sys>; |
||||
}; |
||||
|
||||
vcc18_lcd: vcc18-lcd { |
||||
compatible = "regulator-fixed"; |
||||
enable-active-high; |
||||
gpio = <&gpio2 13 GPIO_ACTIVE_HIGH>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&avdd_1v8_disp_en>; |
||||
regulator-name = "vcc18_lcd"; |
||||
regulator-always-on; |
||||
regulator-boot-on; |
||||
vin-supply = <&vcc18_wl>; |
||||
}; |
||||
}; |
||||
|
||||
&backlight { |
||||
/* Minnie panel PWM must be >= 1%, so start non-zero brightness at 3 */ |
||||
brightness-levels = < |
||||
0 3 4 5 6 7 |
||||
8 9 10 11 12 13 14 15 |
||||
16 17 18 19 20 21 22 23 |
||||
24 25 26 27 28 29 30 31 |
||||
32 33 34 35 36 37 38 39 |
||||
40 41 42 43 44 45 46 47 |
||||
48 49 50 51 52 53 54 55 |
||||
56 57 58 59 60 61 62 63 |
||||
64 65 66 67 68 69 70 71 |
||||
72 73 74 75 76 77 78 79 |
||||
80 81 82 83 84 85 86 87 |
||||
88 89 90 91 92 93 94 95 |
||||
96 97 98 99 100 101 102 103 |
||||
104 105 106 107 108 109 110 111 |
||||
112 113 114 115 116 117 118 119 |
||||
120 121 122 123 124 125 126 127 |
||||
128 129 130 131 132 133 134 135 |
||||
136 137 138 139 140 141 142 143 |
||||
144 145 146 147 148 149 150 151 |
||||
152 153 154 155 156 157 158 159 |
||||
160 161 162 163 164 165 166 167 |
||||
168 169 170 171 172 173 174 175 |
||||
176 177 178 179 180 181 182 183 |
||||
184 185 186 187 188 189 190 191 |
||||
192 193 194 195 196 197 198 199 |
||||
200 201 202 203 204 205 206 207 |
||||
208 209 210 211 212 213 214 215 |
||||
216 217 218 219 220 221 222 223 |
||||
224 225 226 227 228 229 230 231 |
||||
232 233 234 235 236 237 238 239 |
||||
240 241 242 243 244 245 246 247 |
||||
248 249 250 251 252 253 254 255>; |
||||
power-supply = <&backlight_regulator>; |
||||
}; |
||||
|
||||
&dmc { |
||||
rockchip,pctl-timing = <0x215 0xc8 0x0 0x35 0x26 0x2 0x70 0x2000d |
||||
0x6 0x0 0x8 0x4 0x17 0x24 0xd 0x6 |
||||
0x4 0x8 0x4 0x76 0x4 0x0 0x30 0x0 |
||||
0x1 0x2 0x2 0x4 0x0 0x0 0xc0 0x4 |
||||
0x8 0x1f4>; |
||||
rockchip,phy-timing = <0x48d7dd93 0x187008d8 0x121076 |
||||
0x0 0xc3 0x6 0x1>; |
||||
rockchip,sdram-params = <0x20d266a4 0x5b6 6 533000000 6 13 0>; |
||||
}; |
||||
|
||||
&emmc { |
||||
/delete-property/mmc-hs200-1_8v; |
||||
}; |
||||
|
||||
&gpio_keys { |
||||
pinctrl-0 = <&pwr_key_h &ap_lid_int_l &volum_down_l &volum_up_l>; |
||||
|
||||
volum_down { |
||||
label = "Volum_down"; |
||||
gpios = <&gpio5 11 GPIO_ACTIVE_LOW>; |
||||
linux,code = <KEY_VOLUMEDOWN>; |
||||
debounce-interval = <100>; |
||||
}; |
||||
|
||||
volum_up { |
||||
label = "Volum_up"; |
||||
gpios = <&gpio5 10 GPIO_ACTIVE_LOW>; |
||||
linux,code = <KEY_VOLUMEUP>; |
||||
debounce-interval = <100>; |
||||
}; |
||||
}; |
||||
|
||||
&i2c_tunnel { |
||||
battery: bq27500@55 { |
||||
compatible = "ti,bq27500"; |
||||
reg = <0x55>; |
||||
}; |
||||
}; |
||||
|
||||
&i2c3 { |
||||
status = "okay"; |
||||
|
||||
clock-frequency = <400000>; |
||||
i2c-scl-falling-time-ns = <50>; |
||||
i2c-scl-rising-time-ns = <300>; |
||||
|
||||
touchscreen@10 { |
||||
compatible = "elan,ekth3500"; |
||||
reg = <0x10>; |
||||
interrupt-parent = <&gpio2>; |
||||
interrupts = <14 IRQ_TYPE_EDGE_FALLING>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&touch_int &touch_rst>; |
||||
reset-gpios = <&gpio2 15 GPIO_ACTIVE_LOW>; |
||||
vcc33-supply = <&vcc33_touch>; |
||||
vccio-supply = <&vcc33_touch>; |
||||
}; |
||||
}; |
||||
|
||||
&panel { |
||||
compatible = "auo,b101ean01", "simple-panel"; |
||||
power-supply= <&panel_regulator>; |
||||
}; |
||||
|
||||
&rk808 { |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&pmic_int_l &dvs_1 &dvs_2>; |
||||
|
||||
regulators { |
||||
vcc33_touch: LDO_REG2 { |
||||
regulator-min-microvolt = <3300000>; |
||||
regulator-max-microvolt = <3300000>; |
||||
regulator-name = "vcc33_touch"; |
||||
regulator-state-mem { |
||||
regulator-off-in-suspend; |
||||
}; |
||||
}; |
||||
|
||||
vcc5v_touch: SWITCH_REG2 { |
||||
regulator-name = "vcc5v_touch"; |
||||
regulator-state-mem { |
||||
regulator-off-in-suspend; |
||||
}; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&sdmmc { |
||||
disable-wp; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_cd_disabled &sdmmc_cd_gpio |
||||
&sdmmc_bus4>; |
||||
}; |
||||
|
||||
&vcc_5v { |
||||
enable-active-high; |
||||
gpio = <&gpio7 21 GPIO_ACTIVE_HIGH>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&drv_5v>; |
||||
}; |
||||
|
||||
&vcc50_hdmi { |
||||
enable-active-high; |
||||
gpio = <&gpio5 19 GPIO_ACTIVE_HIGH>; |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&vcc50_hdmi_en>; |
||||
}; |
||||
|
||||
&pinctrl { |
||||
backlight { |
||||
bl_pwr_en: bl_pwr_en { |
||||
rockchip,pins = <2 12 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
|
||||
buck-5v { |
||||
drv_5v: drv-5v { |
||||
rockchip,pins = <7 21 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
|
||||
buttons { |
||||
volum_down_l: volum-down-l { |
||||
rockchip,pins = <5 11 RK_FUNC_GPIO &pcfg_pull_up>; |
||||
}; |
||||
|
||||
volum_up_l: volum-up-l { |
||||
rockchip,pins = <5 10 RK_FUNC_GPIO &pcfg_pull_up>; |
||||
}; |
||||
}; |
||||
|
||||
hdmi { |
||||
vcc50_hdmi_en: vcc50-hdmi-en { |
||||
rockchip,pins = <5 19 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
|
||||
lcd { |
||||
lcd_enable_h: lcd-en { |
||||
rockchip,pins = <7 14 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
|
||||
avdd_1v8_disp_en: avdd-1v8-disp-en { |
||||
rockchip,pins = <2 13 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
|
||||
pmic { |
||||
dvs_1: dvs-1 { |
||||
rockchip,pins = <7 12 RK_FUNC_GPIO &pcfg_pull_down>; |
||||
}; |
||||
|
||||
dvs_2: dvs-2 { |
||||
rockchip,pins = <7 15 RK_FUNC_GPIO &pcfg_pull_down>; |
||||
}; |
||||
}; |
||||
|
||||
prochot { |
||||
gpio_prochot: gpio-prochot { |
||||
rockchip,pins = <2 8 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
|
||||
touchscreen { |
||||
touch_int: touch-int { |
||||
rockchip,pins = <2 14 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
|
||||
touch_rst: touch-rst { |
||||
rockchip,pins = <2 15 RK_FUNC_GPIO &pcfg_pull_none>; |
||||
}; |
||||
}; |
||||
}; |
@ -0,0 +1,63 @@ |
||||
/* |
||||
* Copyright (c) 2016 FUKAUMI Naoki <naobsd@gmail.com> |
||||
* |
||||
* 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 "sun8i-a33.dtsi" |
||||
|
||||
/ { |
||||
model = "Nintendo NES Classic Edition"; |
||||
compatible = "nintendo,nes-classic-edition", "allwinner,sun8i-a33"; |
||||
|
||||
aliases { |
||||
serial0 = &uart0; |
||||
}; |
||||
|
||||
chosen { |
||||
stdout-path = "serial0:115200n8"; |
||||
}; |
||||
}; |
||||
|
||||
&uart0 { |
||||
pinctrl-names = "default"; |
||||
pinctrl-0 = <&uart0_pins_a>; |
||||
status = "okay"; |
||||
}; |
@ -0,0 +1,97 @@ |
||||
/* |
||||
* Topic Miami board DTS |
||||
* |
||||
* Copyright (C) 2014-2016 Topic Embedded Products |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
/dts-v1/; |
||||
#include "zynq-7000.dtsi" |
||||
|
||||
/ { |
||||
model = "Topic Miami Zynq Board"; |
||||
compatible = "topic,miami", "xlnx,zynq-7000"; |
||||
|
||||
aliases { |
||||
ethernet0 = &gem0; |
||||
serial0 = &uart0; |
||||
spi0 = &qspi; |
||||
i2c0 = &i2c0; |
||||
i2c1 = &i2c1; |
||||
mmc0 = &sdhci0; |
||||
}; |
||||
|
||||
memory@0 { |
||||
device_type = "memory"; |
||||
reg = <0x0 0x40000000>; |
||||
}; |
||||
|
||||
chosen { |
||||
stdout-path = "serial0:115200n8"; |
||||
}; |
||||
}; |
||||
|
||||
&qspi { |
||||
u-boot,dm-pre-reloc; |
||||
status = "okay"; |
||||
is-dual = <0>; |
||||
num-cs = <1>; |
||||
flash@0 { |
||||
compatible = "st,m25p80", "n25q256a"; |
||||
m25p,fast-read; |
||||
reg = <0x0>; |
||||
spi-tx-bus-width = <1>; |
||||
spi-rx-bus-width = <4>; |
||||
spi-max-frequency = <100000000>; |
||||
#address-cells = <1>; |
||||
#size-cells = <1>; |
||||
partition@qspi-u-boot-spl { |
||||
label = "qspi-u-boot-spl"; |
||||
reg = <0x00000 0x10000>; |
||||
}; |
||||
partition@qspi-u-boot-img { |
||||
label = "qspi-u-boot-img"; |
||||
reg = <0x10000 0x60000>; |
||||
}; |
||||
partition@qspi-device-tree { |
||||
label = "qspi-device-tree"; |
||||
reg = <0x70000 0x10000>; |
||||
}; |
||||
partition@qspi-linux { |
||||
label = "qspi-linux"; |
||||
reg = <0x80000 0x400000>; |
||||
}; |
||||
partition@qspi-rootfs { |
||||
label = "qspi-rootfs"; |
||||
reg = <0x480000 0x1b80000>; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&i2c0 { |
||||
status = "okay"; |
||||
clock-frequency = <400000>; |
||||
}; |
||||
|
||||
&i2c1 { |
||||
status = "okay"; |
||||
clock-frequency = <400000>; |
||||
}; |
||||
|
||||
&clkc { |
||||
ps-clk-frequency = <33333333>; |
||||
}; |
||||
|
||||
&sdhci0 { |
||||
u-boot,dm-pre-reloc; |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&uart0 { |
||||
u-boot,dm-pre-reloc; |
||||
status = "okay"; |
||||
}; |
||||
|
||||
&usb0 { |
||||
status = "okay"; |
||||
}; |
@ -0,0 +1,17 @@ |
||||
/* |
||||
* Topic Miami Plus board DTS |
||||
* |
||||
* Copyright (C) 2016 Topic Embedded Products |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
#include "zynq-topic-miami.dts" |
||||
|
||||
/ { |
||||
model = "Topic Miami+ Zynq Board"; |
||||
compatible = "topic,miamiplus", "xlnx,zynq-7000"; |
||||
}; |
||||
|
||||
&qspi { |
||||
is-dual = <1>; |
||||
}; |
@ -0,0 +1,135 @@ |
||||
/* |
||||
* crt0-efi-aarch64.S - PE/COFF header for aarch64 EFI applications |
||||
* |
||||
* Copright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org>
|
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ BSD-2-Clause |
||||
* |
||||
* This file is taken and modified from the gnu-efi project. |
||||
*/ |
||||
|
||||
.section .text.head |
||||
|
||||
/* |
||||
* Magic "MZ" signature for PE/COFF |
||||
*/ |
||||
.globl ImageBase
|
||||
ImageBase: |
||||
.ascii "MZ" |
||||
.skip 58 /* 'MZ' + pad + offset == 64 */ |
||||
.long pe_header - ImageBase /* Offset to the PE header */ |
||||
pe_header: |
||||
.ascii "PE" |
||||
.short 0
|
||||
coff_header: |
||||
.short 0xaa64 /* AArch64 */ |
||||
.short 2 /* nr_sections */ |
||||
.long 0 /* TimeDateStamp */ |
||||
.long 0 /* PointerToSymbolTable */ |
||||
.long 1 /* NumberOfSymbols */ |
||||
.short section_table - optional_header /* SizeOfOptionalHeader */ |
||||
/* |
||||
* Characteristics: IMAGE_FILE_DEBUG_STRIPPED | |
||||
* IMAGE_FILE_EXECUTABLE_IMAGE | IMAGE_FILE_LINE_NUMS_STRIPPED |
||||
*/ |
||||
.short 0x206
|
||||
optional_header: |
||||
.short 0x20b /* PE32+ format */ |
||||
.byte 0x02 /* MajorLinkerVersion */ |
||||
.byte 0x14 /* MinorLinkerVersion */ |
||||
.long _edata - _start /* SizeOfCode */ |
||||
.long 0 /* SizeOfInitializedData */ |
||||
.long 0 /* SizeOfUninitializedData */ |
||||
.long _start - ImageBase /* AddressOfEntryPoint */ |
||||
.long _start - ImageBase /* BaseOfCode */ |
||||
|
||||
extra_header_fields: |
||||
.quad 0 /* ImageBase */ |
||||
.long 0x20 /* SectionAlignment */ |
||||
.long 0x8 /* FileAlignment */ |
||||
.short 0 /* MajorOperatingSystemVersion */ |
||||
.short 0 /* MinorOperatingSystemVersion */ |
||||
.short 0 /* MajorImageVersion */ |
||||
.short 0 /* MinorImageVersion */ |
||||
.short 0 /* MajorSubsystemVersion */ |
||||
.short 0 /* MinorSubsystemVersion */ |
||||
.long 0 /* Win32VersionValue */ |
||||
|
||||
.long _edata - ImageBase /* SizeOfImage */ |
||||
|
||||
/* |
||||
* Everything before the kernel image is considered part of the header |
||||
*/ |
||||
.long _start - ImageBase /* SizeOfHeaders */ |
||||
.long 0 /* CheckSum */ |
||||
.short EFI_SUBSYSTEM /* Subsystem */ |
||||
.short 0 /* DllCharacteristics */ |
||||
.quad 0 /* SizeOfStackReserve */ |
||||
.quad 0 /* SizeOfStackCommit */ |
||||
.quad 0 /* SizeOfHeapReserve */ |
||||
.quad 0 /* SizeOfHeapCommit */ |
||||
.long 0 /* LoaderFlags */ |
||||
.long 0x6 /* NumberOfRvaAndSizes */ |
||||
|
||||
.quad 0 /* ExportTable */ |
||||
.quad 0 /* ImportTable */ |
||||
.quad 0 /* ResourceTable */ |
||||
.quad 0 /* ExceptionTable */ |
||||
.quad 0 /* CertificationTable */ |
||||
.quad 0 /* BaseRelocationTable */ |
||||
|
||||
/* Section table */ |
||||
section_table: |
||||
|
||||
/* |
||||
* The EFI application loader requires a relocation section |
||||
* because EFI applications must be relocatable. This is a |
||||
* dummy section as far as we are concerned. |
||||
*/ |
||||
.ascii ".reloc" |
||||
.byte 0
|
||||
.byte 0 /* end of 0 padding of section name */ |
||||
.long 0
|
||||
.long 0
|
||||
.long 0 /* SizeOfRawData */ |
||||
.long 0 /* PointerToRawData */ |
||||
.long 0 /* PointerToRelocations */ |
||||
.long 0 /* PointerToLineNumbers */ |
||||
.short 0 /* NumberOfRelocations */ |
||||
.short 0 /* NumberOfLineNumbers */ |
||||
.long 0x42100040 /* Characteristics (section flags) */ |
||||
|
||||
|
||||
.ascii ".text" |
||||
.byte 0
|
||||
.byte 0
|
||||
.byte 0 /* end of 0 padding of section name */ |
||||
.long _edata - _start /* VirtualSize */ |
||||
.long _start - ImageBase /* VirtualAddress */ |
||||
.long _edata - _start /* SizeOfRawData */ |
||||
.long _start - ImageBase /* PointerToRawData */ |
||||
|
||||
.long 0 /* PointerToRelocations (0 for executables) */ |
||||
.long 0 /* PointerToLineNumbers (0 for executables) */ |
||||
.short 0 /* NumberOfRelocations (0 for executables) */ |
||||
.short 0 /* NumberOfLineNumbers (0 for executables) */ |
||||
.long 0xe0500020 /* Characteristics (section flags) */ |
||||
|
||||
_start: |
||||
stp x29, x30, [sp, #-32]! |
||||
mov x29, sp |
||||
|
||||
stp x0, x1, [sp, #16] |
||||
mov x2, x0 |
||||
mov x3, x1 |
||||
adr x0, ImageBase |
||||
adrp x1, _DYNAMIC |
||||
add x1, x1, #:lo12:_DYNAMIC |
||||
bl _relocate |
||||
cbnz x0, 0f |
||||
|
||||
ldp x0, x1, [sp, #16] |
||||
bl efi_main |
||||
|
||||
0: ldp x29, x30, [sp], #32 |
||||
ret |
@ -0,0 +1,138 @@ |
||||
/* |
||||
* crt0-efi-arm.S - PE/COFF header for ARM EFI applications |
||||
* |
||||
* Copright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org>
|
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ BSD-2-Clause |
||||
* |
||||
* This file is taken and modified from the gnu-efi project. |
||||
*/ |
||||
|
||||
.section .text.head |
||||
|
||||
/* |
||||
* Magic "MZ" signature for PE/COFF |
||||
*/ |
||||
.globl image_base
|
||||
image_base: |
||||
.ascii "MZ" |
||||
.skip 58 /* 'MZ' + pad + offset == 64 */ |
||||
.long pe_header - image_base /* Offset to the PE header */ |
||||
pe_header: |
||||
.ascii "PE" |
||||
.short 0
|
||||
coff_header: |
||||
.short 0x1c2 /* Mixed ARM/Thumb */ |
||||
.short 2 /* nr_sections */ |
||||
.long 0 /* TimeDateStamp */ |
||||
.long 0 /* PointerToSymbolTable */ |
||||
.long 1 /* NumberOfSymbols */ |
||||
.short section_table - optional_header /* SizeOfOptionalHeader */ |
||||
/* |
||||
* Characteristics: IMAGE_FILE_32BIT_MACHINE | |
||||
* IMAGE_FILE_DEBUG_STRIPPED | IMAGE_FILE_EXECUTABLE_IMAGE | |
||||
* IMAGE_FILE_LINE_NUMS_STRIPPED |
||||
*/ |
||||
.short 0x306
|
||||
optional_header: |
||||
.short 0x10b /* PE32+ format */ |
||||
.byte 0x02 /* MajorLinkerVersion */ |
||||
.byte 0x14 /* MinorLinkerVersion */ |
||||
.long _edata - _start /* SizeOfCode */ |
||||
.long 0 /* SizeOfInitializedData */ |
||||
.long 0 /* SizeOfUninitializedData */ |
||||
.long _start - image_base /* AddressOfEntryPoint */ |
||||
.long _start - image_base /* BaseOfCode */ |
||||
.long 0 /* BaseOfData */ |
||||
|
||||
extra_header_fields: |
||||
.long 0 /* image_base */ |
||||
.long 0x20 /* SectionAlignment */ |
||||
.long 0x8 /* FileAlignment */ |
||||
.short 0 /* MajorOperatingSystemVersion */ |
||||
.short 0 /* MinorOperatingSystemVersion */ |
||||
.short 0 /* MajorImageVersion */ |
||||
.short 0 /* MinorImageVersion */ |
||||
.short 0 /* MajorSubsystemVersion */ |
||||
.short 0 /* MinorSubsystemVersion */ |
||||
.long 0 /* Win32VersionValue */ |
||||
|
||||
.long _edata - image_base /* SizeOfImage */ |
||||
|
||||
/* |
||||
* Everything before the kernel image is considered part of the header |
||||
*/ |
||||
.long _start - image_base /* SizeOfHeaders */ |
||||
.long 0 /* CheckSum */ |
||||
.short EFI_SUBSYSTEM /* Subsystem */ |
||||
.short 0 /* DllCharacteristics */ |
||||
.long 0 /* SizeOfStackReserve */ |
||||
.long 0 /* SizeOfStackCommit */ |
||||
.long 0 /* SizeOfHeapReserve */ |
||||
.long 0 /* SizeOfHeapCommit */ |
||||
.long 0 /* LoaderFlags */ |
||||
.long 0x6 /* NumberOfRvaAndSizes */ |
||||
|
||||
.quad 0 /* ExportTable */ |
||||
.quad 0 /* ImportTable */ |
||||
.quad 0 /* ResourceTable */ |
||||
.quad 0 /* ExceptionTable */ |
||||
.quad 0 /* CertificationTable */ |
||||
.quad 0 /* BaseRelocationTable */ |
||||
|
||||
section_table: |
||||
|
||||
/* |
||||
* The EFI application loader requires a relocation section |
||||
* because EFI applications must be relocatable. This is a |
||||
* dummy section as far as we are concerned. |
||||
*/ |
||||
.ascii ".reloc" |
||||
.byte 0
|
||||
.byte 0 /* end of 0 padding of section name */ |
||||
.long 0
|
||||
.long 0
|
||||
.long 0 /* SizeOfRawData */ |
||||
.long 0 /* PointerToRawData */ |
||||
.long 0 /* PointerToRelocations */ |
||||
.long 0 /* PointerToLineNumbers */ |
||||
.short 0 /* NumberOfRelocations */ |
||||
.short 0 /* NumberOfLineNumbers */ |
||||
.long 0x42100040 /* Characteristics (section flags) */ |
||||
|
||||
.ascii ".text" |
||||
.byte 0
|
||||
.byte 0
|
||||
.byte 0 /* end of 0 padding of section name */ |
||||
.long _edata - _start /* VirtualSize */ |
||||
.long _start - image_base /* VirtualAddress */ |
||||
.long _edata - _start /* SizeOfRawData */ |
||||
.long _start - image_base /* PointerToRawData */ |
||||
|
||||
.long 0 /* PointerToRelocations (0 for executables) */ |
||||
.long 0 /* PointerToLineNumbers (0 for executables) */ |
||||
.short 0 /* NumberOfRelocations (0 for executables) */ |
||||
.short 0 /* NumberOfLineNumbers (0 for executables) */ |
||||
.long 0xe0500020 /* Characteristics (section flags) */ |
||||
|
||||
_start: |
||||
stmfd sp!, {r0-r2, lr} |
||||
|
||||
mov r2, r0 |
||||
mov r3, r1 |
||||
adr r1, .L_DYNAMIC |
||||
ldr r0, [r1] |
||||
add r1, r0, r1 |
||||
adr r0, image_base |
||||
bl _relocate |
||||
teq r0, #0 |
||||
bne 0f |
||||
|
||||
ldmfd sp, {r0-r1} |
||||
bl efi_main |
||||
|
||||
0: add sp, sp, #12 |
||||
ldr pc, [sp], #4 |
||||
|
||||
.L_DYNAMIC: |
||||
.word _DYNAMIC - . |
@ -0,0 +1,70 @@ |
||||
/* |
||||
* U-Boot aarch64 EFI linker script |
||||
* |
||||
* SPDX-License-Identifier: BSD-2-Clause |
||||
* |
||||
* Modified from elf_aarch64_efi.lds in gnu-efi |
||||
*/ |
||||
|
||||
OUTPUT_FORMAT("elf64-littleaarch64", "elf64-littleaarch64", "elf64-littleaarch64") |
||||
OUTPUT_ARCH(aarch64) |
||||
ENTRY(_start) |
||||
SECTIONS |
||||
{ |
||||
.text 0x0 : { |
||||
_text = .; |
||||
*(.text.head) |
||||
*(.text) |
||||
*(.text.*) |
||||
*(.gnu.linkonce.t.*) |
||||
*(.srodata) |
||||
*(.rodata*) |
||||
. = ALIGN(16); |
||||
} |
||||
_etext = .; |
||||
_text_size = . - _text; |
||||
.dynamic : { *(.dynamic) } |
||||
.data : { |
||||
_data = .; |
||||
*(.sdata) |
||||
*(.data) |
||||
*(.data1) |
||||
*(.data.*) |
||||
*(.got.plt) |
||||
*(.got) |
||||
|
||||
/* |
||||
* The EFI loader doesn't seem to like a .bss section, so we |
||||
* stick it all into .data: |
||||
*/ |
||||
. = ALIGN(16); |
||||
_bss = .; |
||||
*(.sbss) |
||||
*(.scommon) |
||||
*(.dynbss) |
||||
*(.bss) |
||||
*(.bss.*) |
||||
*(COMMON) |
||||
. = ALIGN(16); |
||||
_bss_end = .; |
||||
_edata = .; |
||||
} |
||||
.rela.dyn : { *(.rela.dyn) } |
||||
.rela.plt : { *(.rela.plt) } |
||||
.rela.got : { *(.rela.got) } |
||||
.rela.data : { *(.rela.data) *(.rela.data*) } |
||||
_data_size = . - _etext; |
||||
|
||||
. = ALIGN(4096); |
||||
.dynsym : { *(.dynsym) } |
||||
. = ALIGN(4096); |
||||
.dynstr : { *(.dynstr) } |
||||
. = ALIGN(4096); |
||||
.note.gnu.build-id : { *(.note.gnu.build-id) } |
||||
/DISCARD/ : { |
||||
*(.rel.reloc) |
||||
*(.eh_frame) |
||||
*(.note.GNU-stack) |
||||
} |
||||
.comment 0 : { *(.comment) } |
||||
} |
@ -0,0 +1,70 @@ |
||||
/* |
||||
* U-Boot ARM EFI linker script |
||||
* |
||||
* SPDX-License-Identifier: BSD-2-Clause |
||||
* |
||||
* Modified from elf_arm_efi.lds in gnu-efi |
||||
*/ |
||||
|
||||
OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm") |
||||
OUTPUT_ARCH(arm) |
||||
ENTRY(_start) |
||||
SECTIONS |
||||
{ |
||||
.text 0x0 : { |
||||
_text = .; |
||||
*(.text.head) |
||||
*(.text) |
||||
*(.text.*) |
||||
*(.gnu.linkonce.t.*) |
||||
*(.srodata) |
||||
*(.rodata*) |
||||
. = ALIGN(16); |
||||
} |
||||
_etext = .; |
||||
_text_size = . - _text; |
||||
.dynamic : { *(.dynamic) } |
||||
.data : { |
||||
_data = .; |
||||
*(.sdata) |
||||
*(.data) |
||||
*(.data1) |
||||
*(.data.*) |
||||
*(.got.plt) |
||||
*(.got) |
||||
|
||||
/* |
||||
* The EFI loader doesn't seem to like a .bss section, so we |
||||
* stick it all into .data: |
||||
*/ |
||||
. = ALIGN(16); |
||||
_bss = .; |
||||
*(.sbss) |
||||
*(.scommon) |
||||
*(.dynbss) |
||||
*(.bss) |
||||
*(.bss.*) |
||||
*(COMMON) |
||||
. = ALIGN(16); |
||||
_bss_end = .; |
||||
_edata = .; |
||||
} |
||||
.rel.dyn : { *(.rel.dyn) } |
||||
.rel.plt : { *(.rel.plt) } |
||||
.rel.got : { *(.rel.got) } |
||||
.rel.data : { *(.rel.data) *(.rel.data*) } |
||||
_data_size = . - _etext; |
||||
|
||||
. = ALIGN(4096); |
||||
.dynsym : { *(.dynsym) } |
||||
. = ALIGN(4096); |
||||
.dynstr : { *(.dynstr) } |
||||
. = ALIGN(4096); |
||||
.note.gnu.build-id : { *(.note.gnu.build-id) } |
||||
/DISCARD/ : { |
||||
*(.rel.reloc) |
||||
*(.eh_frame) |
||||
*(.note.GNU-stack) |
||||
} |
||||
.comment 0 : { *(.comment) } |
||||
} |
@ -0,0 +1,87 @@ |
||||
/* reloc_aarch64.c - position independent x86 ELF shared object relocator
|
||||
Copyright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org> |
||||
Copyright (C) 1999 Hewlett-Packard Co. |
||||
Contributed by David Mosberger <davidm@hpl.hp.com>. |
||||
|
||||
All rights reserved. |
||||
|
||||
Redistribution and use in source and binary forms, with or without |
||||
modification, are permitted provided that the following conditions |
||||
are met: |
||||
|
||||
* Redistributions of source code must retain the above copyright |
||||
notice, this list of conditions and the following disclaimer. |
||||
* Redistributions in binary form must reproduce the above |
||||
copyright notice, this list of conditions and the following |
||||
disclaimer in the documentation and/or other materials |
||||
provided with the distribution. |
||||
* Neither the name of Hewlett-Packard Co. nor the names of its |
||||
contributors may be used to endorse or promote products derived |
||||
from this software without specific prior written permission. |
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND |
||||
CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, |
||||
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
||||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS |
||||
BE LIABLE FOR ANYDIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, |
||||
OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
||||
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
||||
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR |
||||
TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF |
||||
THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
||||
SUCH DAMAGE. |
||||
*/ |
||||
|
||||
#include <efi.h> |
||||
|
||||
#include <elf.h> |
||||
|
||||
efi_status_t _relocate(long ldbase, Elf64_Dyn *dyn, efi_handle_t image, |
||||
struct efi_system_table *systab) |
||||
{ |
||||
long relsz = 0, relent = 0; |
||||
Elf64_Rela *rel = 0; |
||||
unsigned long *addr; |
||||
int i; |
||||
|
||||
for (i = 0; dyn[i].d_tag != DT_NULL; ++i) { |
||||
switch (dyn[i].d_tag) { |
||||
case DT_RELA: |
||||
rel = (Elf64_Rela *)((ulong)dyn[i].d_un.d_ptr + ldbase); |
||||
break; |
||||
case DT_RELASZ: |
||||
relsz = dyn[i].d_un.d_val; |
||||
break; |
||||
case DT_RELAENT: |
||||
relent = dyn[i].d_un.d_val; |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
} |
||||
|
||||
if (!rel && relent == 0) |
||||
return EFI_SUCCESS; |
||||
|
||||
if (!rel || relent == 0) |
||||
return EFI_LOAD_ERROR; |
||||
|
||||
while (relsz > 0) { |
||||
/* apply the relocs */ |
||||
switch (ELF64_R_TYPE(rel->r_info)) { |
||||
case R_AARCH64_NONE: |
||||
break; |
||||
case R_AARCH64_RELATIVE: |
||||
addr = (ulong *)(ldbase + rel->r_offset); |
||||
*addr = ldbase + rel->r_addend; |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
rel = (Elf64_Rela *)((char *)rel + relent); |
||||
relsz -= relent; |
||||
} |
||||
return EFI_SUCCESS; |
||||
} |
@ -0,0 +1,66 @@ |
||||
/*
|
||||
* reloc_arm.c - position-independent ARM ELF shared object relocator |
||||
* |
||||
* Copyright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org> |
||||
* Copyright (C) 1999 Hewlett-Packard Co. |
||||
* Contributed by David Mosberger <davidm@hpl.hp.com>. |
||||
* |
||||
* All rights reserved. |
||||
* |
||||
* SPDX-License-Identifier: BSD-3-Clause |
||||
* |
||||
* This file is taken and modified from the gnu-efi project. |
||||
*/ |
||||
|
||||
#include <efi.h> |
||||
#include <elf.h> |
||||
|
||||
efi_status_t _relocate(long ldbase, Elf32_Dyn *dyn, efi_handle_t image, |
||||
struct efi_system_table *systab) |
||||
{ |
||||
long relsz = 0, relent = 0; |
||||
Elf32_Rel *rel = 0; |
||||
ulong *addr; |
||||
int i; |
||||
|
||||
for (i = 0; dyn[i].d_tag != DT_NULL; ++i) { |
||||
switch (dyn[i].d_tag) { |
||||
case DT_REL: |
||||
rel = (Elf32_Rel *)((ulong)dyn[i].d_un.d_ptr |
||||
+ ldbase); |
||||
break; |
||||
case DT_RELSZ: |
||||
relsz = dyn[i].d_un.d_val; |
||||
break; |
||||
case DT_RELENT: |
||||
relent = dyn[i].d_un.d_val; |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
} |
||||
|
||||
if (!rel && relent == 0) |
||||
return EFI_SUCCESS; |
||||
|
||||
if (!rel || relent == 0) |
||||
return EFI_LOAD_ERROR; |
||||
|
||||
while (relsz > 0) { |
||||
/* apply the relocs */ |
||||
switch (ELF32_R_TYPE(rel->r_info)) { |
||||
case R_ARM_NONE: |
||||
break; |
||||
case R_ARM_RELATIVE: |
||||
addr = (ulong *)(ldbase + rel->r_offset); |
||||
*addr += ldbase; |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
rel = (Elf32_Rel *)((char *)rel + relent); |
||||
relsz -= relent; |
||||
} |
||||
|
||||
return EFI_SUCCESS; |
||||
} |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue