Merge branch 'master' into next
Merge in v2022.07-rc5.
This commit is contained in:
commit
52af0101be
2
.gitignore
vendored
2
.gitignore
vendored
@ -10,6 +10,7 @@
|
|||||||
*.asn1.[ch]
|
*.asn1.[ch]
|
||||||
*.bin
|
*.bin
|
||||||
*.cfgout
|
*.cfgout
|
||||||
|
*.cover
|
||||||
*.dtb
|
*.dtb
|
||||||
*.dtbo
|
*.dtbo
|
||||||
*.dtb.S
|
*.dtb.S
|
||||||
@ -22,6 +23,7 @@
|
|||||||
*.lex.c
|
*.lex.c
|
||||||
*.lst
|
*.lst
|
||||||
*.mod.c
|
*.mod.c
|
||||||
|
*.mbx
|
||||||
*.o
|
*.o
|
||||||
*.o.*
|
*.o.*
|
||||||
*.order
|
*.order
|
||||||
|
2
Makefile
2
Makefile
@ -3,7 +3,7 @@
|
|||||||
VERSION = 2022
|
VERSION = 2022
|
||||||
PATCHLEVEL = 07
|
PATCHLEVEL = 07
|
||||||
SUBLEVEL =
|
SUBLEVEL =
|
||||||
EXTRAVERSION = -rc4
|
EXTRAVERSION = -rc5
|
||||||
NAME =
|
NAME =
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -39,8 +39,28 @@ DECLARE_GLOBAL_DATA_PTR;
|
|||||||
* off: FFF
|
* off: FFF
|
||||||
*/
|
*/
|
||||||
|
|
||||||
u64 get_tcr(int el, u64 *pips, u64 *pva_bits)
|
static int get_effective_el(void)
|
||||||
{
|
{
|
||||||
|
int el = current_el();
|
||||||
|
|
||||||
|
if (el == 2) {
|
||||||
|
u64 hcr_el2;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we are using the EL2&0 translation regime, the TCR_EL2
|
||||||
|
* looks like the EL1 version, even though we are in EL2.
|
||||||
|
*/
|
||||||
|
__asm__ ("mrs %0, HCR_EL2\n" : "=r" (hcr_el2));
|
||||||
|
if (hcr_el2 & BIT(HCR_EL2_E2H_BIT))
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return el;
|
||||||
|
}
|
||||||
|
|
||||||
|
u64 get_tcr(u64 *pips, u64 *pva_bits)
|
||||||
|
{
|
||||||
|
int el = get_effective_el();
|
||||||
u64 max_addr = 0;
|
u64 max_addr = 0;
|
||||||
u64 ips, va_bits;
|
u64 ips, va_bits;
|
||||||
u64 tcr;
|
u64 tcr;
|
||||||
@ -115,7 +135,7 @@ static u64 *find_pte(u64 addr, int level)
|
|||||||
|
|
||||||
debug("addr=%llx level=%d\n", addr, level);
|
debug("addr=%llx level=%d\n", addr, level);
|
||||||
|
|
||||||
get_tcr(0, NULL, &va_bits);
|
get_tcr(NULL, &va_bits);
|
||||||
if (va_bits < 39)
|
if (va_bits < 39)
|
||||||
start_level = 1;
|
start_level = 1;
|
||||||
|
|
||||||
@ -343,7 +363,7 @@ __weak u64 get_page_table_size(void)
|
|||||||
u64 va_bits;
|
u64 va_bits;
|
||||||
int start_level = 0;
|
int start_level = 0;
|
||||||
|
|
||||||
get_tcr(0, NULL, &va_bits);
|
get_tcr(NULL, &va_bits);
|
||||||
if (va_bits < 39)
|
if (va_bits < 39)
|
||||||
start_level = 1;
|
start_level = 1;
|
||||||
|
|
||||||
@ -415,7 +435,7 @@ __weak void mmu_setup(void)
|
|||||||
setup_all_pgtables();
|
setup_all_pgtables();
|
||||||
|
|
||||||
el = current_el();
|
el = current_el();
|
||||||
set_ttbr_tcr_mair(el, gd->arch.tlb_addr, get_tcr(el, NULL, NULL),
|
set_ttbr_tcr_mair(el, gd->arch.tlb_addr, get_tcr(NULL, NULL),
|
||||||
MEMORY_ATTRIBUTES);
|
MEMORY_ATTRIBUTES);
|
||||||
|
|
||||||
/* enable the mmu */
|
/* enable the mmu */
|
||||||
|
@ -454,7 +454,7 @@ static inline void early_mmu_setup(void)
|
|||||||
|
|
||||||
/* point TTBR to the new table */
|
/* point TTBR to the new table */
|
||||||
set_ttbr_tcr_mair(el, gd->arch.tlb_addr,
|
set_ttbr_tcr_mair(el, gd->arch.tlb_addr,
|
||||||
get_tcr(el, NULL, NULL) &
|
get_tcr(NULL, NULL) &
|
||||||
~(TCR_ORGN_MASK | TCR_IRGN_MASK),
|
~(TCR_ORGN_MASK | TCR_IRGN_MASK),
|
||||||
MEMORY_ATTRIBUTES);
|
MEMORY_ATTRIBUTES);
|
||||||
|
|
||||||
@ -609,7 +609,7 @@ static inline void final_mmu_setup(void)
|
|||||||
invalidate_icache_all();
|
invalidate_icache_all();
|
||||||
|
|
||||||
/* point TTBR to the new table */
|
/* point TTBR to the new table */
|
||||||
set_ttbr_tcr_mair(el, gd->arch.tlb_addr, get_tcr(el, NULL, NULL),
|
set_ttbr_tcr_mair(el, gd->arch.tlb_addr, get_tcr(NULL, NULL),
|
||||||
MEMORY_ATTRIBUTES);
|
MEMORY_ATTRIBUTES);
|
||||||
|
|
||||||
set_sctlr(get_sctlr() | CR_M);
|
set_sctlr(get_sctlr() | CR_M);
|
||||||
|
@ -125,7 +125,7 @@ pie_fixup_done:
|
|||||||
msr cptr_el3, xzr /* Enable FP/SIMD */
|
msr cptr_el3, xzr /* Enable FP/SIMD */
|
||||||
b 0f
|
b 0f
|
||||||
2: mrs x1, hcr_el2
|
2: mrs x1, hcr_el2
|
||||||
tbnz x1, #34, 1f /* HCR_EL2.E2H */
|
tbnz x1, #HCR_EL2_E2H_BIT, 1f /* HCR_EL2.E2H */
|
||||||
orr x1, x1, #HCR_EL2_AMO_EL2 /* Route SErrors to EL2 */
|
orr x1, x1, #HCR_EL2_AMO_EL2 /* Route SErrors to EL2 */
|
||||||
msr hcr_el2, x1
|
msr hcr_el2, x1
|
||||||
set_vbar vbar_el2, x0
|
set_vbar vbar_el2, x0
|
||||||
|
@ -1178,7 +1178,8 @@ dtb-$(CONFIG_STM32MP15x) += \
|
|||||||
stm32mp15xx-dhcom-drc02.dtb \
|
stm32mp15xx-dhcom-drc02.dtb \
|
||||||
stm32mp15xx-dhcom-pdk2.dtb \
|
stm32mp15xx-dhcom-pdk2.dtb \
|
||||||
stm32mp15xx-dhcom-picoitx.dtb \
|
stm32mp15xx-dhcom-picoitx.dtb \
|
||||||
stm32mp15xx-dhcor-avenger96.dtb
|
stm32mp15xx-dhcor-avenger96.dtb \
|
||||||
|
stm32mp15xx-dhcor-drc-compact.dtb
|
||||||
|
|
||||||
dtb-$(CONFIG_SOC_K3_AM6) += \
|
dtb-$(CONFIG_SOC_K3_AM6) += \
|
||||||
k3-am654-base-board.dtb \
|
k3-am654-base-board.dtb \
|
||||||
|
@ -55,7 +55,13 @@
|
|||||||
pinctrl-0 = <&pinctrl_microsom_enet_ar8035>;
|
pinctrl-0 = <&pinctrl_microsom_enet_ar8035>;
|
||||||
phy-handle = <&phy>;
|
phy-handle = <&phy>;
|
||||||
phy-mode = "rgmii-id";
|
phy-mode = "rgmii-id";
|
||||||
phy-reset-duration = <2>;
|
|
||||||
|
/*
|
||||||
|
* The PHY seems to require a long-enough reset duration to avoid
|
||||||
|
* some rare issues where the PHY gets stuck in an inconsistent and
|
||||||
|
* non-functional state at boot-up. 10ms proved to be fine .
|
||||||
|
*/
|
||||||
|
phy-reset-duration = <10>;
|
||||||
phy-reset-gpios = <&gpio4 15 GPIO_ACTIVE_LOW>;
|
phy-reset-gpios = <&gpio4 15 GPIO_ACTIVE_LOW>;
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
|
||||||
@ -64,8 +70,15 @@
|
|||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
|
|
||||||
phy: ethernet-phy@0 {
|
phy: ethernet-phy@0 {
|
||||||
reg = <0>;
|
/*
|
||||||
|
* The PHY can appear either:
|
||||||
|
* - AR8035: at address 0 or 4
|
||||||
|
* - ADIN1300: at address 1
|
||||||
|
* Actual address being detected at runtime.
|
||||||
|
*/
|
||||||
|
reg = <0xffffffff>;
|
||||||
qca,clk-out-frequency = <125000000>;
|
qca,clk-out-frequency = <125000000>;
|
||||||
|
adi,phy-output-clock = "125mhz-free-running";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -58,7 +58,9 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
flash {
|
spl {
|
||||||
|
filename = "spl.bin";
|
||||||
|
|
||||||
mkimage {
|
mkimage {
|
||||||
args = "-n spl/u-boot-spl.cfgout -T imx8mimage -e 0x912000";
|
args = "-n spl/u-boot-spl.cfgout -T imx8mimage -e 0x912000";
|
||||||
|
|
||||||
|
@ -10,3 +10,18 @@
|
|||||||
sd-uhs-sdr104;
|
sd-uhs-sdr104;
|
||||||
sd-uhs-ddr50;
|
sd-uhs-ddr50;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&uart1 {
|
||||||
|
/delete-property/ assigned-clocks;
|
||||||
|
/delete-property/ assigned-clock-parents;
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart2 {
|
||||||
|
/delete-property/ assigned-clocks;
|
||||||
|
/delete-property/ assigned-clock-parents;
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart3 {
|
||||||
|
/delete-property/ assigned-clocks;
|
||||||
|
/delete-property/ assigned-clock-parents;
|
||||||
|
};
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
/*
|
/*
|
||||||
* U-Boot additions
|
* U-Boot additions
|
||||||
*
|
*
|
||||||
* Copyright (C) 2019 Intel Corporation <www.intel.com>
|
* Copyright (C) 2019-2022 Intel Corporation <www.intel.com>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "socfpga_agilex-u-boot.dtsi"
|
#include "socfpga_agilex-u-boot.dtsi"
|
||||||
@ -11,6 +11,15 @@
|
|||||||
aliases {
|
aliases {
|
||||||
spi0 = &qspi;
|
spi0 = &qspi;
|
||||||
i2c0 = &i2c1;
|
i2c0 = &i2c1;
|
||||||
|
freeze_br0 = &freeze_controller;
|
||||||
|
};
|
||||||
|
|
||||||
|
soc {
|
||||||
|
freeze_controller: freeze_controller@f9000450 {
|
||||||
|
compatible = "altr,freeze-bridge-controller";
|
||||||
|
reg = <0xf9000450 0x00000010>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
memory {
|
memory {
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
/*
|
/*
|
||||||
* U-Boot additions
|
* U-Boot additions
|
||||||
*
|
*
|
||||||
* Copyright (C) 2019-2020 Intel Corporation <www.intel.com>
|
* Copyright (C) 2019-2022 Intel Corporation <www.intel.com>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "socfpga_stratix10-u-boot.dtsi"
|
#include "socfpga_stratix10-u-boot.dtsi"
|
||||||
@ -10,6 +10,15 @@
|
|||||||
/{
|
/{
|
||||||
aliases {
|
aliases {
|
||||||
spi0 = &qspi;
|
spi0 = &qspi;
|
||||||
|
freeze_br0 = &freeze_controller;
|
||||||
|
};
|
||||||
|
|
||||||
|
soc {
|
||||||
|
freeze_controller: freeze_controller@f9000450 {
|
||||||
|
compatible = "altr,freeze-bridge-controller";
|
||||||
|
reg = <0xf9000450 0x00000010>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -92,7 +92,7 @@
|
|||||||
broken-cd;
|
broken-cd;
|
||||||
bus-width = <4>;
|
bus-width = <4>;
|
||||||
drvsel = <3>;
|
drvsel = <3>;
|
||||||
smplsel = <0>;
|
smplsel = <2>;
|
||||||
};
|
};
|
||||||
|
|
||||||
&qspi {
|
&qspi {
|
||||||
|
@ -929,6 +929,26 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
m_can1_pins_c: m-can1-2 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('H', 13, AF9)>; /* CAN1_TX */
|
||||||
|
slew-rate = <1>;
|
||||||
|
drive-push-pull;
|
||||||
|
bias-disable;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('H', 14, AF9)>; /* CAN1_RX */
|
||||||
|
bias-disable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
m_can1_sleep_pins_c: m_can1-sleep-2 {
|
||||||
|
pins {
|
||||||
|
pinmux = <STM32_PINMUX('H', 13, ANALOG)>, /* CAN1_TX */
|
||||||
|
<STM32_PINMUX('H', 14, ANALOG)>; /* CAN1_RX */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
m_can2_pins_a: m-can2-0 {
|
m_can2_pins_a: m-can2-0 {
|
||||||
pins1 {
|
pins1 {
|
||||||
pinmux = <STM32_PINMUX('B', 13, AF9)>; /* CAN2_TX */
|
pinmux = <STM32_PINMUX('B', 13, AF9)>; /* CAN2_TX */
|
||||||
@ -1758,6 +1778,21 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
spi2_pins_b: spi2-1 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('I', 1, AF5)>, /* SPI1_SCK */
|
||||||
|
<STM32_PINMUX('I', 3, AF5)>; /* SPI1_MOSI */
|
||||||
|
bias-disable;
|
||||||
|
drive-push-pull;
|
||||||
|
slew-rate = <1>;
|
||||||
|
};
|
||||||
|
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('I', 2, AF5)>; /* SPI1_MISO */
|
||||||
|
bias-disable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
spi4_pins_a: spi4-0 {
|
spi4_pins_a: spi4-0 {
|
||||||
pins {
|
pins {
|
||||||
pinmux = <STM32_PINMUX('E', 12, AF5)>, /* SPI4_SCK */
|
pinmux = <STM32_PINMUX('E', 12, AF5)>, /* SPI4_SCK */
|
||||||
@ -1835,6 +1870,49 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
uart4_pins_d: uart4-3 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('A', 13, AF8)>; /* UART4_TX */
|
||||||
|
bias-disable;
|
||||||
|
drive-push-pull;
|
||||||
|
slew-rate = <0>;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 2, AF8)>; /* UART4_RX */
|
||||||
|
bias-disable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
uart4_idle_pins_d: uart4-idle-3 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('A', 13, ANALOG)>; /* UART4_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 2, AF8)>; /* UART4_RX */
|
||||||
|
bias-disable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
uart4_sleep_pins_d: uart4-sleep-3 {
|
||||||
|
pins {
|
||||||
|
pinmux = <STM32_PINMUX('A', 13, ANALOG)>, /* UART4_TX */
|
||||||
|
<STM32_PINMUX('B', 2, ANALOG)>; /* UART4_RX */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
uart5_pins_a: uart5-0 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 13, AF14)>; /* UART5_TX */
|
||||||
|
bias-disable;
|
||||||
|
drive-push-pull;
|
||||||
|
slew-rate = <0>;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 5, AF12)>; /* UART5_RX */
|
||||||
|
bias-disable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
uart7_pins_a: uart7-0 {
|
uart7_pins_a: uart7-0 {
|
||||||
pins1 {
|
pins1 {
|
||||||
pinmux = <STM32_PINMUX('E', 8, AF7)>; /* UART7_TX */
|
pinmux = <STM32_PINMUX('E', 8, AF7)>; /* UART7_TX */
|
||||||
@ -2134,6 +2212,47 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
usart3_pins_e: usart3-4 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 10, AF7)>, /* USART3_TX */
|
||||||
|
<STM32_PINMUX('G', 8, AF8)>; /* USART3_RTS */
|
||||||
|
bias-disable;
|
||||||
|
drive-push-pull;
|
||||||
|
slew-rate = <0>;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 11, AF7)>, /* USART3_RX */
|
||||||
|
<STM32_PINMUX('D', 11, AF7)>; /* USART3_CTS_NSS */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
usart3_idle_pins_e: usart3-idle-4 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 10, ANALOG)>, /* USART3_TX */
|
||||||
|
<STM32_PINMUX('D', 11, ANALOG)>; /* USART3_CTS_NSS */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('G', 8, AF8)>; /* USART3_RTS */
|
||||||
|
bias-disable;
|
||||||
|
drive-push-pull;
|
||||||
|
slew-rate = <0>;
|
||||||
|
};
|
||||||
|
pins3 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 11, AF7)>; /* USART3_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
usart3_sleep_pins_e: usart3-sleep-4 {
|
||||||
|
pins {
|
||||||
|
pinmux = <STM32_PINMUX('B', 10, ANALOG)>, /* USART3_TX */
|
||||||
|
<STM32_PINMUX('G', 8, ANALOG)>, /* USART3_RTS */
|
||||||
|
<STM32_PINMUX('D', 11, ANALOG)>, /* USART3_CTS_NSS */
|
||||||
|
<STM32_PINMUX('B', 11, ANALOG)>; /* USART3_RX */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
usbotg_hs_pins_a: usbotg-hs-0 {
|
usbotg_hs_pins_a: usbotg-hs-0 {
|
||||||
pins {
|
pins {
|
||||||
pinmux = <STM32_PINMUX('A', 10, ANALOG)>; /* OTG_ID */
|
pinmux = <STM32_PINMUX('A', 10, ANALOG)>; /* OTG_ID */
|
||||||
|
30
arch/arm/dts/stm32mp153c-dhcor-drc-compact.dts
Normal file
30
arch/arm/dts/stm32mp153c-dhcor-drc-compact.dts
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
// SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2022 Marek Vasut <marex@denx.de>
|
||||||
|
*
|
||||||
|
* DHCOR STM32MP1 variant:
|
||||||
|
* DHCR-STM32MP153C-C065-R051-V33-SPI-I-01LG
|
||||||
|
* DHCOR PCB number: 586-100 or newer
|
||||||
|
* DRC Compact PCB number: 627-100 or newer
|
||||||
|
*/
|
||||||
|
|
||||||
|
/dts-v1/;
|
||||||
|
|
||||||
|
#include "stm32mp153.dtsi"
|
||||||
|
#include "stm32mp15xc.dtsi"
|
||||||
|
#include "stm32mp15xx-dhcor-som.dtsi"
|
||||||
|
#include "stm32mp15xx-dhcor-drc-compact.dtsi"
|
||||||
|
|
||||||
|
/ {
|
||||||
|
model = "DH electronics STM32MP153C DHCOR DRC Compact";
|
||||||
|
compatible = "dh,stm32mp153c-dhcor-drc-compact",
|
||||||
|
"dh,stm32mp153c-dhcor-som",
|
||||||
|
"st,stm32mp153";
|
||||||
|
};
|
||||||
|
|
||||||
|
&m_can1 {
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
pinctrl-0 = <&m_can1_pins_c>;
|
||||||
|
pinctrl-1 = <&m_can1_sleep_pins_c>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
120
arch/arm/dts/stm32mp15xx-dhcor-drc-compact-u-boot.dtsi
Normal file
120
arch/arm/dts/stm32mp15xx-dhcor-drc-compact-u-boot.dtsi
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2022 Marek Vasut <marex@denx.de>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "stm32mp15xx-dhcor-u-boot.dtsi"
|
||||||
|
|
||||||
|
/delete-node/ &ksz8851;
|
||||||
|
|
||||||
|
/ {
|
||||||
|
aliases {
|
||||||
|
mmc0 = &sdmmc1;
|
||||||
|
mmc1 = &sdmmc2;
|
||||||
|
usb0 = &usbotg_hs;
|
||||||
|
ethernet1 = &ks8851;
|
||||||
|
};
|
||||||
|
|
||||||
|
config {
|
||||||
|
dh,board-coding-gpios = <&gpioh 9 0>, <&gpioh 8 0>, <&gpioh 3 0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* This is actually on FMC2, but we do not have bus driver for that */
|
||||||
|
ks8851: ks8851mll@64000000 {
|
||||||
|
compatible = "micrel,ks8851-mll";
|
||||||
|
reg = <0x64000000 0x20000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
ðernet0 {
|
||||||
|
phy-reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>;
|
||||||
|
|
||||||
|
mdio0 {
|
||||||
|
ethernet-phy@7 {
|
||||||
|
reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>;
|
||||||
|
reset-assert-us = <11000>;
|
||||||
|
reset-deassert-us = <1000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&pinctrl {
|
||||||
|
/* These should bound to FMC2 bus driver, but we do not have one */
|
||||||
|
pinctrl-0 = <&fmc_pins_b>;
|
||||||
|
pinctrl-1 = <&fmc_sleep_pins_b>;
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc1 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
st,use-ckin;
|
||||||
|
st,cmd-gpios = <&gpiod 2 0>;
|
||||||
|
st,ck-gpios = <&gpioc 12 0>;
|
||||||
|
st,ckin-gpios = <&gpioe 4 0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc1_b4_pins_a {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
pins1 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc1_dir_pins_b {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
pins1 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc2 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc2_b4_pins_a {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
pins1 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc2_d47_pins_c {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
pins {
|
||||||
|
u-boot,dm-spl;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc3 { /* SDIO Wi-Fi */
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart4 {
|
||||||
|
u-boot,dm-pre-reloc;
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart4_pins_d {
|
||||||
|
u-boot,dm-pre-reloc;
|
||||||
|
pins1 {
|
||||||
|
u-boot,dm-pre-reloc;
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
u-boot,dm-pre-reloc;
|
||||||
|
/delete-property/ bias-disable;
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbotg_hs {
|
||||||
|
u-boot,force-b-session-valid;
|
||||||
|
hnp-srp-disable;
|
||||||
|
};
|
16
arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dts
Normal file
16
arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
// SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2022 Marek Vasut <marex@denx.de>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/dts-v1/;
|
||||||
|
|
||||||
|
#include "stm32mp151.dtsi"
|
||||||
|
#include "stm32mp15xc.dtsi"
|
||||||
|
#include "stm32mp15xx-dhcor-som.dtsi"
|
||||||
|
#include "stm32mp15xx-dhcor-drc-compact.dtsi"
|
||||||
|
|
||||||
|
/ {
|
||||||
|
model = "DH electronics STM32MP15xx DHCOR DRC Compact";
|
||||||
|
compatible = "dh,stm32mp15xx-dhcor-drc-compact", "st,stm32mp1xx";
|
||||||
|
};
|
326
arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dtsi
Normal file
326
arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dtsi
Normal file
@ -0,0 +1,326 @@
|
|||||||
|
// SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2022 Marek Vasut <marex@denx.de>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/ {
|
||||||
|
aliases {
|
||||||
|
ethernet0 = ðernet0;
|
||||||
|
ethernet1 = &ksz8851;
|
||||||
|
mmc0 = &sdmmc1;
|
||||||
|
rtc0 = &hwrtc;
|
||||||
|
rtc1 = &rtc;
|
||||||
|
serial0 = &uart4;
|
||||||
|
serial1 = &uart8;
|
||||||
|
serial2 = &usart3;
|
||||||
|
serial3 = &uart5;
|
||||||
|
spi0 = &qspi;
|
||||||
|
};
|
||||||
|
|
||||||
|
chosen {
|
||||||
|
stdout-path = "serial0:115200n8";
|
||||||
|
};
|
||||||
|
|
||||||
|
led {
|
||||||
|
compatible = "gpio-leds";
|
||||||
|
led1 {
|
||||||
|
label = "yellow:user0";
|
||||||
|
gpios = <&gpioz 6 GPIO_ACTIVE_LOW>;
|
||||||
|
default-state = "off";
|
||||||
|
};
|
||||||
|
|
||||||
|
led2 {
|
||||||
|
label = "red:user1";
|
||||||
|
gpios = <&gpioz 3 GPIO_ACTIVE_LOW>;
|
||||||
|
default-state = "off";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
ethernet_vio: vioregulator {
|
||||||
|
compatible = "regulator-fixed";
|
||||||
|
regulator-name = "vio";
|
||||||
|
regulator-min-microvolt = <3300000>;
|
||||||
|
regulator-max-microvolt = <3300000>;
|
||||||
|
gpio = <&gpioh 2 GPIO_ACTIVE_LOW>;
|
||||||
|
regulator-always-on;
|
||||||
|
regulator-boot-on;
|
||||||
|
vin-supply = <&vdd>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&adc { /* X11 ADC inputs */
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&adc12_ain_pins_b>;
|
||||||
|
vdd-supply = <&vdd>;
|
||||||
|
vdda-supply = <&vdda>;
|
||||||
|
vref-supply = <&vdda>;
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
adc1: adc@0 {
|
||||||
|
st,adc-channels = <0 1 6>;
|
||||||
|
st,min-sample-time-nsecs = <5000>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
adc2: adc@100 {
|
||||||
|
st,adc-channels = <0 1 2>;
|
||||||
|
st,min-sample-time-nsecs = <5000>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
ðernet0 {
|
||||||
|
status = "okay";
|
||||||
|
pinctrl-0 = <ðernet0_rgmii_pins_c>;
|
||||||
|
pinctrl-1 = <ðernet0_rgmii_sleep_pins_c>;
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
phy-mode = "rgmii";
|
||||||
|
max-speed = <1000>;
|
||||||
|
phy-handle = <&phy0>;
|
||||||
|
|
||||||
|
mdio0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
compatible = "snps,dwmac-mdio";
|
||||||
|
reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>;
|
||||||
|
reset-delay-us = <1000>;
|
||||||
|
reset-post-delay-us = <1000>;
|
||||||
|
|
||||||
|
phy0: ethernet-phy@7 {
|
||||||
|
reg = <7>;
|
||||||
|
|
||||||
|
rxc-skew-ps = <1500>;
|
||||||
|
rxdv-skew-ps = <540>;
|
||||||
|
rxd0-skew-ps = <420>;
|
||||||
|
rxd1-skew-ps = <420>;
|
||||||
|
rxd2-skew-ps = <420>;
|
||||||
|
rxd3-skew-ps = <420>;
|
||||||
|
|
||||||
|
txc-skew-ps = <1440>;
|
||||||
|
txen-skew-ps = <540>;
|
||||||
|
txd0-skew-ps = <420>;
|
||||||
|
txd1-skew-ps = <420>;
|
||||||
|
txd2-skew-ps = <420>;
|
||||||
|
txd3-skew-ps = <420>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&fmc {
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
pinctrl-0 = <&fmc_pins_b>;
|
||||||
|
pinctrl-1 = <&fmc_sleep_pins_b>;
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
ksz8851: ethernet@1,0 {
|
||||||
|
compatible = "micrel,ks8851-mll";
|
||||||
|
reg = <1 0x0 0x2>, <1 0x2 0x20000>;
|
||||||
|
interrupt-parent = <&gpioc>;
|
||||||
|
interrupts = <3 IRQ_TYPE_LEVEL_LOW>;
|
||||||
|
bank-width = <2>;
|
||||||
|
|
||||||
|
/* Timing values are in nS */
|
||||||
|
st,fmc2-ebi-cs-mux-enable;
|
||||||
|
st,fmc2-ebi-cs-transaction-type = <4>;
|
||||||
|
st,fmc2-ebi-cs-buswidth = <16>;
|
||||||
|
st,fmc2-ebi-cs-address-setup-ns = <5>;
|
||||||
|
st,fmc2-ebi-cs-address-hold-ns = <5>;
|
||||||
|
st,fmc2-ebi-cs-bus-turnaround-ns = <5>;
|
||||||
|
st,fmc2-ebi-cs-data-setup-ns = <45>;
|
||||||
|
st,fmc2-ebi-cs-data-hold-ns = <1>;
|
||||||
|
st,fmc2-ebi-cs-write-address-setup-ns = <5>;
|
||||||
|
st,fmc2-ebi-cs-write-address-hold-ns = <5>;
|
||||||
|
st,fmc2-ebi-cs-write-bus-turnaround-ns = <5>;
|
||||||
|
st,fmc2-ebi-cs-write-data-setup-ns = <45>;
|
||||||
|
st,fmc2-ebi-cs-write-data-hold-ns = <1>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpioa {
|
||||||
|
gpio-line-names = "", "", "", "",
|
||||||
|
"DRCC-VAR2", "", "", "",
|
||||||
|
"", "", "", "",
|
||||||
|
"", "", "", "";
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpioe {
|
||||||
|
gpio-line-names = "", "", "", "",
|
||||||
|
"", "DRCC-GPIO0", "", "",
|
||||||
|
"", "", "", "",
|
||||||
|
"", "", "", "";
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpiog {
|
||||||
|
gpio-line-names = "", "", "", "",
|
||||||
|
"", "", "", "",
|
||||||
|
"", "", "", "",
|
||||||
|
"DRCC-GPIO5", "", "", "";
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpioh {
|
||||||
|
gpio-line-names = "", "", "", "DRCC-HW2",
|
||||||
|
"DRCC-GPIO4", "", "", "",
|
||||||
|
"DRCC-HW1", "DRCC-HW0", "", "DRCC-VAR1",
|
||||||
|
"DRCC-VAR0", "", "", "DRCC-GPIO6";
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpioi {
|
||||||
|
gpio-line-names = "", "", "", "",
|
||||||
|
"", "", "", "DRCC-GPIO2",
|
||||||
|
"", "DRCC-GPIO1", "", "",
|
||||||
|
"", "", "", "";
|
||||||
|
};
|
||||||
|
|
||||||
|
&i2c1 { /* X11 I2C1 */
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&i2c1_pins_b>;
|
||||||
|
i2c-scl-rising-time-ns = <185>;
|
||||||
|
i2c-scl-falling-time-ns = <20>;
|
||||||
|
status = "okay";
|
||||||
|
/delete-property/dmas;
|
||||||
|
/delete-property/dma-names;
|
||||||
|
};
|
||||||
|
|
||||||
|
&i2c4 {
|
||||||
|
hwrtc: rtc@32 {
|
||||||
|
compatible = "microcrystal,rv8803";
|
||||||
|
reg = <0x32>;
|
||||||
|
};
|
||||||
|
|
||||||
|
eeprom@50 {
|
||||||
|
compatible = "atmel,24c04";
|
||||||
|
reg = <0x50>;
|
||||||
|
pagesize = <16>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc1 { /* MicroSD */
|
||||||
|
pinctrl-names = "default", "opendrain", "sleep";
|
||||||
|
pinctrl-0 = <&sdmmc1_b4_pins_a>;
|
||||||
|
pinctrl-1 = <&sdmmc1_b4_od_pins_a>;
|
||||||
|
pinctrl-2 = <&sdmmc1_b4_sleep_pins_a>;
|
||||||
|
cd-gpios = <&gpioi 8 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
|
||||||
|
disable-wp;
|
||||||
|
st,neg-edge;
|
||||||
|
bus-width = <4>;
|
||||||
|
vmmc-supply = <&vdd>;
|
||||||
|
vqmmc-supply = <&vdd>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc2 { /* eMMC */
|
||||||
|
pinctrl-names = "default", "opendrain", "sleep";
|
||||||
|
pinctrl-0 = <&sdmmc2_b4_pins_a &sdmmc2_d47_pins_c>;
|
||||||
|
pinctrl-1 = <&sdmmc2_b4_od_pins_a &sdmmc2_d47_pins_c>;
|
||||||
|
pinctrl-2 = <&sdmmc2_b4_sleep_pins_a &sdmmc2_d47_sleep_pins_c>;
|
||||||
|
bus-width = <8>;
|
||||||
|
no-sd;
|
||||||
|
no-sdio;
|
||||||
|
non-removable;
|
||||||
|
st,neg-edge;
|
||||||
|
vmmc-supply = <&v3v3>;
|
||||||
|
vqmmc-supply = <&vdd>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&sdmmc3 { /* SDIO Wi-Fi */
|
||||||
|
pinctrl-names = "default", "opendrain", "sleep";
|
||||||
|
pinctrl-0 = <&sdmmc3_b4_pins_a>;
|
||||||
|
pinctrl-1 = <&sdmmc3_b4_od_pins_a>;
|
||||||
|
pinctrl-2 = <&sdmmc3_b4_sleep_pins_a>;
|
||||||
|
broken-cd;
|
||||||
|
bus-width = <4>;
|
||||||
|
mmc-ddr-3_3v;
|
||||||
|
st,neg-edge;
|
||||||
|
vmmc-supply = <&v3v3>;
|
||||||
|
vqmmc-supply = <&v3v3>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&spi2 { /* X11 SPI */
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&spi2_pins_b>;
|
||||||
|
cs-gpios = <&gpioi 0 0>;
|
||||||
|
status = "disabled";
|
||||||
|
/delete-property/dmas;
|
||||||
|
/delete-property/dma-names;
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart4 {
|
||||||
|
label = "UART0";
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&uart4_pins_d>;
|
||||||
|
/delete-property/dmas;
|
||||||
|
/delete-property/dma-names;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart5 { /* X11 UART */
|
||||||
|
label = "X11-UART5";
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&uart5_pins_a>;
|
||||||
|
/delete-property/dmas;
|
||||||
|
/delete-property/dma-names;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart8 {
|
||||||
|
label = "RS485-1";
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&uart8_pins_a &uart8_rtscts_pins_a>;
|
||||||
|
uart-has-rtscts;
|
||||||
|
/delete-property/dmas;
|
||||||
|
/delete-property/dma-names;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usart3 { /* RS485 or RS232 */
|
||||||
|
label = "RS485-2";
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
pinctrl-0 = <&usart3_pins_e>;
|
||||||
|
pinctrl-1 = <&usart3_sleep_pins_e>;
|
||||||
|
uart-has-rtscts;
|
||||||
|
/delete-property/dmas;
|
||||||
|
/delete-property/dma-names;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbh_ehci {
|
||||||
|
phys = <&usbphyc_port0>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbh_ohci {
|
||||||
|
phys = <&usbphyc_port0>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbotg_hs {
|
||||||
|
dr_mode = "otg";
|
||||||
|
pinctrl-0 = <&usbotg_hs_pins_a>;
|
||||||
|
pinctrl-names = "default";
|
||||||
|
phy-names = "usb2-phy";
|
||||||
|
phys = <&usbphyc_port1 0>;
|
||||||
|
vbus-supply = <&vbus_otg>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbphyc {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbphyc_port0 {
|
||||||
|
phy-supply = <&vdd_usb>;
|
||||||
|
vdda1v1-supply = <®11>;
|
||||||
|
vdda1v8-supply = <®18>;
|
||||||
|
connector {
|
||||||
|
compatible = "usb-a-connector";
|
||||||
|
vbus-supply = <&vbus_sw>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbphyc_port1 {
|
||||||
|
phy-supply = <&vdd_usb>;
|
||||||
|
vdda1v1-supply = <®11>;
|
||||||
|
vdda1v8-supply = <®18>;
|
||||||
|
};
|
@ -103,6 +103,8 @@
|
|||||||
#define TCR_EL2_RSVD (1U << 31 | 1 << 23)
|
#define TCR_EL2_RSVD (1U << 31 | 1 << 23)
|
||||||
#define TCR_EL3_RSVD (1U << 31 | 1 << 23)
|
#define TCR_EL3_RSVD (1U << 31 | 1 << 23)
|
||||||
|
|
||||||
|
#define HCR_EL2_E2H_BIT 34
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
static inline void set_ttbr_tcr_mair(int el, u64 table, u64 tcr, u64 attr)
|
static inline void set_ttbr_tcr_mair(int el, u64 table, u64 tcr, u64 attr)
|
||||||
{
|
{
|
||||||
@ -134,7 +136,7 @@ struct mm_region {
|
|||||||
|
|
||||||
extern struct mm_region *mem_map;
|
extern struct mm_region *mem_map;
|
||||||
void setup_pgtables(void);
|
void setup_pgtables(void);
|
||||||
u64 get_tcr(int el, u64 *pips, u64 *pva_bits);
|
u64 get_tcr(u64 *pips, u64 *pva_bits);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* _ASM_ARMV8_MMU_H_ */
|
#endif /* _ASM_ARMV8_MMU_H_ */
|
||||||
|
@ -47,6 +47,9 @@ static void ctrl_mmr_unlock(void)
|
|||||||
mmr_unlock(CTRL_MMR0_BASE, 3);
|
mmr_unlock(CTRL_MMR0_BASE, 3);
|
||||||
mmr_unlock(CTRL_MMR0_BASE, 5);
|
mmr_unlock(CTRL_MMR0_BASE, 5);
|
||||||
mmr_unlock(CTRL_MMR0_BASE, 6);
|
mmr_unlock(CTRL_MMR0_BASE, 6);
|
||||||
|
|
||||||
|
/* Unlock all MCU_PADCFG_MMR1 module registers */
|
||||||
|
mmr_unlock(MCU_PADCFG_MMR1_BASE, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017-2018 Intel Corporation <www.intel.com>
|
* Copyright (C) 2017-2022 Intel Corporation <www.intel.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <init.h>
|
#include <init.h>
|
||||||
|
#include <div64.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <asm/arch/timer.h>
|
#include <asm/arch/timer.h>
|
||||||
|
|
||||||
@ -26,3 +27,34 @@ int timer_init(void)
|
|||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
__always_inline u64 __get_time_stamp(void)
|
||||||
|
{
|
||||||
|
u64 cntpct;
|
||||||
|
|
||||||
|
isb();
|
||||||
|
asm volatile("mrs %0, cntpct_el0" : "=r" (cntpct));
|
||||||
|
|
||||||
|
return cntpct;
|
||||||
|
}
|
||||||
|
|
||||||
|
__always_inline uint64_t __usec_to_tick(unsigned long usec)
|
||||||
|
{
|
||||||
|
u64 tick = usec;
|
||||||
|
u64 cntfrq;
|
||||||
|
|
||||||
|
asm volatile("mrs %0, cntfrq_el0" : "=r" (cntfrq));
|
||||||
|
tick *= cntfrq;
|
||||||
|
do_div(tick, 1000000);
|
||||||
|
|
||||||
|
return tick;
|
||||||
|
}
|
||||||
|
|
||||||
|
__always_inline void __udelay(unsigned long usec)
|
||||||
|
{
|
||||||
|
/* get current timestamp */
|
||||||
|
u64 tmp = __get_time_stamp() + __usec_to_tick(usec);
|
||||||
|
|
||||||
|
while (__get_time_stamp() < tmp + 1) /* loop till event */
|
||||||
|
;
|
||||||
|
}
|
@ -1262,7 +1262,7 @@ static int stm32prog_alt_add(struct stm32prog_data *data,
|
|||||||
"raw 0x%llx 0x%llx",
|
"raw 0x%llx 0x%llx",
|
||||||
part->addr, nb_blk);
|
part->addr, nb_blk);
|
||||||
offset += snprintf(buf + offset, ALT_BUF_LEN - offset,
|
offset += snprintf(buf + offset, ALT_BUF_LEN - offset,
|
||||||
" mmcpart %d;", -(part->part_id));
|
" mmcpart %d", -(part->part_id));
|
||||||
} else {
|
} else {
|
||||||
if (part->part_type == PART_SYSTEM &&
|
if (part->part_type == PART_SYSTEM &&
|
||||||
(part->target == STM32PROG_NAND ||
|
(part->target == STM32PROG_NAND ||
|
||||||
@ -1280,7 +1280,7 @@ static int stm32prog_alt_add(struct stm32prog_data *data,
|
|||||||
offset += snprintf(buf + offset, ALT_BUF_LEN - offset,
|
offset += snprintf(buf + offset, ALT_BUF_LEN - offset,
|
||||||
" %d", part->dev_id);
|
" %d", part->dev_id);
|
||||||
offset += snprintf(buf + offset, ALT_BUF_LEN - offset,
|
offset += snprintf(buf + offset, ALT_BUF_LEN - offset,
|
||||||
" %d;", part->part_id);
|
" %d", part->part_id);
|
||||||
}
|
}
|
||||||
ret = -ENODEV;
|
ret = -ENODEV;
|
||||||
switch (part->target) {
|
switch (part->target) {
|
||||||
|
@ -84,7 +84,7 @@ tegra_xusb_padctl_group_parse_dt(struct tegra_xusb_padctl *padctl,
|
|||||||
|
|
||||||
len = ofnode_read_string_count(node, "nvidia,lanes");
|
len = ofnode_read_string_count(node, "nvidia,lanes");
|
||||||
if (len < 0) {
|
if (len < 0) {
|
||||||
pr_err("failed to parse \"nvidia,lanes\" property");
|
pr_err("failed to parse \"nvidia,lanes\" property\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,7 +94,7 @@ tegra_xusb_padctl_group_parse_dt(struct tegra_xusb_padctl *padctl,
|
|||||||
ret = ofnode_read_string_index(node, "nvidia,lanes", i,
|
ret = ofnode_read_string_index(node, "nvidia,lanes", i,
|
||||||
&group->pins[i]);
|
&group->pins[i]);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
pr_err("failed to read string from \"nvidia,lanes\" property");
|
pr_err("failed to read string from \"nvidia,lanes\" property\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -104,7 +104,7 @@ tegra_xusb_padctl_group_parse_dt(struct tegra_xusb_padctl *padctl,
|
|||||||
ret = ofnode_read_string_index(node, "nvidia,function", 0,
|
ret = ofnode_read_string_index(node, "nvidia,function", 0,
|
||||||
&group->func);
|
&group->func);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
pr_err("failed to parse \"nvidia,func\" property");
|
pr_err("failed to parse \"nvidia,func\" property\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -232,7 +232,7 @@ tegra_xusb_padctl_config_parse_dt(struct tegra_xusb_padctl *padctl,
|
|||||||
|
|
||||||
err = tegra_xusb_padctl_group_parse_dt(padctl, group, subnode);
|
err = tegra_xusb_padctl_group_parse_dt(padctl, group, subnode);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
pr_err("failed to parse group %s", group->name);
|
pr_err("failed to parse group %s\n", group->name);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -261,7 +261,7 @@ static int tegra_xusb_padctl_parse_dt(struct tegra_xusb_padctl *padctl,
|
|||||||
err = tegra_xusb_padctl_config_parse_dt(padctl, config,
|
err = tegra_xusb_padctl_config_parse_dt(padctl, config,
|
||||||
subnode);
|
subnode);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
pr_err("failed to parse entry %s: %d",
|
pr_err("failed to parse entry %s: %d\n",
|
||||||
config->name, err);
|
config->name, err);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -289,7 +289,7 @@ int tegra_xusb_process_nodes(ofnode nodes[], unsigned int count,
|
|||||||
|
|
||||||
err = tegra_xusb_padctl_parse_dt(&padctl, nodes[i]);
|
err = tegra_xusb_padctl_parse_dt(&padctl, nodes[i]);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
pr_err("failed to parse DT: %d", err);
|
pr_err("failed to parse DT: %d\n", err);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BOARDS from CS Systemes d'Information
|
BOARDS from CS GROUP France
|
||||||
M: Christophe Leroy <christophe.leroy@c-s.fr>
|
M: Christophe Leroy <christophe.leroy@csgroup.eu>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: board/cssi/
|
F: board/cssi/
|
||||||
F: include/configs/MCR3000.h
|
F: include/configs/MCR3000.h
|
||||||
|
@ -23,6 +23,14 @@
|
|||||||
arch = "arm";
|
arch = "arm";
|
||||||
compression = "none";
|
compression = "none";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
fdt-2 {
|
||||||
|
description = ".dtb";
|
||||||
|
data = /incbin/("arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dtb");
|
||||||
|
type = "flat_dt";
|
||||||
|
arch = "arm";
|
||||||
|
compression = "none";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
configurations {
|
configurations {
|
||||||
@ -35,6 +43,13 @@
|
|||||||
fdt = "fdt-1";
|
fdt = "fdt-1";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
config-2 {
|
||||||
|
/* DT+SoM+board model */
|
||||||
|
description = "dh,stm32mp15xx-dhcor-drc-compact_somrev0_boardrev0";
|
||||||
|
firmware = "uboot";
|
||||||
|
fdt = "fdt-2";
|
||||||
|
};
|
||||||
|
|
||||||
/* Add 586-200..586-400 with fdt-2..fdt-4 here */
|
/* Add 586-200..586-400 with fdt-2..fdt-4 here */
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -3,6 +3,7 @@ config CHAIN_OF_TRUST
|
|||||||
imply CMD_BLOB
|
imply CMD_BLOB
|
||||||
imply CMD_HASH if ARM
|
imply CMD_HASH if ARM
|
||||||
select FSL_CAAM
|
select FSL_CAAM
|
||||||
|
select ARCH_MISC_INIT
|
||||||
select SPL_BOARD_INIT if (ARM && SPL)
|
select SPL_BOARD_INIT if (ARM && SPL)
|
||||||
select SPL_HASH if (ARM && SPL)
|
select SPL_HASH if (ARM && SPL)
|
||||||
select SHA_HW_ACCEL
|
select SHA_HW_ACCEL
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0+
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
/*
|
/*
|
||||||
|
* Copyright (C) 2022 Josua Mayer <josua@solid-run.com>
|
||||||
|
*
|
||||||
* Copyright (C) 2015 Freescale Semiconductor, Inc.
|
* Copyright (C) 2015 Freescale Semiconductor, Inc.
|
||||||
*
|
*
|
||||||
* Author: Fabio Estevam <fabio.estevam@freescale.com>
|
* Author: Fabio Estevam <fabio.estevam@freescale.com>
|
||||||
@ -39,6 +41,8 @@
|
|||||||
#include <spl.h>
|
#include <spl.h>
|
||||||
#include <usb.h>
|
#include <usb.h>
|
||||||
#include <usb/ehci-ci.h>
|
#include <usb/ehci-ci.h>
|
||||||
|
#include <netdev.h>
|
||||||
|
#include <phy.h>
|
||||||
|
|
||||||
DECLARE_GLOBAL_DATA_PTR;
|
DECLARE_GLOBAL_DATA_PTR;
|
||||||
|
|
||||||
@ -407,6 +411,80 @@ out:
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int find_ethernet_phy(void)
|
||||||
|
{
|
||||||
|
struct mii_dev *bus = NULL;
|
||||||
|
struct phy_device *phydev = NULL;
|
||||||
|
int phy_addr = -ENOENT;
|
||||||
|
|
||||||
|
#ifdef CONFIG_FEC_MXC
|
||||||
|
bus = fec_get_miibus(ENET_BASE_ADDR, -1);
|
||||||
|
if (!bus)
|
||||||
|
return -ENOENT;
|
||||||
|
|
||||||
|
// scan address 0, 1, 4
|
||||||
|
phydev = phy_find_by_mask(bus, 0b00010011);
|
||||||
|
if (!phydev) {
|
||||||
|
free(bus);
|
||||||
|
return -ENOENT;
|
||||||
|
}
|
||||||
|
pr_debug("%s: detected ethernet phy at address %d\n", __func__, phydev->addr);
|
||||||
|
phy_addr = phydev->addr;
|
||||||
|
|
||||||
|
free(phydev);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return phy_addr;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
||||||
|
/*
|
||||||
|
* Configure the correct ethernet PHYs nodes in device-tree:
|
||||||
|
* - AR8035 at addresses 0 or 4: Cubox
|
||||||
|
* - AR8035 at address 0: HummingBoard, HummingBoard 2
|
||||||
|
* - ADIN1300 at address 1: since SoM rev 1.9
|
||||||
|
*/
|
||||||
|
int ft_board_setup(void *fdt, struct bd_info *bd)
|
||||||
|
{
|
||||||
|
int node_phy0, node_phy1, node_phy4;
|
||||||
|
int ret, phy;
|
||||||
|
bool enable_phy0 = false, enable_phy1 = false, enable_phy4 = false;
|
||||||
|
|
||||||
|
// detect phy
|
||||||
|
phy = find_ethernet_phy();
|
||||||
|
if (phy == 0 || phy == 4) {
|
||||||
|
enable_phy0 = true;
|
||||||
|
switch (board_type()) {
|
||||||
|
case CUBOXI:
|
||||||
|
case UNKNOWN:
|
||||||
|
default:
|
||||||
|
enable_phy4 = true;
|
||||||
|
}
|
||||||
|
} else if (phy == 1) {
|
||||||
|
enable_phy1 = true;
|
||||||
|
} else {
|
||||||
|
pr_err("%s: couldn't detect ethernet phy, not patching dtb!\n", __func__);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// update all phy nodes status
|
||||||
|
node_phy0 = fdt_path_offset(fdt, "/soc/bus@2100000/ethernet@2188000/mdio/ethernet-phy@0");
|
||||||
|
ret = fdt_setprop_string(fdt, node_phy0, "status", enable_phy0 ? "okay" : "disabled");
|
||||||
|
if (ret < 0 && enable_phy0)
|
||||||
|
pr_err("%s: failed to enable ethernet phy at address 0 in dtb!\n", __func__);
|
||||||
|
node_phy1 = fdt_path_offset(fdt, "/soc/bus@2100000/ethernet@2188000/mdio/ethernet-phy@1");
|
||||||
|
ret = fdt_setprop_string(fdt, node_phy1, "status", enable_phy1 ? "okay" : "disabled");
|
||||||
|
if (ret < 0 && enable_phy1)
|
||||||
|
pr_err("%s: failed to enable ethernet phy at address 1 in dtb!\n", __func__);
|
||||||
|
node_phy4 = fdt_path_offset(fdt, "/soc/bus@2100000/ethernet@2188000/mdio/ethernet-phy@4");
|
||||||
|
ret = fdt_setprop_string(fdt, node_phy4, "status", enable_phy4 ? "okay" : "disabled");
|
||||||
|
if (ret < 0 && enable_phy4)
|
||||||
|
pr_err("%s: failed to enable ethernet phy at address 4 in dtb!\n", __func__);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Override the default implementation, DT model is not accurate */
|
/* Override the default implementation, DT model is not accurate */
|
||||||
int show_board_info(void)
|
int show_board_info(void)
|
||||||
{
|
{
|
||||||
|
@ -902,7 +902,7 @@ int board_late_init(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* CPSW plat */
|
/* CPSW plat */
|
||||||
#if !CONFIG_IS_ENABLED(OF_CONTROL)
|
#if CONFIG_IS_ENABLED(NET) && !CONFIG_IS_ENABLED(OF_CONTROL)
|
||||||
struct cpsw_slave_data slave_data[] = {
|
struct cpsw_slave_data slave_data[] = {
|
||||||
{
|
{
|
||||||
.slave_reg_ofs = CPSW_SLAVE0_OFFSET,
|
.slave_reg_ofs = CPSW_SLAVE0_OFFSET,
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
#include <env.h>
|
#include <env.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <linux/libfdt.h>
|
#include <linux/libfdt.h>
|
||||||
|
#include <linux/bitops.h>
|
||||||
|
|
||||||
#include "../common/tdx-cfg-block.h"
|
#include "../common/tdx-cfg-block.h"
|
||||||
|
|
||||||
@ -28,22 +29,75 @@ DECLARE_GLOBAL_DATA_PTR;
|
|||||||
(SC_PAD_28FDSOI_DSE_DV_HIGH << PADRING_DSE_SHIFT) | \
|
(SC_PAD_28FDSOI_DSE_DV_HIGH << PADRING_DSE_SHIFT) | \
|
||||||
(SC_PAD_28FDSOI_PS_PU << PADRING_PULL_SHIFT))
|
(SC_PAD_28FDSOI_PS_PU << PADRING_PULL_SHIFT))
|
||||||
|
|
||||||
|
#define TDX_USER_FUSE_BLOCK1_A 276
|
||||||
|
#define TDX_USER_FUSE_BLOCK1_B 277
|
||||||
|
#define TDX_USER_FUSE_BLOCK2_A 278
|
||||||
|
#define TDX_USER_FUSE_BLOCK2_B 279
|
||||||
|
|
||||||
static iomux_cfg_t uart1_pads[] = {
|
static iomux_cfg_t uart1_pads[] = {
|
||||||
SC_P_UART1_RX | MUX_PAD_CTRL(UART_PAD_CTRL),
|
SC_P_UART1_RX | MUX_PAD_CTRL(UART_PAD_CTRL),
|
||||||
SC_P_UART1_TX | MUX_PAD_CTRL(UART_PAD_CTRL),
|
SC_P_UART1_TX | MUX_PAD_CTRL(UART_PAD_CTRL),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct tdx_user_fuses {
|
||||||
|
u16 pid4;
|
||||||
|
u16 vers;
|
||||||
|
u8 ramid;
|
||||||
|
};
|
||||||
|
|
||||||
static void setup_iomux_uart(void)
|
static void setup_iomux_uart(void)
|
||||||
{
|
{
|
||||||
imx8_iomux_setup_multiple_pads(uart1_pads, ARRAY_SIZE(uart1_pads));
|
imx8_iomux_setup_multiple_pads(uart1_pads, ARRAY_SIZE(uart1_pads));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static uint32_t do_get_tdx_user_fuse(int a, int b)
|
||||||
|
{
|
||||||
|
sc_err_t sciErr;
|
||||||
|
u32 val_a = 0;
|
||||||
|
u32 val_b = 0;
|
||||||
|
|
||||||
|
sciErr = sc_misc_otp_fuse_read(-1, a, &val_a);
|
||||||
|
if (sciErr != SC_ERR_NONE) {
|
||||||
|
printf("Error reading out user fuse %d\n", a);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
sciErr = sc_misc_otp_fuse_read(-1, b, &val_b);
|
||||||
|
if (sciErr != SC_ERR_NONE) {
|
||||||
|
printf("Error reading out user fuse %d\n", b);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ((val_a & 0xffff) << 16) | (val_b & 0xffff);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void get_tdx_user_fuse(struct tdx_user_fuses *tdxuserfuse)
|
||||||
|
{
|
||||||
|
u32 fuse_block;
|
||||||
|
|
||||||
|
fuse_block = do_get_tdx_user_fuse(TDX_USER_FUSE_BLOCK2_A,
|
||||||
|
TDX_USER_FUSE_BLOCK2_B);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Fuse block 2 acts as a backup area, if this reads 0 we want to
|
||||||
|
* use fuse block 1
|
||||||
|
*/
|
||||||
|
if (fuse_block == 0)
|
||||||
|
fuse_block = do_get_tdx_user_fuse(TDX_USER_FUSE_BLOCK1_A,
|
||||||
|
TDX_USER_FUSE_BLOCK1_B);
|
||||||
|
|
||||||
|
tdxuserfuse->pid4 = (fuse_block >> 18) & GENMASK(13, 0);
|
||||||
|
tdxuserfuse->vers = (fuse_block >> 4) & GENMASK(13, 0);
|
||||||
|
tdxuserfuse->ramid = fuse_block & GENMASK(3, 0);
|
||||||
|
}
|
||||||
|
|
||||||
void board_mem_get_layout(u64 *phys_sdram_1_start,
|
void board_mem_get_layout(u64 *phys_sdram_1_start,
|
||||||
u64 *phys_sdram_1_size,
|
u64 *phys_sdram_1_size,
|
||||||
u64 *phys_sdram_2_start,
|
u64 *phys_sdram_2_start,
|
||||||
u64 *phys_sdram_2_size)
|
u64 *phys_sdram_2_size)
|
||||||
{
|
{
|
||||||
u32 is_quadplus = 0, val = 0;
|
u32 is_quadplus = 0, val = 0;
|
||||||
|
struct tdx_user_fuses tdxramfuses;
|
||||||
sc_err_t scierr = sc_misc_otp_fuse_read(-1, 6, &val);
|
sc_err_t scierr = sc_misc_otp_fuse_read(-1, 6, &val);
|
||||||
|
|
||||||
if (scierr == SC_ERR_NONE) {
|
if (scierr == SC_ERR_NONE) {
|
||||||
@ -51,14 +105,33 @@ void board_mem_get_layout(u64 *phys_sdram_1_start,
|
|||||||
is_quadplus = ((val >> 4) & 0x3) != 0x0;
|
is_quadplus = ((val >> 4) & 0x3) != 0x0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get_tdx_user_fuse(&tdxramfuses);
|
||||||
|
|
||||||
*phys_sdram_1_start = PHYS_SDRAM_1;
|
*phys_sdram_1_start = PHYS_SDRAM_1;
|
||||||
*phys_sdram_1_size = PHYS_SDRAM_1_SIZE;
|
*phys_sdram_1_size = PHYS_SDRAM_1_SIZE;
|
||||||
*phys_sdram_2_start = PHYS_SDRAM_2;
|
*phys_sdram_2_start = PHYS_SDRAM_2;
|
||||||
if (is_quadplus)
|
|
||||||
/* Our QP based SKUs only have 2 GB RAM (PHYS_SDRAM_1_SIZE) */
|
switch (tdxramfuses.ramid) {
|
||||||
|
case 1:
|
||||||
|
*phys_sdram_2_size = SZ_2G;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
*phys_sdram_2_size = 0x0UL;
|
*phys_sdram_2_size = 0x0UL;
|
||||||
else
|
break;
|
||||||
*phys_sdram_2_size = PHYS_SDRAM_2_SIZE;
|
case 3:
|
||||||
|
*phys_sdram_2_size = SZ_2G;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
*phys_sdram_2_size = SZ_4G + SZ_2G;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if (is_quadplus)
|
||||||
|
/* Our QP based SKUs only have 2 GB RAM (PHYS_SDRAM_1_SIZE) */
|
||||||
|
*phys_sdram_2_size = 0x0UL;
|
||||||
|
else
|
||||||
|
*phys_sdram_2_size = PHYS_SDRAM_2_SIZE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int board_early_init_f(void)
|
int board_early_init_f(void)
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#include <asm/arch/gpio.h>
|
#include <asm/arch/gpio.h>
|
||||||
#include <asm/arch/pinmux.h>
|
#include <asm/arch/pinmux.h>
|
||||||
#include <env_internal.h>
|
#include <env_internal.h>
|
||||||
|
#include <fdt_support.h>
|
||||||
#include <pci_tegra.h>
|
#include <pci_tegra.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <power/as3722.h>
|
#include <power/as3722.h>
|
||||||
@ -99,6 +100,24 @@ int checkboard(void)
|
|||||||
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
||||||
int ft_board_setup(void *blob, struct bd_info *bd)
|
int ft_board_setup(void *blob, struct bd_info *bd)
|
||||||
{
|
{
|
||||||
|
u8 enetaddr[6];
|
||||||
|
|
||||||
|
/* MAC addr */
|
||||||
|
if (eth_env_get_enetaddr("ethaddr", enetaddr)) {
|
||||||
|
int err = fdt_find_and_setprop(blob,
|
||||||
|
"/pcie@1003000/pci@2,0/ethernet@0,0",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
/* Older device trees might have used a different node name */
|
||||||
|
if (err < 0)
|
||||||
|
err = fdt_find_and_setprop(blob,
|
||||||
|
"/pcie@1003000/pci@2,0/pcie@0",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
if (err >= 0)
|
||||||
|
puts(" MAC address updated...\n");
|
||||||
|
}
|
||||||
|
|
||||||
return ft_common_board_setup(blob, bd);
|
return ft_common_board_setup(blob, bd);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
|
#include <env.h>
|
||||||
#include <init.h>
|
#include <init.h>
|
||||||
#include <log.h>
|
#include <log.h>
|
||||||
#include <asm/arch/gp_padctrl.h>
|
#include <asm/arch/gp_padctrl.h>
|
||||||
@ -16,6 +17,7 @@
|
|||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <dm.h>
|
#include <dm.h>
|
||||||
#include <i2c.h>
|
#include <i2c.h>
|
||||||
|
#include <fdt_support.h>
|
||||||
#include <pci_tegra.h>
|
#include <pci_tegra.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include "../common/tdx-common.h"
|
#include "../common/tdx-common.h"
|
||||||
@ -54,6 +56,24 @@ int checkboard(void)
|
|||||||
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
||||||
int ft_board_setup(void *blob, struct bd_info *bd)
|
int ft_board_setup(void *blob, struct bd_info *bd)
|
||||||
{
|
{
|
||||||
|
u8 enetaddr[6];
|
||||||
|
|
||||||
|
/* MAC addr */
|
||||||
|
if (eth_env_get_enetaddr("ethaddr", enetaddr)) {
|
||||||
|
int err = fdt_find_and_setprop(blob,
|
||||||
|
"/pcie@3000/pci@3,0/ethernet@0,0",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
/* Older device trees might have used a different node name */
|
||||||
|
if (err < 0)
|
||||||
|
err = fdt_find_and_setprop(blob,
|
||||||
|
"/pcie@3000/pci@3,0/pcie@0",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
if (err >= 0)
|
||||||
|
puts(" MAC address updated...\n");
|
||||||
|
}
|
||||||
|
|
||||||
return ft_common_board_setup(blob, bd);
|
return ft_common_board_setup(blob, bd);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -4,6 +4,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
|
#include <env.h>
|
||||||
|
#include <fdt_support.h>
|
||||||
#include <init.h>
|
#include <init.h>
|
||||||
#include <log.h>
|
#include <log.h>
|
||||||
#include <asm/arch/clock.h>
|
#include <asm/arch/clock.h>
|
||||||
@ -81,6 +83,24 @@ int checkboard(void)
|
|||||||
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
||||||
int ft_board_setup(void *blob, struct bd_info *bd)
|
int ft_board_setup(void *blob, struct bd_info *bd)
|
||||||
{
|
{
|
||||||
|
u8 enetaddr[6];
|
||||||
|
|
||||||
|
/* MAC addr */
|
||||||
|
if (eth_env_get_enetaddr("ethaddr", enetaddr)) {
|
||||||
|
int err = fdt_find_and_setprop(blob,
|
||||||
|
"/usb@7d004000/ethernet@1",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
/* Older device trees might have used a different node name */
|
||||||
|
if (err < 0)
|
||||||
|
err = fdt_find_and_setprop(blob,
|
||||||
|
"/usb@7d004000/asix@1",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
if (err >= 0)
|
||||||
|
puts(" MAC address updated...\n");
|
||||||
|
}
|
||||||
|
|
||||||
return ft_common_board_setup(blob, bd);
|
return ft_common_board_setup(blob, bd);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
|
#include <env.h>
|
||||||
#include <init.h>
|
#include <init.h>
|
||||||
#include <asm/arch/gp_padctrl.h>
|
#include <asm/arch/gp_padctrl.h>
|
||||||
#include <asm/arch/pinmux.h>
|
#include <asm/arch/pinmux.h>
|
||||||
@ -12,6 +13,7 @@
|
|||||||
#include <asm/arch-tegra/tegra.h>
|
#include <asm/arch-tegra/tegra.h>
|
||||||
#include <asm/gpio.h>
|
#include <asm/gpio.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
#include <fdt_support.h>
|
||||||
#include <i2c.h>
|
#include <i2c.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include "pinmux-config-colibri_t30.h"
|
#include "pinmux-config-colibri_t30.h"
|
||||||
@ -36,6 +38,24 @@ int checkboard(void)
|
|||||||
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
|
||||||
int ft_board_setup(void *blob, struct bd_info *bd)
|
int ft_board_setup(void *blob, struct bd_info *bd)
|
||||||
{
|
{
|
||||||
|
u8 enetaddr[6];
|
||||||
|
|
||||||
|
/* MAC addr */
|
||||||
|
if (eth_env_get_enetaddr("ethaddr", enetaddr)) {
|
||||||
|
int err = fdt_find_and_setprop(blob,
|
||||||
|
"/usb@7d004000/ethernet@1",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
/* Older device trees might have used a different node name */
|
||||||
|
if (err < 0)
|
||||||
|
err = fdt_find_and_setprop(blob,
|
||||||
|
"/usb@7d004000/asix@1",
|
||||||
|
"local-mac-address", enetaddr, 6, 0);
|
||||||
|
|
||||||
|
if (err >= 0)
|
||||||
|
puts(" MAC address updated...\n");
|
||||||
|
}
|
||||||
|
|
||||||
return ft_common_board_setup(blob, bd);
|
return ft_common_board_setup(blob, bd);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -144,6 +144,7 @@ const char * const toradex_modules[] = {
|
|||||||
[64] = "Verdin iMX8M Plus Quad 2GB Wi-Fi / BT IT",
|
[64] = "Verdin iMX8M Plus Quad 2GB Wi-Fi / BT IT",
|
||||||
[65] = "Verdin iMX8M Plus QuadLite 1GB IT",
|
[65] = "Verdin iMX8M Plus QuadLite 1GB IT",
|
||||||
[66] = "Verdin iMX8M Plus Quad 8GB Wi-Fi / BT",
|
[66] = "Verdin iMX8M Plus Quad 8GB Wi-Fi / BT",
|
||||||
|
[67] = "Apalis iMX8 QuadMax 8GB Wi-Fi / BT IT",
|
||||||
};
|
};
|
||||||
|
|
||||||
const char * const toradex_carrier_boards[] = {
|
const char * const toradex_carrier_boards[] = {
|
||||||
@ -359,6 +360,7 @@ static int get_cfgblock_interactive(void)
|
|||||||
char *soc;
|
char *soc;
|
||||||
char it = 'n';
|
char it = 'n';
|
||||||
char wb = 'n';
|
char wb = 'n';
|
||||||
|
char mem8g = 'n';
|
||||||
int len = 0;
|
int len = 0;
|
||||||
|
|
||||||
/* Unknown module by default */
|
/* Unknown module by default */
|
||||||
@ -377,6 +379,14 @@ static int get_cfgblock_interactive(void)
|
|||||||
sprintf(message, "Does the module have Wi-Fi / Bluetooth? [y/N] ");
|
sprintf(message, "Does the module have Wi-Fi / Bluetooth? [y/N] ");
|
||||||
len = cli_readline(message);
|
len = cli_readline(message);
|
||||||
wb = console_buffer[0];
|
wb = console_buffer[0];
|
||||||
|
|
||||||
|
#if defined(CONFIG_TARGET_APALIS_IMX8)
|
||||||
|
if ((wb == 'y' || wb == 'Y') && (it == 'y' || it == 'Y')) {
|
||||||
|
sprintf(message, "Does your module have 8GB of RAM? [y/N] ");
|
||||||
|
len = cli_readline(message);
|
||||||
|
mem8g = console_buffer[0];
|
||||||
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
soc = env_get("soc");
|
soc = env_get("soc");
|
||||||
@ -430,8 +440,12 @@ static int get_cfgblock_interactive(void)
|
|||||||
tdx_hw_tag.prodid = COLIBRI_IMX7S;
|
tdx_hw_tag.prodid = COLIBRI_IMX7S;
|
||||||
else if (is_cpu_type(MXC_CPU_IMX8QM)) {
|
else if (is_cpu_type(MXC_CPU_IMX8QM)) {
|
||||||
if (it == 'y' || it == 'Y') {
|
if (it == 'y' || it == 'Y') {
|
||||||
if (wb == 'y' || wb == 'Y')
|
if (wb == 'y' || wb == 'Y') {
|
||||||
tdx_hw_tag.prodid = APALIS_IMX8QM_WIFI_BT_IT;
|
if (mem8g == 'y' || mem8g == 'Y')
|
||||||
|
tdx_hw_tag.prodid = APALIS_IMX8QM_8GB_WIFI_BT_IT;
|
||||||
|
else
|
||||||
|
tdx_hw_tag.prodid = APALIS_IMX8QM_WIFI_BT_IT;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
tdx_hw_tag.prodid = APALIS_IMX8QM_IT;
|
tdx_hw_tag.prodid = APALIS_IMX8QM_IT;
|
||||||
} else {
|
} else {
|
||||||
|
@ -87,6 +87,7 @@ enum {
|
|||||||
VERDIN_IMX8MPQ_2GB_WIFI_BT_IT,
|
VERDIN_IMX8MPQ_2GB_WIFI_BT_IT,
|
||||||
VERDIN_IMX8MPQL_IT, /* 65 */
|
VERDIN_IMX8MPQL_IT, /* 65 */
|
||||||
VERDIN_IMX8MPQ_8GB_WIFI_BT,
|
VERDIN_IMX8MPQ_8GB_WIFI_BT,
|
||||||
|
APALIS_IMX8QM_8GB_WIFI_BT_IT,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -245,6 +245,10 @@ static int xilinx_read_eeprom_fru(struct udevice *dev, char *name,
|
|||||||
}
|
}
|
||||||
strncpy(desc->revision, (char *)fru_data.brd.rev,
|
strncpy(desc->revision, (char *)fru_data.brd.rev,
|
||||||
sizeof(desc->revision));
|
sizeof(desc->revision));
|
||||||
|
for (i = 0; i < sizeof(desc->revision); i++) {
|
||||||
|
if (desc->revision[i] == ' ')
|
||||||
|
desc->revision[i] = '\0';
|
||||||
|
}
|
||||||
strncpy(desc->serial, (char *)fru_data.brd.serial_number,
|
strncpy(desc->serial, (char *)fru_data.brd.serial_number,
|
||||||
sizeof(desc->serial));
|
sizeof(desc->serial));
|
||||||
|
|
||||||
|
@ -182,8 +182,10 @@ static int efi_dump_var_all(int argc, char *const argv[],
|
|||||||
}
|
}
|
||||||
free(var_name16);
|
free(var_name16);
|
||||||
|
|
||||||
if (!match && argc == 1)
|
if (!match && argc == 1) {
|
||||||
printf("Error: \"%s\" not defined\n", argv[0]);
|
printf("Error: \"%s\" not defined\n", argv[0]);
|
||||||
|
return CMD_RET_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
return CMD_RET_SUCCESS;
|
return CMD_RET_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -59,6 +59,9 @@ CONFIG_CMD_FUSE=y
|
|||||||
CONFIG_CMD_GPIO=y
|
CONFIG_CMD_GPIO=y
|
||||||
CONFIG_CMD_I2C=y
|
CONFIG_CMD_I2C=y
|
||||||
CONFIG_CMD_MMC=y
|
CONFIG_CMD_MMC=y
|
||||||
|
CONFIG_CMD_DHCP=y
|
||||||
|
CONFIG_CMD_MII=y
|
||||||
|
CONFIG_CMD_PING=y
|
||||||
CONFIG_CMD_CACHE=y
|
CONFIG_CMD_CACHE=y
|
||||||
CONFIG_CMD_REGULATOR=y
|
CONFIG_CMD_REGULATOR=y
|
||||||
CONFIG_CMD_EXT4_WRITE=y
|
CONFIG_CMD_EXT4_WRITE=y
|
||||||
@ -83,7 +86,12 @@ CONFIG_MMC_HS400_SUPPORT=y
|
|||||||
CONFIG_SPL_MMC_HS400_SUPPORT=y
|
CONFIG_SPL_MMC_HS400_SUPPORT=y
|
||||||
CONFIG_FSL_USDHC=y
|
CONFIG_FSL_USDHC=y
|
||||||
CONFIG_PHYLIB=y
|
CONFIG_PHYLIB=y
|
||||||
|
CONFIG_PHY_ATHEROS=y
|
||||||
CONFIG_DM_ETH=y
|
CONFIG_DM_ETH=y
|
||||||
|
CONFIG_DM_ETH_PHY=y
|
||||||
|
CONFIG_PHY_GIGE=y
|
||||||
|
CONFIG_FEC_MXC=y
|
||||||
|
CONFIG_MII=y
|
||||||
CONFIG_PINCTRL=y
|
CONFIG_PINCTRL=y
|
||||||
CONFIG_SPL_PINCTRL=y
|
CONFIG_SPL_PINCTRL=y
|
||||||
CONFIG_PINCTRL_IMX8M=y
|
CONFIG_PINCTRL_IMX8M=y
|
||||||
|
@ -22,6 +22,7 @@ CONFIG_CMD_HDMIDETECT=y
|
|||||||
CONFIG_AHCI=y
|
CONFIG_AHCI=y
|
||||||
CONFIG_DISTRO_DEFAULTS=y
|
CONFIG_DISTRO_DEFAULTS=y
|
||||||
CONFIG_FIT=y
|
CONFIG_FIT=y
|
||||||
|
CONFIG_OF_BOARD_SETUP=y
|
||||||
CONFIG_BOOTCOMMAND="run findfdt; run finduuid; run distro_bootcmd"
|
CONFIG_BOOTCOMMAND="run findfdt; run finduuid; run distro_bootcmd"
|
||||||
CONFIG_USE_PREBOOT=y
|
CONFIG_USE_PREBOOT=y
|
||||||
CONFIG_PREBOOT="if hdmidet; then usb start; setenv stdin serial,usbkbd; setenv stdout serial,vidconsole; setenv stderr serial,vidconsole; else setenv stdin serial; setenv stdout serial; setenv stderr serial; fi;"
|
CONFIG_PREBOOT="if hdmidet; then usb start; setenv stdin serial,usbkbd; setenv stdout serial,vidconsole; setenv stderr serial,vidconsole; else setenv stdin serial; setenv stdout serial; setenv stderr serial; fi;"
|
||||||
@ -58,6 +59,7 @@ CONFIG_DWC_AHSATA=y
|
|||||||
CONFIG_SPL_SYS_I2C_LEGACY=y
|
CONFIG_SPL_SYS_I2C_LEGACY=y
|
||||||
CONFIG_FSL_USDHC=y
|
CONFIG_FSL_USDHC=y
|
||||||
CONFIG_PHYLIB=y
|
CONFIG_PHYLIB=y
|
||||||
|
CONFIG_PHY_ADIN=y
|
||||||
CONFIG_PHY_ATHEROS=y
|
CONFIG_PHY_ATHEROS=y
|
||||||
CONFIG_DM_ETH=y
|
CONFIG_DM_ETH=y
|
||||||
CONFIG_FEC_MXC=y
|
CONFIG_FEC_MXC=y
|
||||||
|
@ -121,6 +121,7 @@ CONFIG_PHY_MICREL=y
|
|||||||
CONFIG_PHY_MICREL_KSZ90X1=y
|
CONFIG_PHY_MICREL_KSZ90X1=y
|
||||||
CONFIG_DM_ETH=y
|
CONFIG_DM_ETH=y
|
||||||
CONFIG_DWC_ETH_QOS=y
|
CONFIG_DWC_ETH_QOS=y
|
||||||
|
CONFIG_KS8851_MLL=y
|
||||||
CONFIG_PHY=y
|
CONFIG_PHY=y
|
||||||
CONFIG_SPL_PHY=y
|
CONFIG_SPL_PHY=y
|
||||||
CONFIG_PHY_STM32_USBPHYC=y
|
CONFIG_PHY_STM32_USBPHYC=y
|
||||||
|
@ -95,7 +95,7 @@ alias nios2 nios
|
|||||||
|
|
||||||
alias powerpc uboot, afleming, stroese, wd, priyankajain, mariosix
|
alias powerpc uboot, afleming, stroese, wd, priyankajain, mariosix
|
||||||
alias ppc powerpc
|
alias ppc powerpc
|
||||||
alias mpc8xx uboot, wd, Christophe Leroy <christophe.leroy@c-s.fr>
|
alias mpc8xx uboot, wd, Christophe Leroy <christophe.leroy@csgroup.eu>
|
||||||
alias mpc83xx uboot, mariosix
|
alias mpc83xx uboot, mariosix
|
||||||
alias mpc85xx uboot, afleming, priyankajain
|
alias mpc85xx uboot, afleming, priyankajain
|
||||||
|
|
||||||
|
66
doc/usage/cmd/bootz.rst
Normal file
66
doc/usage/cmd/bootz.rst
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
.. SPDX-License-Identifier: GPL-2.0+:
|
||||||
|
|
||||||
|
bootz command
|
||||||
|
=============
|
||||||
|
|
||||||
|
Synopsis
|
||||||
|
--------
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
bootz [<addr> [<initrd>[:<size>]] [<fdt>]]
|
||||||
|
|
||||||
|
Description
|
||||||
|
-----------
|
||||||
|
|
||||||
|
The bootz command is used to boot a Linux kernel in 'zImage' format.
|
||||||
|
|
||||||
|
addr
|
||||||
|
address of kernel image, defaults to the value of the environment
|
||||||
|
variable $loadaddr.
|
||||||
|
|
||||||
|
initrd
|
||||||
|
address of the initial RAM disk. Use '-' to boot a kernel with a device
|
||||||
|
tree but without an initial RAM disk.
|
||||||
|
|
||||||
|
size
|
||||||
|
size of the initial RAM disk. This parameter must be specified for raw
|
||||||
|
initial RAM disks.
|
||||||
|
|
||||||
|
fdt
|
||||||
|
address of the device tree.
|
||||||
|
|
||||||
|
Example
|
||||||
|
-------
|
||||||
|
|
||||||
|
This is the boot log of an OrangePi PC board:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
=> load mmc 0:2 $fdt_addr_r dtb
|
||||||
|
23093 bytes read in 7 ms (3.1 MiB/s)
|
||||||
|
=> load mmc 0:2 $kernel_addr_r vmlinuz
|
||||||
|
5079552 bytes read in 215 ms (22.5 MiB/s)
|
||||||
|
=> load mmc 0:2 $ramdisk_addr_r initrd.img
|
||||||
|
23854965 bytes read in 995 ms (22.9 MiB/s)
|
||||||
|
=> bootz $kernel_addr_r $ramdisk_addr_r:$filesize $fdt_addr_r
|
||||||
|
Kernel image @ 0x42000000 [ 0x000000 - 0x4d8200 ]
|
||||||
|
## Flattened Device Tree blob at 43000000
|
||||||
|
Booting using the fdt blob at 0x43000000
|
||||||
|
EHCI failed to shut down host controller.
|
||||||
|
Loading Ramdisk to 48940000, end 49ffff75 ... OK
|
||||||
|
Loading Device Tree to 48937000, end 4893fa34 ... OK
|
||||||
|
|
||||||
|
Starting kernel ...
|
||||||
|
|
||||||
|
Configuration
|
||||||
|
-------------
|
||||||
|
|
||||||
|
The bootz command is only available if CONFIG_CMD_BOOTZ=y.
|
||||||
|
|
||||||
|
Return value
|
||||||
|
------------
|
||||||
|
|
||||||
|
Normally this command does not return. If an error occurs, the return value $?
|
||||||
|
is set to 1 (false). If the operating system returns to U-Boot, the system is
|
||||||
|
reset.
|
90
doc/usage/cmd/printenv.rst
Normal file
90
doc/usage/cmd/printenv.rst
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
.. SPDX-License-Identifier: GPL-2.0+:
|
||||||
|
|
||||||
|
printenv command
|
||||||
|
================
|
||||||
|
|
||||||
|
Synopsis
|
||||||
|
--------
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
printenv [-a] [name ...]
|
||||||
|
printenv -e [-guid guid][-n] [name]
|
||||||
|
|
||||||
|
Description
|
||||||
|
-----------
|
||||||
|
|
||||||
|
The printenv command is used to print environment or UEFI variables.
|
||||||
|
|
||||||
|
\-a
|
||||||
|
Print environment variables starting with a period ('.').
|
||||||
|
|
||||||
|
\-e
|
||||||
|
Print UEFI variables. Without -e environment variables are printed.
|
||||||
|
|
||||||
|
\-guid *guid*
|
||||||
|
Specify vendor GUID *guid*. If none is specified, all UEFI variables with
|
||||||
|
the specified name are printed irrespective of their vendor GUID.
|
||||||
|
|
||||||
|
\-n
|
||||||
|
don't show hexadecimal dump of value
|
||||||
|
|
||||||
|
name
|
||||||
|
Variable name. If no name is provided, all variables are printed.
|
||||||
|
Multiple environment variable names may be specified.
|
||||||
|
|
||||||
|
Examples
|
||||||
|
--------
|
||||||
|
|
||||||
|
The following examples demonstrates the effect of the *-a* flag when displaying
|
||||||
|
environment variables:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
=> setenv .foo bar
|
||||||
|
=> printenv
|
||||||
|
arch=sandbox
|
||||||
|
baudrate=115200
|
||||||
|
board=sandbox
|
||||||
|
...
|
||||||
|
stdout=serial,vidconsole
|
||||||
|
|
||||||
|
Environment size: 644/8188 bytes
|
||||||
|
=> printenv -a
|
||||||
|
.foo=bar
|
||||||
|
arch=sandbox
|
||||||
|
baudrate=115200
|
||||||
|
board=sandbox
|
||||||
|
...
|
||||||
|
stdout=serial,vidconsole
|
||||||
|
|
||||||
|
Environment size: 653/8188 bytes
|
||||||
|
=>
|
||||||
|
|
||||||
|
The next example shows the effect of the *-n* flag when displaying an UEFI
|
||||||
|
variable and how to specify a vendor GUID:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
=> printenv -e -guid 8be4df61-93ca-11d2-aa0d-00e098032b8c PlatformLangCodes
|
||||||
|
PlatformLangCodes:
|
||||||
|
8be4df61-93ca-11d2-aa0d-00e098032b8c (EFI_GLOBAL_VARIABLE_GUID)
|
||||||
|
BS|RT|RO, DataSize = 0x6
|
||||||
|
00000000: 65 6e 2d 55 53 00 en-US.
|
||||||
|
=> printenv -e -n PlatformLangCodes
|
||||||
|
PlatformLangCodes:
|
||||||
|
8be4df61-93ca-11d2-aa0d-00e098032b8c (EFI_GLOBAL_VARIABLE_GUID)
|
||||||
|
BS|RT|RO, DataSize = 0x6
|
||||||
|
=>
|
||||||
|
|
||||||
|
Configuration
|
||||||
|
=============
|
||||||
|
|
||||||
|
UEFI variables are only supported if CONFIG_CMD_NVEDIT_EFI=y. The value of UEFI
|
||||||
|
variables can only be displayed if CONFIG_HEXDUMP=y.
|
||||||
|
|
||||||
|
Return value
|
||||||
|
------------
|
||||||
|
|
||||||
|
The return value $? is 1 (false) if a specified variable is not found.
|
||||||
|
Otherwise $? is set to 0 (true).
|
@ -30,6 +30,7 @@ Shell commands
|
|||||||
cmd/bootmenu
|
cmd/bootmenu
|
||||||
cmd/bootmeth
|
cmd/bootmeth
|
||||||
cmd/button
|
cmd/button
|
||||||
|
cmd/bootz
|
||||||
cmd/cbsysinfo
|
cmd/cbsysinfo
|
||||||
cmd/conitrace
|
cmd/conitrace
|
||||||
cmd/echo
|
cmd/echo
|
||||||
@ -48,6 +49,7 @@ Shell commands
|
|||||||
cmd/md
|
cmd/md
|
||||||
cmd/mmc
|
cmd/mmc
|
||||||
cmd/pinmux
|
cmd/pinmux
|
||||||
|
cmd/printenv
|
||||||
cmd/pstore
|
cmd/pstore
|
||||||
cmd/qfw
|
cmd/qfw
|
||||||
cmd/reset
|
cmd/reset
|
||||||
|
6
drivers/cache/cache-ncore.c
vendored
6
drivers/cache/cache-ncore.c
vendored
@ -1,6 +1,6 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2019 Intel Corporation <www.intel.com>
|
* Copyright (C) 2019-2022 Intel Corporation <www.intel.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
#include <dm.h>
|
#include <dm.h>
|
||||||
@ -81,8 +81,8 @@ static void ncore_ccu_init_dirs(void __iomem *base)
|
|||||||
hang();
|
hang();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Enable snoop filter, a bit per snoop filter */
|
/* Disable snoop filter, a bit per snoop filter */
|
||||||
setbits_le32((ulong)CCU_DIR_REG_ADDR(base, DIRUSFER, i),
|
clrbits_le32((ulong)CCU_DIR_REG_ADDR(base, DIRUSFER, i),
|
||||||
BIT(f));
|
BIT(f));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -122,15 +122,15 @@ static const char *imx8mp_gic_sels[] = {"clock-osc-24m", "sys_pll2_200m", "sys_p
|
|||||||
"sys_pll2_100m", "sys_pll1_800m",
|
"sys_pll2_100m", "sys_pll1_800m",
|
||||||
"sys_pll2_500m", "clk_ext4", "audio_pll2_out" };
|
"sys_pll2_500m", "clk_ext4", "audio_pll2_out" };
|
||||||
|
|
||||||
static const char *imx8mp_ecspi1_sels[] = {"clock-osc_24m", "sys_pll2_200m", "sys_pll1_40m",
|
static const char *imx8mp_ecspi1_sels[] = {"clock-osc-24m", "sys_pll2_200m", "sys_pll1_40m",
|
||||||
"sys_pll1_160m", "sys_pll1_800m", "sys_pll3_out",
|
"sys_pll1_160m", "sys_pll1_800m", "sys_pll3_out",
|
||||||
"sys_pll2_250m", "audio_pll2_out", };
|
"sys_pll2_250m", "audio_pll2_out", };
|
||||||
|
|
||||||
static const char *imx8mp_ecspi2_sels[] = {"clock-osc_24m", "sys_pll2_200m", "sys_pll1_40m",
|
static const char *imx8mp_ecspi2_sels[] = {"clock-osc-24m", "sys_pll2_200m", "sys_pll1_40m",
|
||||||
"sys_pll1_160m", "sys_pll1_800m", "sys_pll3_out",
|
"sys_pll1_160m", "sys_pll1_800m", "sys_pll3_out",
|
||||||
"sys_pll2_250m", "audio_pll2_out", };
|
"sys_pll2_250m", "audio_pll2_out", };
|
||||||
|
|
||||||
static const char *imx8mp_ecspi3_sels[] = {"clock-osc_24m", "sys_pll2_200m", "sys_pll1_40m",
|
static const char *imx8mp_ecspi3_sels[] = {"clock-osc-24m", "sys_pll2_200m", "sys_pll1_40m",
|
||||||
"sys_pll1_160m", "sys_pll1_800m", "sys_pll3_out",
|
"sys_pll1_160m", "sys_pll1_800m", "sys_pll3_out",
|
||||||
"sys_pll2_250m", "audio_pll2_out", };
|
"sys_pll2_250m", "audio_pll2_out", };
|
||||||
|
|
||||||
@ -300,7 +300,7 @@ static int imx8mp_clk_probe(struct udevice *dev)
|
|||||||
clk_dm(IMX8MP_CLK_UART2_ROOT, imx_clk_gate4("uart2_root_clk", "uart2", base + 0x44a0, 0));
|
clk_dm(IMX8MP_CLK_UART2_ROOT, imx_clk_gate4("uart2_root_clk", "uart2", base + 0x44a0, 0));
|
||||||
clk_dm(IMX8MP_CLK_UART3_ROOT, imx_clk_gate4("uart3_root_clk", "uart3", base + 0x44b0, 0));
|
clk_dm(IMX8MP_CLK_UART3_ROOT, imx_clk_gate4("uart3_root_clk", "uart3", base + 0x44b0, 0));
|
||||||
clk_dm(IMX8MP_CLK_UART4_ROOT, imx_clk_gate4("uart4_root_clk", "uart4", base + 0x44c0, 0));
|
clk_dm(IMX8MP_CLK_UART4_ROOT, imx_clk_gate4("uart4_root_clk", "uart4", base + 0x44c0, 0));
|
||||||
clk_dm(IMX8MP_CLK_USB_ROOT, imx_clk_gate4("usb_root_clk", "osc_32k", base + 0x44d0, 0));
|
clk_dm(IMX8MP_CLK_USB_ROOT, imx_clk_gate4("usb_root_clk", "usb_core_ref", base + 0x44d0, 0));
|
||||||
clk_dm(IMX8MP_CLK_USB_PHY_ROOT, imx_clk_gate4("usb_phy_root_clk", "usb_phy_ref", base + 0x44f0, 0));
|
clk_dm(IMX8MP_CLK_USB_PHY_ROOT, imx_clk_gate4("usb_phy_root_clk", "usb_phy_ref", base + 0x44f0, 0));
|
||||||
clk_dm(IMX8MP_CLK_USDHC1_ROOT, imx_clk_gate4("usdhc1_root_clk", "usdhc1", base + 0x4510, 0));
|
clk_dm(IMX8MP_CLK_USDHC1_ROOT, imx_clk_gate4("usdhc1_root_clk", "usdhc1", base + 0x4510, 0));
|
||||||
clk_dm(IMX8MP_CLK_USDHC2_ROOT, imx_clk_gate4("usdhc2_root_clk", "usdhc2", base + 0x4520, 0));
|
clk_dm(IMX8MP_CLK_USDHC2_ROOT, imx_clk_gate4("usdhc2_root_clk", "usdhc2", base + 0x4520, 0));
|
||||||
|
@ -176,12 +176,6 @@ int caam_hash(const unsigned char *pbuf, unsigned int buf_len,
|
|||||||
uint32_t *desc;
|
uint32_t *desc;
|
||||||
unsigned int size;
|
unsigned int size;
|
||||||
|
|
||||||
if (!IS_ALIGNED((uintptr_t)pbuf, ARCH_DMA_MINALIGN) ||
|
|
||||||
!IS_ALIGNED((uintptr_t)pout, ARCH_DMA_MINALIGN)) {
|
|
||||||
puts("Error: Address arguments are not aligned\n");
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
|
||||||
|
|
||||||
desc = malloc_cache_aligned(sizeof(int) * MAX_CAAM_DESCSIZE);
|
desc = malloc_cache_aligned(sizeof(int) * MAX_CAAM_DESCSIZE);
|
||||||
if (!desc) {
|
if (!desc) {
|
||||||
debug("Not enough memory for descriptor allocation\n");
|
debug("Not enough memory for descriptor allocation\n");
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2020-2021 Intel Corporation <www.intel.com>
|
* Copyright (C) 2020-2022 Intel Corporation <www.intel.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016-2018 Intel Corporation <www.intel.com>
|
* Copyright (C) 2016-2022 Intel Corporation <www.intel.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -277,7 +277,7 @@ int sdram_mmr_init_full(struct udevice *dev)
|
|||||||
DDR_SCH_DEVTODEV);
|
DDR_SCH_DEVTODEV);
|
||||||
|
|
||||||
/* assigning the SDRAM size */
|
/* assigning the SDRAM size */
|
||||||
unsigned long long size = sdram_calculate_size(plat);
|
phys_size_t size = sdram_calculate_size(plat);
|
||||||
/* If the size is invalid, use default Config size */
|
/* If the size is invalid, use default Config size */
|
||||||
if (size <= 0)
|
if (size <= 0)
|
||||||
hw_size = PHYS_SDRAM_1_SIZE;
|
hw_size = PHYS_SDRAM_1_SIZE;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016-2021 Intel Corporation <www.intel.com>
|
* Copyright (C) 2016-2022 Intel Corporation <www.intel.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -239,7 +239,8 @@ phys_size_t sdram_calculate_size(struct altera_sdram_plat *plat)
|
|||||||
{
|
{
|
||||||
u32 dramaddrw = hmc_readl(plat, DRAMADDRW);
|
u32 dramaddrw = hmc_readl(plat, DRAMADDRW);
|
||||||
|
|
||||||
phys_size_t size = 1 << (DRAMADDRW_CFG_CS_ADDR_WIDTH(dramaddrw) +
|
phys_size_t size = (phys_size_t)1 <<
|
||||||
|
(DRAMADDRW_CFG_CS_ADDR_WIDTH(dramaddrw) +
|
||||||
DRAMADDRW_CFG_BANK_GRP_ADDR_WIDTH(dramaddrw) +
|
DRAMADDRW_CFG_BANK_GRP_ADDR_WIDTH(dramaddrw) +
|
||||||
DRAMADDRW_CFG_BANK_ADDR_WIDTH(dramaddrw) +
|
DRAMADDRW_CFG_BANK_ADDR_WIDTH(dramaddrw) +
|
||||||
DRAMADDRW_CFG_ROW_ADDR_WIDTH(dramaddrw) +
|
DRAMADDRW_CFG_ROW_ADDR_WIDTH(dramaddrw) +
|
||||||
|
@ -53,7 +53,7 @@ struct altera_sdram_plat {
|
|||||||
#define DDR_HMC_INTSTAT_DERRPENA_SET_MSK BIT(1)
|
#define DDR_HMC_INTSTAT_DERRPENA_SET_MSK BIT(1)
|
||||||
#define DDR_HMC_INTSTAT_ADDRMTCFLG_SET_MSK BIT(16)
|
#define DDR_HMC_INTSTAT_ADDRMTCFLG_SET_MSK BIT(16)
|
||||||
#define DDR_HMC_INTMODE_INTMODE_SET_MSK BIT(0)
|
#define DDR_HMC_INTMODE_INTMODE_SET_MSK BIT(0)
|
||||||
#define DDR_HMC_RSTHANDSHAKE_MASK 0x000000ff
|
#define DDR_HMC_RSTHANDSHAKE_MASK 0x0000000f
|
||||||
#define DDR_HMC_CORE2SEQ_INT_REQ 0xF
|
#define DDR_HMC_CORE2SEQ_INT_REQ 0xF
|
||||||
#define DDR_HMC_SEQ2CORE_INT_RESP_MASK BIT(3)
|
#define DDR_HMC_SEQ2CORE_INT_RESP_MASK BIT(3)
|
||||||
#define DDR_HMC_HPSINTFCSEL_ENABLE_MASK 0x001f1f1f
|
#define DDR_HMC_HPSINTFCSEL_ENABLE_MASK 0x001f1f1f
|
||||||
|
@ -514,6 +514,7 @@ static const struct dm_i2c_ops tegra_i2c_ops = {
|
|||||||
|
|
||||||
static const struct udevice_id tegra_i2c_ids[] = {
|
static const struct udevice_id tegra_i2c_ids[] = {
|
||||||
{ .compatible = "nvidia,tegra114-i2c", .data = TYPE_114 },
|
{ .compatible = "nvidia,tegra114-i2c", .data = TYPE_114 },
|
||||||
|
{ .compatible = "nvidia,tegra124-i2c", .data = TYPE_114 },
|
||||||
{ .compatible = "nvidia,tegra20-i2c", .data = TYPE_STD },
|
{ .compatible = "nvidia,tegra20-i2c", .data = TYPE_STD },
|
||||||
{ .compatible = "nvidia,tegra20-i2c-dvc", .data = TYPE_DVC },
|
{ .compatible = "nvidia,tegra20-i2c-dvc", .data = TYPE_DVC },
|
||||||
{ }
|
{ }
|
||||||
|
@ -439,6 +439,15 @@ config TEST_DRV
|
|||||||
model. This should only be enabled for testing as it is not useful for
|
model. This should only be enabled for testing as it is not useful for
|
||||||
anything else.
|
anything else.
|
||||||
|
|
||||||
|
config USB_HUB_USB251XB
|
||||||
|
tristate "USB251XB Hub Controller Configuration Driver"
|
||||||
|
depends on I2C
|
||||||
|
help
|
||||||
|
This option enables support for configuration via SMBus of the
|
||||||
|
Microchip USB251x/xBi USB 2.0 Hub Controller series. Configuration
|
||||||
|
parameters may be set in devicetree or platform data.
|
||||||
|
Say Y or M here if you need to configure such a device via SMBus.
|
||||||
|
|
||||||
config TWL4030_LED
|
config TWL4030_LED
|
||||||
bool "Enable TWL4030 LED controller"
|
bool "Enable TWL4030 LED controller"
|
||||||
help
|
help
|
||||||
|
@ -21,6 +21,7 @@ endif
|
|||||||
ifdef CONFIG_$(SPL_)DM_I2C
|
ifdef CONFIG_$(SPL_)DM_I2C
|
||||||
ifndef CONFIG_SPL_BUILD
|
ifndef CONFIG_SPL_BUILD
|
||||||
obj-$(CONFIG_SANDBOX) += i2c_eeprom_emul.o
|
obj-$(CONFIG_SANDBOX) += i2c_eeprom_emul.o
|
||||||
|
obj-$(CONFIG_USB_HUB_USB251XB) += usb251xb.o
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
ifdef CONFIG_SPL_OF_PLATDATA
|
ifdef CONFIG_SPL_OF_PLATDATA
|
||||||
|
605
drivers/misc/usb251xb.c
Normal file
605
drivers/misc/usb251xb.c
Normal file
@ -0,0 +1,605 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0+
|
||||||
|
/*
|
||||||
|
* Driver for Microchip USB251xB USB 2.0 Hi-Speed Hub Controller
|
||||||
|
* Configuration via SMBus.
|
||||||
|
*
|
||||||
|
* Copyright (c) 2017 SKIDATA AG
|
||||||
|
*
|
||||||
|
* This work is based on the USB3503 driver by Dongjin Kim and
|
||||||
|
* a not-accepted patch by Fabien Lahoudere, see:
|
||||||
|
* https://patchwork.kernel.org/patch/9257715/
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <common.h>
|
||||||
|
#include <asm/gpio.h>
|
||||||
|
#include <dm.h>
|
||||||
|
#include <dm/device_compat.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <i2c.h>
|
||||||
|
#include <linux/delay.h>
|
||||||
|
#include <linux/utf.h>
|
||||||
|
#include <power/regulator.h>
|
||||||
|
|
||||||
|
/* Internal Register Set Addresses & Default Values acc. to DS00001692C */
|
||||||
|
#define USB251XB_ADDR_VENDOR_ID_LSB 0x00
|
||||||
|
#define USB251XB_ADDR_VENDOR_ID_MSB 0x01
|
||||||
|
#define USB251XB_DEF_VENDOR_ID 0x0424
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_PRODUCT_ID_LSB 0x02
|
||||||
|
#define USB251XB_ADDR_PRODUCT_ID_MSB 0x03
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_DEVICE_ID_LSB 0x04
|
||||||
|
#define USB251XB_ADDR_DEVICE_ID_MSB 0x05
|
||||||
|
#define USB251XB_DEF_DEVICE_ID 0x0BB3
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_CONFIG_DATA_1 0x06
|
||||||
|
#define USB251XB_DEF_CONFIG_DATA_1 0x9B
|
||||||
|
#define USB251XB_ADDR_CONFIG_DATA_2 0x07
|
||||||
|
#define USB251XB_DEF_CONFIG_DATA_2 0x20
|
||||||
|
#define USB251XB_ADDR_CONFIG_DATA_3 0x08
|
||||||
|
#define USB251XB_DEF_CONFIG_DATA_3 0x02
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_NON_REMOVABLE_DEVICES 0x09
|
||||||
|
#define USB251XB_DEF_NON_REMOVABLE_DEVICES 0x00
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_PORT_DISABLE_SELF 0x0A
|
||||||
|
#define USB251XB_DEF_PORT_DISABLE_SELF 0x00
|
||||||
|
#define USB251XB_ADDR_PORT_DISABLE_BUS 0x0B
|
||||||
|
#define USB251XB_DEF_PORT_DISABLE_BUS 0x00
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_MAX_POWER_SELF 0x0C
|
||||||
|
#define USB251XB_DEF_MAX_POWER_SELF 0x01
|
||||||
|
#define USB251XB_ADDR_MAX_POWER_BUS 0x0D
|
||||||
|
#define USB251XB_DEF_MAX_POWER_BUS 0x32
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_MAX_CURRENT_SELF 0x0E
|
||||||
|
#define USB251XB_DEF_MAX_CURRENT_SELF 0x01
|
||||||
|
#define USB251XB_ADDR_MAX_CURRENT_BUS 0x0F
|
||||||
|
#define USB251XB_DEF_MAX_CURRENT_BUS 0x32
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_POWER_ON_TIME 0x10
|
||||||
|
#define USB251XB_DEF_POWER_ON_TIME 0x32
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_LANGUAGE_ID_HIGH 0x11
|
||||||
|
#define USB251XB_ADDR_LANGUAGE_ID_LOW 0x12
|
||||||
|
#define USB251XB_DEF_LANGUAGE_ID 0x0000
|
||||||
|
|
||||||
|
#define USB251XB_STRING_BUFSIZE 62
|
||||||
|
#define USB251XB_ADDR_MANUFACTURER_STRING_LEN 0x13
|
||||||
|
#define USB251XB_ADDR_MANUFACTURER_STRING 0x16
|
||||||
|
#define USB251XB_DEF_MANUFACTURER_STRING "Microchip"
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_PRODUCT_STRING_LEN 0x14
|
||||||
|
#define USB251XB_ADDR_PRODUCT_STRING 0x54
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_SERIAL_STRING_LEN 0x15
|
||||||
|
#define USB251XB_ADDR_SERIAL_STRING 0x92
|
||||||
|
#define USB251XB_DEF_SERIAL_STRING ""
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_BATTERY_CHARGING_ENABLE 0xD0
|
||||||
|
#define USB251XB_DEF_BATTERY_CHARGING_ENABLE 0x00
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_BOOST_UP 0xF6
|
||||||
|
#define USB251XB_DEF_BOOST_UP 0x00
|
||||||
|
#define USB251XB_ADDR_BOOST_57 0xF7
|
||||||
|
#define USB251XB_DEF_BOOST_57 0x00
|
||||||
|
#define USB251XB_ADDR_BOOST_14 0xF8
|
||||||
|
#define USB251XB_DEF_BOOST_14 0x00
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_PORT_SWAP 0xFA
|
||||||
|
#define USB251XB_DEF_PORT_SWAP 0x00
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_PORT_MAP_12 0xFB
|
||||||
|
#define USB251XB_DEF_PORT_MAP_12 0x00
|
||||||
|
#define USB251XB_ADDR_PORT_MAP_34 0xFC
|
||||||
|
#define USB251XB_DEF_PORT_MAP_34 0x00 /* USB251{3B/i,4B/i,7/i} only */
|
||||||
|
#define USB251XB_ADDR_PORT_MAP_56 0xFD
|
||||||
|
#define USB251XB_DEF_PORT_MAP_56 0x00 /* USB2517/i only */
|
||||||
|
#define USB251XB_ADDR_PORT_MAP_7 0xFE
|
||||||
|
#define USB251XB_DEF_PORT_MAP_7 0x00 /* USB2517/i only */
|
||||||
|
|
||||||
|
#define USB251XB_ADDR_STATUS_COMMAND 0xFF
|
||||||
|
#define USB251XB_STATUS_COMMAND_SMBUS_DOWN 0x04
|
||||||
|
#define USB251XB_STATUS_COMMAND_RESET 0x02
|
||||||
|
#define USB251XB_STATUS_COMMAND_ATTACH 0x01
|
||||||
|
|
||||||
|
#define USB251XB_I2C_REG_SZ 0x100
|
||||||
|
#define USB251XB_I2C_WRITE_SZ 0x10
|
||||||
|
|
||||||
|
#define DRIVER_NAME "usb251xb"
|
||||||
|
#define DRIVER_DESC "Microchip USB 2.0 Hi-Speed Hub Controller"
|
||||||
|
|
||||||
|
struct usb251xb {
|
||||||
|
struct device *dev;
|
||||||
|
struct i2c_client *i2c;
|
||||||
|
struct udevice *vdd;
|
||||||
|
u8 skip_config;
|
||||||
|
struct gpio_desc gpio_reset;
|
||||||
|
u32 vendor_id;
|
||||||
|
u32 product_id;
|
||||||
|
u32 device_id;
|
||||||
|
u8 conf_data1;
|
||||||
|
u8 conf_data2;
|
||||||
|
u8 conf_data3;
|
||||||
|
u8 non_rem_dev;
|
||||||
|
u8 port_disable_sp;
|
||||||
|
u8 port_disable_bp;
|
||||||
|
u8 max_power_sp;
|
||||||
|
u8 max_power_bp;
|
||||||
|
u8 max_current_sp;
|
||||||
|
u8 max_current_bp;
|
||||||
|
u8 power_on_time;
|
||||||
|
u32 lang_id;
|
||||||
|
u8 manufacturer_len;
|
||||||
|
u8 product_len;
|
||||||
|
u8 serial_len;
|
||||||
|
s16 manufacturer[USB251XB_STRING_BUFSIZE];
|
||||||
|
s16 product[USB251XB_STRING_BUFSIZE];
|
||||||
|
s16 serial[USB251XB_STRING_BUFSIZE];
|
||||||
|
u8 bat_charge_en;
|
||||||
|
u32 boost_up;
|
||||||
|
u8 boost_57;
|
||||||
|
u8 boost_14;
|
||||||
|
u8 port_swap;
|
||||||
|
u8 port_map12;
|
||||||
|
u8 port_map34;
|
||||||
|
u8 port_map56;
|
||||||
|
u8 port_map7;
|
||||||
|
u8 status;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct usb251xb_data {
|
||||||
|
u16 product_id;
|
||||||
|
u8 port_cnt;
|
||||||
|
bool led_support;
|
||||||
|
bool bat_support;
|
||||||
|
char product_str[USB251XB_STRING_BUFSIZE / 2]; /* ASCII string */
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2422_data = {
|
||||||
|
.product_id = 0x2422,
|
||||||
|
.port_cnt = 2,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2422",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2512b_data = {
|
||||||
|
.product_id = 0x2512,
|
||||||
|
.port_cnt = 2,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2512B",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2512bi_data = {
|
||||||
|
.product_id = 0x2512,
|
||||||
|
.port_cnt = 2,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2512Bi",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2513b_data = {
|
||||||
|
.product_id = 0x2513,
|
||||||
|
.port_cnt = 3,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2513B",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2513bi_data = {
|
||||||
|
.product_id = 0x2513,
|
||||||
|
.port_cnt = 3,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2513Bi",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2514b_data = {
|
||||||
|
.product_id = 0x2514,
|
||||||
|
.port_cnt = 4,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2514B",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2514bi_data = {
|
||||||
|
.product_id = 0x2514,
|
||||||
|
.port_cnt = 4,
|
||||||
|
.led_support = false,
|
||||||
|
.bat_support = true,
|
||||||
|
.product_str = "USB2514Bi",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2517_data = {
|
||||||
|
.product_id = 0x2517,
|
||||||
|
.port_cnt = 7,
|
||||||
|
.led_support = true,
|
||||||
|
.bat_support = false,
|
||||||
|
.product_str = "USB2517",
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb251xb_data usb2517i_data = {
|
||||||
|
.product_id = 0x2517,
|
||||||
|
.port_cnt = 7,
|
||||||
|
.led_support = true,
|
||||||
|
.bat_support = false,
|
||||||
|
.product_str = "USB2517i",
|
||||||
|
};
|
||||||
|
|
||||||
|
static void usb251xb_reset(struct usb251xb *hub)
|
||||||
|
{
|
||||||
|
dm_gpio_set_value(&hub->gpio_reset, 1);
|
||||||
|
udelay(10); /* >=1us RESET_N asserted */
|
||||||
|
dm_gpio_set_value(&hub->gpio_reset, 0);
|
||||||
|
|
||||||
|
/* wait for hub recovery/stabilization */
|
||||||
|
udelay(750); /* >=500us after RESET_N deasserted */
|
||||||
|
}
|
||||||
|
|
||||||
|
static int usb251xb_connect(struct udevice *dev)
|
||||||
|
{
|
||||||
|
struct usb251xb *hub = dev_get_priv(dev);
|
||||||
|
char i2c_wb[USB251XB_I2C_REG_SZ];
|
||||||
|
int err, i;
|
||||||
|
|
||||||
|
memset(i2c_wb, 0, USB251XB_I2C_REG_SZ);
|
||||||
|
|
||||||
|
if (hub->skip_config) {
|
||||||
|
dev_info(dev, "Skip hub configuration, only attach.\n");
|
||||||
|
i2c_wb[0] = 0x01;
|
||||||
|
i2c_wb[1] = USB251XB_STATUS_COMMAND_ATTACH;
|
||||||
|
|
||||||
|
usb251xb_reset(hub);
|
||||||
|
|
||||||
|
err = dm_i2c_write(dev, USB251XB_ADDR_STATUS_COMMAND, i2c_wb, 2);
|
||||||
|
if (err) {
|
||||||
|
dev_err(dev, "attaching hub failed: %d\n", err);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
i2c_wb[USB251XB_ADDR_VENDOR_ID_MSB] = (hub->vendor_id >> 8) & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_VENDOR_ID_LSB] = hub->vendor_id & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_PRODUCT_ID_MSB] = (hub->product_id >> 8) & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_PRODUCT_ID_LSB] = hub->product_id & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_DEVICE_ID_MSB] = (hub->device_id >> 8) & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_DEVICE_ID_LSB] = hub->device_id & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_CONFIG_DATA_1] = hub->conf_data1;
|
||||||
|
i2c_wb[USB251XB_ADDR_CONFIG_DATA_2] = hub->conf_data2;
|
||||||
|
i2c_wb[USB251XB_ADDR_CONFIG_DATA_3] = hub->conf_data3;
|
||||||
|
i2c_wb[USB251XB_ADDR_NON_REMOVABLE_DEVICES] = hub->non_rem_dev;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_DISABLE_SELF] = hub->port_disable_sp;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_DISABLE_BUS] = hub->port_disable_bp;
|
||||||
|
i2c_wb[USB251XB_ADDR_MAX_POWER_SELF] = hub->max_power_sp;
|
||||||
|
i2c_wb[USB251XB_ADDR_MAX_POWER_BUS] = hub->max_power_bp;
|
||||||
|
i2c_wb[USB251XB_ADDR_MAX_CURRENT_SELF] = hub->max_current_sp;
|
||||||
|
i2c_wb[USB251XB_ADDR_MAX_CURRENT_BUS] = hub->max_current_bp;
|
||||||
|
i2c_wb[USB251XB_ADDR_POWER_ON_TIME] = hub->power_on_time;
|
||||||
|
i2c_wb[USB251XB_ADDR_LANGUAGE_ID_HIGH] = (hub->lang_id >> 8) & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_LANGUAGE_ID_LOW] = hub->lang_id & 0xFF;
|
||||||
|
i2c_wb[USB251XB_ADDR_MANUFACTURER_STRING_LEN] = hub->manufacturer_len;
|
||||||
|
i2c_wb[USB251XB_ADDR_PRODUCT_STRING_LEN] = hub->product_len;
|
||||||
|
i2c_wb[USB251XB_ADDR_SERIAL_STRING_LEN] = hub->serial_len;
|
||||||
|
memcpy(&i2c_wb[USB251XB_ADDR_MANUFACTURER_STRING], hub->manufacturer,
|
||||||
|
USB251XB_STRING_BUFSIZE);
|
||||||
|
memcpy(&i2c_wb[USB251XB_ADDR_SERIAL_STRING], hub->serial,
|
||||||
|
USB251XB_STRING_BUFSIZE);
|
||||||
|
memcpy(&i2c_wb[USB251XB_ADDR_PRODUCT_STRING], hub->product,
|
||||||
|
USB251XB_STRING_BUFSIZE);
|
||||||
|
i2c_wb[USB251XB_ADDR_BATTERY_CHARGING_ENABLE] = hub->bat_charge_en;
|
||||||
|
i2c_wb[USB251XB_ADDR_BOOST_UP] = hub->boost_up;
|
||||||
|
i2c_wb[USB251XB_ADDR_BOOST_57] = hub->boost_57;
|
||||||
|
i2c_wb[USB251XB_ADDR_BOOST_14] = hub->boost_14;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_SWAP] = hub->port_swap;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_MAP_12] = hub->port_map12;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_MAP_34] = hub->port_map34;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_MAP_56] = hub->port_map56;
|
||||||
|
i2c_wb[USB251XB_ADDR_PORT_MAP_7] = hub->port_map7;
|
||||||
|
i2c_wb[USB251XB_ADDR_STATUS_COMMAND] = USB251XB_STATUS_COMMAND_ATTACH;
|
||||||
|
|
||||||
|
usb251xb_reset(hub);
|
||||||
|
|
||||||
|
/* write registers */
|
||||||
|
for (i = 0; i < (USB251XB_I2C_REG_SZ / USB251XB_I2C_WRITE_SZ); i++) {
|
||||||
|
int offset = i * USB251XB_I2C_WRITE_SZ;
|
||||||
|
char wbuf[USB251XB_I2C_WRITE_SZ + 1];
|
||||||
|
|
||||||
|
/* The first data byte transferred tells the hub how many data
|
||||||
|
* bytes will follow (byte count).
|
||||||
|
*/
|
||||||
|
wbuf[0] = USB251XB_I2C_WRITE_SZ;
|
||||||
|
memcpy(&wbuf[1], &i2c_wb[offset], USB251XB_I2C_WRITE_SZ);
|
||||||
|
|
||||||
|
dev_dbg(dev, "writing %d byte block %d to 0x%02X\n",
|
||||||
|
USB251XB_I2C_WRITE_SZ, i, offset);
|
||||||
|
|
||||||
|
err = dm_i2c_write(dev, offset, wbuf, USB251XB_I2C_WRITE_SZ + 1);
|
||||||
|
if (err)
|
||||||
|
goto out_err;
|
||||||
|
}
|
||||||
|
|
||||||
|
dev_info(dev, "Hub configuration was successful.\n");
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
out_err:
|
||||||
|
dev_err(dev, "configuring block %d failed: %d\n", i, err);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int usb251xb_probe(struct udevice *dev)
|
||||||
|
{
|
||||||
|
struct usb251xb *hub = dev_get_priv(dev);
|
||||||
|
int err;
|
||||||
|
|
||||||
|
if (IS_ENABLED(CONFIG_DM_REGULATOR) && hub->vdd) {
|
||||||
|
err = regulator_set_enable(hub->vdd, true);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = usb251xb_connect(dev);
|
||||||
|
if (err) {
|
||||||
|
dev_err(dev, "Failed to connect hub (%d)\n", err);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
dev_info(dev, "Hub probed successfully\n");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void usb251xb_get_ports_field(struct udevice *dev,
|
||||||
|
const char *prop_name, u8 port_cnt,
|
||||||
|
bool ds_only, u8 *fld)
|
||||||
|
{
|
||||||
|
u32 i, port;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
for (i = 0; i < port_cnt; i++) {
|
||||||
|
ret = dev_read_u32_index(dev, prop_name, i, &port);
|
||||||
|
if (ret)
|
||||||
|
continue;
|
||||||
|
if (port >= ds_only ? 1 : 0 && port <= port_cnt)
|
||||||
|
*fld |= BIT(port);
|
||||||
|
else
|
||||||
|
dev_warn(dev, "port %u doesn't exist\n", port);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int usb251xb_of_to_plat(struct udevice *dev)
|
||||||
|
{
|
||||||
|
struct usb251xb_data *data =
|
||||||
|
(struct usb251xb_data *)dev_get_driver_data(dev);
|
||||||
|
struct usb251xb *hub = dev_get_priv(dev);
|
||||||
|
char str[USB251XB_STRING_BUFSIZE / 2];
|
||||||
|
const char *cproperty_char;
|
||||||
|
u32 property_u32 = 0;
|
||||||
|
int len, err;
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "skip-config"))
|
||||||
|
hub->skip_config = 1;
|
||||||
|
else
|
||||||
|
hub->skip_config = 0;
|
||||||
|
|
||||||
|
err = gpio_request_by_name(dev, "reset-gpios", 0, &hub->gpio_reset,
|
||||||
|
GPIOD_IS_OUT | GPIOD_IS_OUT_ACTIVE);
|
||||||
|
if (err && err != -ENOENT) {
|
||||||
|
dev_err(dev, "unable to request GPIO reset pin (%d)\n", err);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IS_ENABLED(CONFIG_DM_REGULATOR)) {
|
||||||
|
err = device_get_supply_regulator(dev, "vdd-supply",
|
||||||
|
&hub->vdd);
|
||||||
|
if (err && err != -ENOENT) {
|
||||||
|
dev_err(dev, "Warning: cannot get power supply\n");
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev_read_u32(dev, "vendor-id", &hub->vendor_id))
|
||||||
|
hub->vendor_id = USB251XB_DEF_VENDOR_ID;
|
||||||
|
|
||||||
|
if (dev_read_u32(dev, "product-id", &hub->product_id))
|
||||||
|
hub->product_id = data->product_id;
|
||||||
|
|
||||||
|
if (dev_read_u32(dev, "device-id", &hub->device_id))
|
||||||
|
hub->device_id = USB251XB_DEF_DEVICE_ID;
|
||||||
|
|
||||||
|
hub->conf_data1 = USB251XB_DEF_CONFIG_DATA_1;
|
||||||
|
if (dev_read_bool(dev, "self-powered")) {
|
||||||
|
hub->conf_data1 |= BIT(7);
|
||||||
|
|
||||||
|
/* Configure Over-Current sens when self-powered */
|
||||||
|
hub->conf_data1 &= ~BIT(2);
|
||||||
|
if (dev_read_bool(dev, "ganged-sensing"))
|
||||||
|
hub->conf_data1 &= ~BIT(1);
|
||||||
|
else if (dev_read_bool(dev, "individual-sensing"))
|
||||||
|
hub->conf_data1 |= BIT(1);
|
||||||
|
} else if (dev_read_bool(dev, "bus-powered")) {
|
||||||
|
hub->conf_data1 &= ~BIT(7);
|
||||||
|
|
||||||
|
/* Disable Over-Current sense when bus-powered */
|
||||||
|
hub->conf_data1 |= BIT(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "disable-hi-speed"))
|
||||||
|
hub->conf_data1 |= BIT(5);
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "multi-tt"))
|
||||||
|
hub->conf_data1 |= BIT(4);
|
||||||
|
else if (dev_read_bool(dev, "single-tt"))
|
||||||
|
hub->conf_data1 &= ~BIT(4);
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "disable-eop"))
|
||||||
|
hub->conf_data1 |= BIT(3);
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "individual-port-switching"))
|
||||||
|
hub->conf_data1 |= BIT(0);
|
||||||
|
else if (dev_read_bool(dev, "ganged-port-switching"))
|
||||||
|
hub->conf_data1 &= ~BIT(0);
|
||||||
|
|
||||||
|
hub->conf_data2 = USB251XB_DEF_CONFIG_DATA_2;
|
||||||
|
if (dev_read_bool(dev, "dynamic-power-switching"))
|
||||||
|
hub->conf_data2 |= BIT(7);
|
||||||
|
|
||||||
|
if (!dev_read_u32(dev, "oc-delay-us", &property_u32)) {
|
||||||
|
if (property_u32 == 100) {
|
||||||
|
/* 100 us*/
|
||||||
|
hub->conf_data2 &= ~BIT(5);
|
||||||
|
hub->conf_data2 &= ~BIT(4);
|
||||||
|
} else if (property_u32 == 4000) {
|
||||||
|
/* 4 ms */
|
||||||
|
hub->conf_data2 &= ~BIT(5);
|
||||||
|
hub->conf_data2 |= BIT(4);
|
||||||
|
} else if (property_u32 == 16000) {
|
||||||
|
/* 16 ms */
|
||||||
|
hub->conf_data2 |= BIT(5);
|
||||||
|
hub->conf_data2 |= BIT(4);
|
||||||
|
} else {
|
||||||
|
/* 8 ms (DEFAULT) */
|
||||||
|
hub->conf_data2 |= BIT(5);
|
||||||
|
hub->conf_data2 &= ~BIT(4);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "compound-device"))
|
||||||
|
hub->conf_data2 |= BIT(3);
|
||||||
|
|
||||||
|
hub->conf_data3 = USB251XB_DEF_CONFIG_DATA_3;
|
||||||
|
if (dev_read_bool(dev, "port-mapping-mode"))
|
||||||
|
hub->conf_data3 |= BIT(3);
|
||||||
|
|
||||||
|
if (data->led_support && dev_read_bool(dev, "led-usb-mode"))
|
||||||
|
hub->conf_data3 &= ~BIT(1);
|
||||||
|
|
||||||
|
if (dev_read_bool(dev, "string-support"))
|
||||||
|
hub->conf_data3 |= BIT(0);
|
||||||
|
|
||||||
|
hub->non_rem_dev = USB251XB_DEF_NON_REMOVABLE_DEVICES;
|
||||||
|
usb251xb_get_ports_field(dev, "non-removable-ports", data->port_cnt,
|
||||||
|
true, &hub->non_rem_dev);
|
||||||
|
|
||||||
|
hub->port_disable_sp = USB251XB_DEF_PORT_DISABLE_SELF;
|
||||||
|
usb251xb_get_ports_field(dev, "sp-disabled-ports", data->port_cnt,
|
||||||
|
true, &hub->port_disable_sp);
|
||||||
|
|
||||||
|
hub->port_disable_bp = USB251XB_DEF_PORT_DISABLE_BUS;
|
||||||
|
usb251xb_get_ports_field(dev, "bp-disabled-ports", data->port_cnt,
|
||||||
|
true, &hub->port_disable_bp);
|
||||||
|
|
||||||
|
hub->max_power_sp = USB251XB_DEF_MAX_POWER_SELF;
|
||||||
|
if (!dev_read_u32(dev, "sp-max-total-current-microamp", &property_u32))
|
||||||
|
hub->max_power_sp = min_t(u8, property_u32 / 2000, 50);
|
||||||
|
|
||||||
|
hub->max_power_bp = USB251XB_DEF_MAX_POWER_BUS;
|
||||||
|
if (!dev_read_u32(dev, "bp-max-total-current-microamp", &property_u32))
|
||||||
|
hub->max_power_bp = min_t(u8, property_u32 / 2000, 255);
|
||||||
|
|
||||||
|
hub->max_current_sp = USB251XB_DEF_MAX_CURRENT_SELF;
|
||||||
|
if (!dev_read_u32(dev, "sp-max-removable-current-microamp",
|
||||||
|
&property_u32))
|
||||||
|
hub->max_current_sp = min_t(u8, property_u32 / 2000, 50);
|
||||||
|
|
||||||
|
hub->max_current_bp = USB251XB_DEF_MAX_CURRENT_BUS;
|
||||||
|
if (!dev_read_u32(dev, "bp-max-removable-current-microamp",
|
||||||
|
&property_u32))
|
||||||
|
hub->max_current_bp = min_t(u8, property_u32 / 2000, 255);
|
||||||
|
|
||||||
|
hub->power_on_time = USB251XB_DEF_POWER_ON_TIME;
|
||||||
|
if (!dev_read_u32(dev, "power-on-time-ms", &property_u32))
|
||||||
|
hub->power_on_time = min_t(u8, property_u32 / 2, 255);
|
||||||
|
|
||||||
|
if (dev_read_u32(dev, "language-id", &hub->lang_id))
|
||||||
|
hub->lang_id = USB251XB_DEF_LANGUAGE_ID;
|
||||||
|
|
||||||
|
if (!dev_read_u32(dev, "boost-up", &hub->boost_up))
|
||||||
|
hub->boost_up = USB251XB_DEF_BOOST_UP;
|
||||||
|
|
||||||
|
cproperty_char = dev_read_string(dev, "manufacturer");
|
||||||
|
strlcpy(str, cproperty_char ? : USB251XB_DEF_MANUFACTURER_STRING,
|
||||||
|
sizeof(str));
|
||||||
|
hub->manufacturer_len = strlen(str) & 0xFF;
|
||||||
|
memset(hub->manufacturer, 0, USB251XB_STRING_BUFSIZE);
|
||||||
|
len = min_t(size_t, USB251XB_STRING_BUFSIZE / 2, strlen(str));
|
||||||
|
len = utf8_to_utf16le(str, hub->manufacturer, len);
|
||||||
|
|
||||||
|
cproperty_char = dev_read_string(dev, "product");
|
||||||
|
strlcpy(str, cproperty_char ? : data->product_str, sizeof(str));
|
||||||
|
hub->product_len = strlen(str) & 0xFF;
|
||||||
|
memset(hub->product, 0, USB251XB_STRING_BUFSIZE);
|
||||||
|
len = min_t(size_t, USB251XB_STRING_BUFSIZE / 2, strlen(str));
|
||||||
|
len = utf8_to_utf16le(str, hub->product, len);
|
||||||
|
|
||||||
|
cproperty_char = dev_read_string(dev, "serial");
|
||||||
|
strlcpy(str, cproperty_char ? : USB251XB_DEF_SERIAL_STRING,
|
||||||
|
sizeof(str));
|
||||||
|
hub->serial_len = strlen(str) & 0xFF;
|
||||||
|
memset(hub->serial, 0, USB251XB_STRING_BUFSIZE);
|
||||||
|
len = min_t(size_t, USB251XB_STRING_BUFSIZE / 2, strlen(str));
|
||||||
|
len = utf8_to_utf16le(str, hub->serial, len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The datasheet documents the register as 'Port Swap' but in real the
|
||||||
|
* register controls the USB DP/DM signal swapping for each port.
|
||||||
|
*/
|
||||||
|
hub->port_swap = USB251XB_DEF_PORT_SWAP;
|
||||||
|
usb251xb_get_ports_field(dev, "swap-dx-lanes", data->port_cnt,
|
||||||
|
false, &hub->port_swap);
|
||||||
|
|
||||||
|
/* The following parameters are currently not exposed to devicetree, but
|
||||||
|
* may be as soon as needed.
|
||||||
|
*/
|
||||||
|
hub->bat_charge_en = USB251XB_DEF_BATTERY_CHARGING_ENABLE;
|
||||||
|
hub->boost_57 = USB251XB_DEF_BOOST_57;
|
||||||
|
hub->boost_14 = USB251XB_DEF_BOOST_14;
|
||||||
|
hub->port_map12 = USB251XB_DEF_PORT_MAP_12;
|
||||||
|
hub->port_map34 = USB251XB_DEF_PORT_MAP_34;
|
||||||
|
hub->port_map56 = USB251XB_DEF_PORT_MAP_56;
|
||||||
|
hub->port_map7 = USB251XB_DEF_PORT_MAP_7;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct udevice_id usb251xb_of_match[] = {
|
||||||
|
{
|
||||||
|
.compatible = "microchip,usb2422",
|
||||||
|
.data = (ulong)&usb2422_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2512b",
|
||||||
|
.data = (ulong)&usb2512b_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2512bi",
|
||||||
|
.data = (ulong)&usb2512bi_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2513b",
|
||||||
|
.data = (ulong)&usb2513b_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2513bi",
|
||||||
|
.data = (ulong)&usb2513bi_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2514b",
|
||||||
|
.data = (ulong)&usb2514b_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2514bi",
|
||||||
|
.data = (ulong)&usb2514bi_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2517",
|
||||||
|
.data = (ulong)&usb2517_data,
|
||||||
|
}, {
|
||||||
|
.compatible = "microchip,usb2517i",
|
||||||
|
.data = (ulong)&usb2517i_data,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
U_BOOT_DRIVER(usb251xb) = {
|
||||||
|
.name = "usb251xb",
|
||||||
|
.id = UCLASS_MISC,
|
||||||
|
.of_match = usb251xb_of_match,
|
||||||
|
.of_to_plat = usb251xb_of_to_plat,
|
||||||
|
.probe = usb251xb_probe,
|
||||||
|
.priv_auto = sizeof(struct usb251xb),
|
||||||
|
};
|
@ -1060,6 +1060,30 @@ static int esdhc_getcd_common(struct fsl_esdhc_priv *priv)
|
|||||||
return timeout > 0;
|
return timeout > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int esdhc_wait_dat0_common(struct fsl_esdhc_priv *priv, int state,
|
||||||
|
int timeout_us)
|
||||||
|
{
|
||||||
|
struct fsl_esdhc *regs = priv->esdhc_regs;
|
||||||
|
int ret, err;
|
||||||
|
u32 tmp;
|
||||||
|
|
||||||
|
/* make sure the card clock keep on */
|
||||||
|
esdhc_setbits32(®s->vendorspec, VENDORSPEC_FRC_SDCLK_ON);
|
||||||
|
|
||||||
|
ret = readx_poll_timeout(esdhc_read32, ®s->prsstat, tmp,
|
||||||
|
!!(tmp & PRSSTAT_DAT0) == !!state,
|
||||||
|
timeout_us);
|
||||||
|
|
||||||
|
/* change to default setting, let host control the card clock */
|
||||||
|
esdhc_clrbits32(®s->vendorspec, VENDORSPEC_FRC_SDCLK_ON);
|
||||||
|
|
||||||
|
err = readx_poll_timeout(esdhc_read32, ®s->prsstat, tmp, tmp & PRSSTAT_SDOFF, 100);
|
||||||
|
if (err)
|
||||||
|
pr_warn("card clock not gate off as expect.\n");
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static int esdhc_reset(struct fsl_esdhc *regs)
|
static int esdhc_reset(struct fsl_esdhc *regs)
|
||||||
{
|
{
|
||||||
ulong start;
|
ulong start;
|
||||||
@ -1109,11 +1133,19 @@ static int esdhc_set_ios(struct mmc *mmc)
|
|||||||
return esdhc_set_ios_common(priv, mmc);
|
return esdhc_set_ios_common(priv, mmc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int esdhc_wait_dat0(struct mmc *mmc, int state, int timeout_us)
|
||||||
|
{
|
||||||
|
struct fsl_esdhc_priv *priv = mmc->priv;
|
||||||
|
|
||||||
|
return esdhc_wait_dat0_common(priv, state, timeout_us);
|
||||||
|
}
|
||||||
|
|
||||||
static const struct mmc_ops esdhc_ops = {
|
static const struct mmc_ops esdhc_ops = {
|
||||||
.getcd = esdhc_getcd,
|
.getcd = esdhc_getcd,
|
||||||
.init = esdhc_init,
|
.init = esdhc_init,
|
||||||
.send_cmd = esdhc_send_cmd,
|
.send_cmd = esdhc_send_cmd,
|
||||||
.set_ios = esdhc_set_ios,
|
.set_ios = esdhc_set_ios,
|
||||||
|
.wait_dat0 = esdhc_wait_dat0,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1576,25 +1608,9 @@ static int __maybe_unused fsl_esdhc_set_enhanced_strobe(struct udevice *dev)
|
|||||||
static int fsl_esdhc_wait_dat0(struct udevice *dev, int state,
|
static int fsl_esdhc_wait_dat0(struct udevice *dev, int state,
|
||||||
int timeout_us)
|
int timeout_us)
|
||||||
{
|
{
|
||||||
int ret, err;
|
|
||||||
u32 tmp;
|
|
||||||
struct fsl_esdhc_priv *priv = dev_get_priv(dev);
|
struct fsl_esdhc_priv *priv = dev_get_priv(dev);
|
||||||
struct fsl_esdhc *regs = priv->esdhc_regs;
|
|
||||||
|
|
||||||
/* make sure the card clock keep on */
|
return esdhc_wait_dat0_common(priv, state, timeout_us);
|
||||||
esdhc_setbits32(®s->vendorspec, VENDORSPEC_FRC_SDCLK_ON);
|
|
||||||
|
|
||||||
ret = readx_poll_timeout(esdhc_read32, ®s->prsstat, tmp,
|
|
||||||
!!(tmp & PRSSTAT_DAT0) == !!state,
|
|
||||||
timeout_us);
|
|
||||||
|
|
||||||
/* change to default setting, let host control the card clock */
|
|
||||||
esdhc_clrbits32(®s->vendorspec, VENDORSPEC_FRC_SDCLK_ON);
|
|
||||||
err = readx_poll_timeout(esdhc_read32, ®s->prsstat, tmp, tmp & PRSSTAT_SDOFF, 100);
|
|
||||||
if (err)
|
|
||||||
dev_warn(dev, "card clock not gate off as expect.\n");
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct dm_mmc_ops fsl_esdhc_ops = {
|
static const struct dm_mmc_ops fsl_esdhc_ops = {
|
||||||
|
@ -34,6 +34,9 @@ static int mmc_set_signal_voltage(struct mmc *mmc, uint signal_voltage);
|
|||||||
|
|
||||||
static int mmc_wait_dat0(struct mmc *mmc, int state, int timeout_us)
|
static int mmc_wait_dat0(struct mmc *mmc, int state, int timeout_us)
|
||||||
{
|
{
|
||||||
|
if (mmc->cfg->ops->wait_dat0)
|
||||||
|
return mmc->cfg->ops->wait_dat0(mmc, state, timeout_us);
|
||||||
|
|
||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,7 +102,7 @@ ulong mmc_berase(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt)
|
|||||||
"The erase range would be change to "
|
"The erase range would be change to "
|
||||||
"0x" LBAF "~0x" LBAF "\n\n",
|
"0x" LBAF "~0x" LBAF "\n\n",
|
||||||
mmc->erase_grp_size, start & ~(mmc->erase_grp_size - 1),
|
mmc->erase_grp_size, start & ~(mmc->erase_grp_size - 1),
|
||||||
((start + blkcnt + mmc->erase_grp_size)
|
((start + blkcnt + mmc->erase_grp_size - 1)
|
||||||
& ~(mmc->erase_grp_size - 1)) - 1);
|
& ~(mmc->erase_grp_size - 1)) - 1);
|
||||||
|
|
||||||
while (blk < blkcnt) {
|
while (blk < blkcnt) {
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
*
|
*
|
||||||
* Copyright 2019 Analog Devices Inc.
|
* Copyright 2019 Analog Devices Inc.
|
||||||
* Copyright 2022 Variscite Ltd.
|
* Copyright 2022 Variscite Ltd.
|
||||||
|
* Copyright 2022 Josua Mayer <josua@solid-run.com>
|
||||||
*/
|
*/
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <phy.h>
|
#include <phy.h>
|
||||||
@ -13,6 +14,16 @@
|
|||||||
#define PHY_ID_ADIN1300 0x0283bc30
|
#define PHY_ID_ADIN1300 0x0283bc30
|
||||||
#define ADIN1300_EXT_REG_PTR 0x10
|
#define ADIN1300_EXT_REG_PTR 0x10
|
||||||
#define ADIN1300_EXT_REG_DATA 0x11
|
#define ADIN1300_EXT_REG_DATA 0x11
|
||||||
|
|
||||||
|
#define ADIN1300_GE_CLK_CFG_REG 0xff1f
|
||||||
|
#define ADIN1300_GE_CLK_CFG_MASK GENMASK(5, 0)
|
||||||
|
#define ADIN1300_GE_CLK_CFG_RCVR_125 BIT(5)
|
||||||
|
#define ADIN1300_GE_CLK_CFG_FREE_125 BIT(4)
|
||||||
|
#define ADIN1300_GE_CLK_CFG_REF_EN BIT(3)
|
||||||
|
#define ADIN1300_GE_CLK_CFG_HRT_RCVR BIT(2)
|
||||||
|
#define ADIN1300_GE_CLK_CFG_HRT_FREE BIT(1)
|
||||||
|
#define ADIN1300_GE_CLK_CFG_25 BIT(0)
|
||||||
|
|
||||||
#define ADIN1300_GE_RGMII_CFG 0xff23
|
#define ADIN1300_GE_RGMII_CFG 0xff23
|
||||||
#define ADIN1300_GE_RGMII_RX_MSK GENMASK(8, 6)
|
#define ADIN1300_GE_RGMII_RX_MSK GENMASK(8, 6)
|
||||||
#define ADIN1300_GE_RGMII_RX_SEL(x) \
|
#define ADIN1300_GE_RGMII_RX_SEL(x) \
|
||||||
@ -100,27 +111,27 @@ static u32 adin_get_reg_value(struct phy_device *phydev,
|
|||||||
* The function gets phy-mode string from property 'adi,phy-mode-override'
|
* The function gets phy-mode string from property 'adi,phy-mode-override'
|
||||||
* and return its index in phy_interface_strings table, or -1 in error case.
|
* and return its index in phy_interface_strings table, or -1 in error case.
|
||||||
*/
|
*/
|
||||||
int adin_get_phy_mode_override(struct phy_device *phydev)
|
phy_interface_t adin_get_phy_mode_override(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
ofnode node = phy_get_ofnode(phydev);
|
ofnode node = phy_get_ofnode(phydev);
|
||||||
const char *phy_mode_override;
|
const char *phy_mode_override;
|
||||||
const char *prop_phy_mode_override = "adi,phy-mode-override";
|
const char *prop_phy_mode_override = "adi,phy-mode-override";
|
||||||
int override_interface;
|
int i;
|
||||||
|
|
||||||
phy_mode_override = ofnode_read_string(node, prop_phy_mode_override);
|
phy_mode_override = ofnode_read_string(node, prop_phy_mode_override);
|
||||||
if (!phy_mode_override)
|
if (!phy_mode_override)
|
||||||
return -ENODEV;
|
return PHY_INTERFACE_MODE_NA;
|
||||||
|
|
||||||
debug("%s: %s = '%s'\n",
|
debug("%s: %s = '%s'\n",
|
||||||
__func__, prop_phy_mode_override, phy_mode_override);
|
__func__, prop_phy_mode_override, phy_mode_override);
|
||||||
|
|
||||||
override_interface = phy_get_interface_by_name(phy_mode_override);
|
for (i = 0; i < PHY_INTERFACE_MODE_MAX; i++)
|
||||||
|
if (!strcmp(phy_mode_override, phy_interface_strings[i]))
|
||||||
|
return (phy_interface_t) i;
|
||||||
|
|
||||||
if (override_interface < 0)
|
printf("%s: Invalid PHY interface '%s'\n", __func__, phy_mode_override);
|
||||||
printf("%s: %s = '%s' is not valid\n",
|
|
||||||
__func__, prop_phy_mode_override, phy_mode_override);
|
|
||||||
|
|
||||||
return override_interface;
|
return PHY_INTERFACE_MODE_NA;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u16 adin_ext_read(struct phy_device *phydev, const u32 regnum)
|
static u16 adin_ext_read(struct phy_device *phydev, const u32 regnum)
|
||||||
@ -144,14 +155,41 @@ static int adin_ext_write(struct phy_device *phydev, const u32 regnum, const u16
|
|||||||
return phy_write(phydev, MDIO_DEVAD_NONE, ADIN1300_EXT_REG_DATA, val);
|
return phy_write(phydev, MDIO_DEVAD_NONE, ADIN1300_EXT_REG_DATA, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int adin_config_clk_out(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
ofnode node = phy_get_ofnode(phydev);
|
||||||
|
const char *val = NULL;
|
||||||
|
u8 sel = 0;
|
||||||
|
|
||||||
|
val = ofnode_read_string(node, "adi,phy-output-clock");
|
||||||
|
if (!val) {
|
||||||
|
/* property not present, do not enable GP_CLK pin */
|
||||||
|
} else if (strcmp(val, "25mhz-reference") == 0) {
|
||||||
|
sel |= ADIN1300_GE_CLK_CFG_25;
|
||||||
|
} else if (strcmp(val, "125mhz-free-running") == 0) {
|
||||||
|
sel |= ADIN1300_GE_CLK_CFG_FREE_125;
|
||||||
|
} else if (strcmp(val, "adaptive-free-running") == 0) {
|
||||||
|
sel |= ADIN1300_GE_CLK_CFG_HRT_FREE;
|
||||||
|
} else {
|
||||||
|
pr_err("%s: invalid adi,phy-output-clock\n", __func__);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ofnode_read_bool(node, "adi,phy-output-reference-clock"))
|
||||||
|
sel |= ADIN1300_GE_CLK_CFG_REF_EN;
|
||||||
|
|
||||||
|
return adin_ext_write(phydev, ADIN1300_GE_CLK_CFG_REG,
|
||||||
|
ADIN1300_GE_CLK_CFG_MASK & sel);
|
||||||
|
}
|
||||||
|
|
||||||
static int adin_config_rgmii_mode(struct phy_device *phydev)
|
static int adin_config_rgmii_mode(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
u16 reg_val;
|
u16 reg_val;
|
||||||
u32 val;
|
u32 val;
|
||||||
int phy_mode_override = adin_get_phy_mode_override(phydev);
|
phy_interface_t phy_mode_override = adin_get_phy_mode_override(phydev);
|
||||||
|
|
||||||
if (phy_mode_override >= 0) {
|
if (phy_mode_override != PHY_INTERFACE_MODE_NA) {
|
||||||
phydev->interface = (phy_interface_t) phy_mode_override;
|
phydev->interface = phy_mode_override;
|
||||||
}
|
}
|
||||||
|
|
||||||
reg_val = adin_ext_read(phydev, ADIN1300_GE_RGMII_CFG);
|
reg_val = adin_ext_read(phydev, ADIN1300_GE_RGMII_CFG);
|
||||||
@ -202,6 +240,10 @@ static int adin1300_config(struct phy_device *phydev)
|
|||||||
|
|
||||||
printf("ADIN1300 PHY detected at addr %d\n", phydev->addr);
|
printf("ADIN1300 PHY detected at addr %d\n", phydev->addr);
|
||||||
|
|
||||||
|
ret = adin_config_clk_out(phydev);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
ret = adin_config_rgmii_mode(phydev);
|
ret = adin_config_rgmii_mode(phydev);
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
|
@ -455,7 +455,7 @@ static int tegra_pcie_parse_port_info(ofnode node, uint *index, uint *lanes)
|
|||||||
|
|
||||||
err = ofnode_read_u32_default(node, "nvidia,num-lanes", -1);
|
err = ofnode_read_u32_default(node, "nvidia,num-lanes", -1);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
pr_err("failed to parse \"nvidia,num-lanes\" property");
|
pr_err("failed to parse \"nvidia,num-lanes\" property\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -463,7 +463,7 @@ static int tegra_pcie_parse_port_info(ofnode node, uint *index, uint *lanes)
|
|||||||
|
|
||||||
err = ofnode_read_pci_addr(node, 0, "reg", &addr);
|
err = ofnode_read_pci_addr(node, 0, "reg", &addr);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
pr_err("failed to parse \"reg\" property");
|
pr_err("failed to parse \"reg\" property\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -158,13 +158,15 @@ config SPL_DM_PMIC_MP5416
|
|||||||
|
|
||||||
config DM_PMIC_PCA9450
|
config DM_PMIC_PCA9450
|
||||||
bool "Enable Driver Model for PMIC PCA9450"
|
bool "Enable Driver Model for PMIC PCA9450"
|
||||||
|
depends on DM_I2C
|
||||||
help
|
help
|
||||||
This config enables implementation of driver-model pmic uclass features
|
This config enables implementation of driver-model pmic uclass features
|
||||||
for PMIC PCA9450. The driver implements read/write operations.
|
for PMIC PCA9450. The driver implements read/write operations.
|
||||||
|
|
||||||
config SPL_DM_PMIC_PCA9450
|
config SPL_DM_PMIC_PCA9450
|
||||||
bool "Enable Driver Model for PMIC PCA9450"
|
bool "Enable Driver Model for PMIC PCA9450 in SPL"
|
||||||
depends on SPL_DM_PMIC
|
depends on SPL_DM_PMIC
|
||||||
|
depends on SPL_DM_I2C
|
||||||
help
|
help
|
||||||
This config enables implementation of driver-model pmic uclass features
|
This config enables implementation of driver-model pmic uclass features
|
||||||
for PMIC PCA9450 in SPL. The driver implements read/write operations.
|
for PMIC PCA9450 in SPL. The driver implements read/write operations.
|
||||||
|
@ -866,9 +866,6 @@ static int nxp_fspi_default_setup(struct nxp_fspi *f)
|
|||||||
u32 reg;
|
u32 reg;
|
||||||
|
|
||||||
#if CONFIG_IS_ENABLED(CLK)
|
#if CONFIG_IS_ENABLED(CLK)
|
||||||
/* disable and unprepare clock to avoid glitch pass to controller */
|
|
||||||
nxp_fspi_clk_disable_unprep(f);
|
|
||||||
|
|
||||||
/* the default frequency, we will change it later if necessary. */
|
/* the default frequency, we will change it later if necessary. */
|
||||||
ret = clk_set_rate(&f->clk, 20000000);
|
ret = clk_set_rate(&f->clk, 20000000);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
|
@ -69,7 +69,7 @@ static int ehci_usb_probe(struct udevice *dev)
|
|||||||
|
|
||||||
err = 0;
|
err = 0;
|
||||||
ret = clk_get_bulk(dev, &priv->clocks);
|
ret = clk_get_bulk(dev, &priv->clocks);
|
||||||
if (ret) {
|
if (ret && ret != -ENOENT) {
|
||||||
dev_err(dev, "Failed to get clocks (ret=%d)\n", ret);
|
dev_err(dev, "Failed to get clocks (ret=%d)\n", ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -81,7 +81,7 @@ static int ehci_usb_probe(struct udevice *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
err = reset_get_bulk(dev, &priv->resets);
|
err = reset_get_bulk(dev, &priv->resets);
|
||||||
if (err) {
|
if (ret && ret != -ENOENT) {
|
||||||
dev_err(dev, "Failed to get resets (err=%d)\n", err);
|
dev_err(dev, "Failed to get resets (err=%d)\n", err);
|
||||||
goto clk_err;
|
goto clk_err;
|
||||||
}
|
}
|
||||||
|
@ -122,11 +122,13 @@ static int xhci_mtk_host_disable(struct mtk_xhci *mtk)
|
|||||||
|
|
||||||
/* power down all u3 ports */
|
/* power down all u3 ports */
|
||||||
for (i = 0; i < mtk->num_u3ports; i++)
|
for (i = 0; i < mtk->num_u3ports; i++)
|
||||||
setbits_le32(mtk->ippc + IPPC_U3_CTRL(i), CTRL_U3_PORT_PDN);
|
setbits_le32(mtk->ippc + IPPC_U3_CTRL(i),
|
||||||
|
CTRL_U3_PORT_PDN | CTRL_U3_PORT_DIS);
|
||||||
|
|
||||||
/* power down all u2 ports */
|
/* power down all u2 ports */
|
||||||
for (i = 0; i < mtk->num_u2ports; i++)
|
for (i = 0; i < mtk->num_u2ports; i++)
|
||||||
setbits_le32(mtk->ippc + IPPC_U2_CTRL(i), CTRL_U2_PORT_PDN);
|
setbits_le32(mtk->ippc + IPPC_U2_CTRL(i),
|
||||||
|
CTRL_U2_PORT_PDN | CTRL_U2_PORT_DIS);
|
||||||
|
|
||||||
/* power down host ip */
|
/* power down host ip */
|
||||||
setbits_le32(mtk->ippc + IPPC_IP_PW_CTRL1, CTRL1_IP_HOST_PDN);
|
setbits_le32(mtk->ippc + IPPC_IP_PW_CTRL1, CTRL1_IP_HOST_PDN);
|
||||||
|
@ -1609,6 +1609,7 @@ static int dp_tegra_probe(struct udevice *dev)
|
|||||||
|
|
||||||
static const struct udevice_id tegra_dp_ids[] = {
|
static const struct udevice_id tegra_dp_ids[] = {
|
||||||
{ .compatible = "nvidia,tegra124-dpaux" },
|
{ .compatible = "nvidia,tegra124-dpaux" },
|
||||||
|
{ .compatible = "nvidia,tegra210-dpaux" },
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
10
env/mmc.c
vendored
10
env/mmc.c
vendored
@ -257,12 +257,15 @@ static inline int erase_env(struct mmc *mmc, unsigned long size,
|
|||||||
{
|
{
|
||||||
uint blk_start, blk_cnt, n;
|
uint blk_start, blk_cnt, n;
|
||||||
struct blk_desc *desc = mmc_get_blk_desc(mmc);
|
struct blk_desc *desc = mmc_get_blk_desc(mmc);
|
||||||
|
u32 erase_size;
|
||||||
|
|
||||||
blk_start = ALIGN(offset, mmc->write_bl_len) / mmc->write_bl_len;
|
erase_size = mmc->erase_grp_size * desc->blksz;
|
||||||
blk_cnt = ALIGN(size, mmc->write_bl_len) / mmc->write_bl_len;
|
blk_start = ALIGN_DOWN(offset, erase_size) / desc->blksz;
|
||||||
|
blk_cnt = ALIGN(size, erase_size) / desc->blksz;
|
||||||
|
|
||||||
n = blk_derase(desc, blk_start, blk_cnt);
|
n = blk_derase(desc, blk_start, blk_cnt);
|
||||||
printf("%d blocks erased: %s\n", n, (n == blk_cnt) ? "OK" : "ERROR");
|
printf("%d blocks erased at 0x%x: %s\n", n, blk_start,
|
||||||
|
(n == blk_cnt) ? "OK" : "ERROR");
|
||||||
|
|
||||||
return (n == blk_cnt) ? 0 : 1;
|
return (n == blk_cnt) ? 0 : 1;
|
||||||
}
|
}
|
||||||
@ -286,6 +289,7 @@ static int env_mmc_erase(void)
|
|||||||
goto fini;
|
goto fini;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
ret = erase_env(mmc, CONFIG_ENV_SIZE, offset);
|
ret = erase_env(mmc, CONFIG_ENV_SIZE, offset);
|
||||||
|
|
||||||
#ifdef CONFIG_ENV_OFFSET_REDUND
|
#ifdef CONFIG_ENV_OFFSET_REDUND
|
||||||
|
@ -975,6 +975,7 @@ int sqfs_readdir(struct fs_dir_stream *fs_dirs, struct fs_dirent **dentp)
|
|||||||
int i_number, offset = 0, ret;
|
int i_number, offset = 0, ret;
|
||||||
struct fs_dirent *dent;
|
struct fs_dirent *dent;
|
||||||
unsigned char *ipos;
|
unsigned char *ipos;
|
||||||
|
u16 name_size;
|
||||||
|
|
||||||
dirs = (struct squashfs_dir_stream *)fs_dirs;
|
dirs = (struct squashfs_dir_stream *)fs_dirs;
|
||||||
if (!dirs->size) {
|
if (!dirs->size) {
|
||||||
@ -1057,9 +1058,10 @@ int sqfs_readdir(struct fs_dir_stream *fs_dirs, struct fs_dirent **dentp)
|
|||||||
return -SQFS_STOP_READDIR;
|
return -SQFS_STOP_READDIR;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set entry name */
|
/* Set entry name (capped at FS_DIRENT_NAME_LEN which is a U-Boot limitation) */
|
||||||
strncpy(dent->name, dirs->entry->name, dirs->entry->name_size + 1);
|
name_size = min_t(u16, dirs->entry->name_size + 1, FS_DIRENT_NAME_LEN - 1);
|
||||||
dent->name[dirs->entry->name_size + 1] = '\0';
|
strncpy(dent->name, dirs->entry->name, name_size);
|
||||||
|
dent->name[name_size] = '\0';
|
||||||
|
|
||||||
offset = dirs->entry->name_size + 1 + SQFS_ENTRY_BASE_LENGTH;
|
offset = dirs->entry->name_size + 1 + SQFS_ENTRY_BASE_LENGTH;
|
||||||
dirs->entry_count--;
|
dirs->entry_count--;
|
||||||
|
@ -84,6 +84,7 @@
|
|||||||
"rootfstype=ext4\0" \
|
"rootfstype=ext4\0" \
|
||||||
"console=console=ttySAC2,115200n8\0" \
|
"console=console=ttySAC2,115200n8\0" \
|
||||||
"fdtfile=exynos5422-odroidxu3.dtb\0" \
|
"fdtfile=exynos5422-odroidxu3.dtb\0" \
|
||||||
|
"board=odroid\0" \
|
||||||
"board_name=odroidxu3\0" \
|
"board_name=odroidxu3\0" \
|
||||||
"mmcbootdev=0\0" \
|
"mmcbootdev=0\0" \
|
||||||
"mmcrootdev=0\0" \
|
"mmcrootdev=0\0" \
|
||||||
|
@ -116,7 +116,8 @@
|
|||||||
"addargs=run addcons addmtd addmisc\0" \
|
"addargs=run addcons addmtd addmisc\0" \
|
||||||
"ubiload=" \
|
"ubiload=" \
|
||||||
"ubi part ${ubimtd} ; ubifsmount ${ubipart} ; " \
|
"ubi part ${ubimtd} ; ubifsmount ${ubipart} ; " \
|
||||||
"ubifsload ${kernel_addr_r} /boot/${bootfile}\0" \
|
"ubifsload ${kernel_addr_r} /boot/${bootfile} ; " \
|
||||||
|
"ubifsumount ; ubi detach\0" \
|
||||||
"netload=" \
|
"netload=" \
|
||||||
"tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \
|
"tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \
|
||||||
"miscargs=nohlt panic=1\0" \
|
"miscargs=nohlt panic=1\0" \
|
||||||
|
@ -50,8 +50,8 @@
|
|||||||
"fdt_board=dev\0" \
|
"fdt_board=dev\0" \
|
||||||
"initrd_addr=0x43800000\0" \
|
"initrd_addr=0x43800000\0" \
|
||||||
"initrd_high=0xffffffffffffffff\0" \
|
"initrd_high=0xffffffffffffffff\0" \
|
||||||
"setup=setenv setupargs console=${console},${baudrate} " \
|
"setup=setenv setupargs console=tty1 console=${console},${baudrate} " \
|
||||||
"console=tty1 consoleblank=0 earlycon\0" \
|
"consoleblank=0 earlycon\0" \
|
||||||
"update_uboot=askenv confirm Did you load flash.bin (y/N)?; " \
|
"update_uboot=askenv confirm Did you load flash.bin (y/N)?; " \
|
||||||
"if test \"$confirm\" = \"y\"; then " \
|
"if test \"$confirm\" = \"y\"; then " \
|
||||||
"setexpr blkcnt ${filesize} + 0x1ff && setexpr blkcnt " \
|
"setexpr blkcnt ${filesize} + 0x1ff && setexpr blkcnt " \
|
||||||
|
@ -68,7 +68,7 @@
|
|||||||
"fdt_board=dev\0" \
|
"fdt_board=dev\0" \
|
||||||
"initrd_addr=0x43800000\0" \
|
"initrd_addr=0x43800000\0" \
|
||||||
"initrd_high=0xffffffffffffffff\0" \
|
"initrd_high=0xffffffffffffffff\0" \
|
||||||
"setup=setenv setupargs console=${console},${baudrate} console=tty1 " \
|
"setup=setenv setupargs console=tty1 console=${console},${baudrate} " \
|
||||||
"consoleblank=0 earlycon\0" \
|
"consoleblank=0 earlycon\0" \
|
||||||
"update_uboot=askenv confirm Did you load flash.bin (y/N)?; " \
|
"update_uboot=askenv confirm Did you load flash.bin (y/N)?; " \
|
||||||
"if test \"$confirm\" = \"y\"; then " \
|
"if test \"$confirm\" = \"y\"; then " \
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
* file name is defined in this include.
|
* file name is defined in this include.
|
||||||
*
|
*
|
||||||
* Copyright (c) 2022, Heinrich Schuchardt <xypron.glpk@gmx.de>
|
* Copyright (c) 2022, Heinrich Schuchardt <xypron.glpk@gmx.de>
|
||||||
|
* Copyright (c) 2022, Linaro Limited
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _EFI_DEFAULT_FILENAME_H
|
#ifndef _EFI_DEFAULT_FILENAME_H
|
||||||
@ -14,32 +15,42 @@
|
|||||||
|
|
||||||
#undef BOOTEFI_NAME
|
#undef BOOTEFI_NAME
|
||||||
|
|
||||||
|
#ifdef CONFIG_SANDBOX
|
||||||
|
|
||||||
#if HOST_ARCH == HOST_ARCH_X86_64
|
#if HOST_ARCH == HOST_ARCH_X86_64
|
||||||
#define BOOTEFI_NAME "BOOTX64.EFI"
|
#define BOOTEFI_NAME "BOOTX64.EFI"
|
||||||
#endif
|
#elif HOST_ARCH == HOST_ARCH_X86
|
||||||
|
|
||||||
#if HOST_ARCH == HOST_ARCH_X86
|
|
||||||
#define BOOTEFI_NAME "BOOTIA32.EFI"
|
#define BOOTEFI_NAME "BOOTIA32.EFI"
|
||||||
#endif
|
#elif HOST_ARCH == HOST_ARCH_AARCH64
|
||||||
|
|
||||||
#if HOST_ARCH == HOST_ARCH_AARCH64
|
|
||||||
#define BOOTEFI_NAME "BOOTAA64.EFI"
|
#define BOOTEFI_NAME "BOOTAA64.EFI"
|
||||||
#endif
|
#elif HOST_ARCH == HOST_ARCH_ARM
|
||||||
|
|
||||||
#if HOST_ARCH == HOST_ARCH_ARM
|
|
||||||
#define BOOTEFI_NAME "BOOTARM.EFI"
|
#define BOOTEFI_NAME "BOOTARM.EFI"
|
||||||
#endif
|
#elif HOST_ARCH == HOST_ARCH_RISCV32
|
||||||
|
|
||||||
#if HOST_ARCH == HOST_ARCH_RISCV32
|
|
||||||
#define BOOTEFI_NAME "BOOTRISCV32.EFI"
|
#define BOOTEFI_NAME "BOOTRISCV32.EFI"
|
||||||
#endif
|
#elif HOST_ARCH == HOST_ARCH_RISCV64
|
||||||
|
|
||||||
#if HOST_ARCH == HOST_ARCH_RISCV64
|
|
||||||
#define BOOTEFI_NAME "BOOTRISCV64.EFI"
|
#define BOOTEFI_NAME "BOOTRISCV64.EFI"
|
||||||
|
#else
|
||||||
|
#error Unsupported UEFI architecture
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef BOOTEFI_NAME
|
#else
|
||||||
|
|
||||||
|
#if defined(CONFIG_ARM64)
|
||||||
|
#define BOOTEFI_NAME "BOOTAA64.EFI"
|
||||||
|
#elif defined(CONFIG_ARM)
|
||||||
|
#define BOOTEFI_NAME "BOOTARM.EFI"
|
||||||
|
#elif defined(CONFIG_X86_64)
|
||||||
|
#define BOOTEFI_NAME "BOOTX64.EFI"
|
||||||
|
#elif defined(CONFIG_X86)
|
||||||
|
#define BOOTEFI_NAME "BOOTIA32.EFI"
|
||||||
|
#elif defined(CONFIG_ARCH_RV32I)
|
||||||
|
#define BOOTEFI_NAME "BOOTRISCV32.EFI"
|
||||||
|
#elif defined(CONFIG_ARCH_RV64I)
|
||||||
|
#define BOOTEFI_NAME "BOOTRISCV64.EFI"
|
||||||
|
#else
|
||||||
#error Unsupported UEFI architecture
|
#error Unsupported UEFI architecture
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -499,6 +499,8 @@ extern struct list_head efi_register_notify_events;
|
|||||||
int efi_init_early(void);
|
int efi_init_early(void);
|
||||||
/* Initialize efi execution environment */
|
/* Initialize efi execution environment */
|
||||||
efi_status_t efi_init_obj_list(void);
|
efi_status_t efi_init_obj_list(void);
|
||||||
|
/* Set up console modes */
|
||||||
|
void efi_setup_console_size(void);
|
||||||
/* Install device tree */
|
/* Install device tree */
|
||||||
efi_status_t efi_install_fdt(void *fdt);
|
efi_status_t efi_install_fdt(void *fdt);
|
||||||
/* Run loaded UEFI image */
|
/* Run loaded UEFI image */
|
||||||
|
@ -174,6 +174,8 @@ int fs_write(const char *filename, ulong addr, loff_t offset, loff_t len,
|
|||||||
#define FS_DT_REG 8 /* regular file */
|
#define FS_DT_REG 8 /* regular file */
|
||||||
#define FS_DT_LNK 10 /* symbolic link */
|
#define FS_DT_LNK 10 /* symbolic link */
|
||||||
|
|
||||||
|
#define FS_DIRENT_NAME_LEN 256
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct fs_dirent - directory entry
|
* struct fs_dirent - directory entry
|
||||||
*
|
*
|
||||||
@ -194,7 +196,7 @@ struct fs_dirent {
|
|||||||
/** change_time: time of last modification */
|
/** change_time: time of last modification */
|
||||||
struct rtc_time change_time;
|
struct rtc_time change_time;
|
||||||
/** name: file name */
|
/** name: file name */
|
||||||
char name[256];
|
char name[FS_DIRENT_NAME_LEN];
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Note: fs_dir_stream should be treated as opaque to the user of fs layer */
|
/* Note: fs_dir_stream should be treated as opaque to the user of fs layer */
|
||||||
|
@ -561,6 +561,7 @@ struct mmc_ops {
|
|||||||
int (*getwp)(struct mmc *mmc);
|
int (*getwp)(struct mmc *mmc);
|
||||||
int (*host_power_cycle)(struct mmc *mmc);
|
int (*host_power_cycle)(struct mmc *mmc);
|
||||||
int (*get_b_max)(struct mmc *mmc, void *dst, lbaint_t blkcnt);
|
int (*get_b_max)(struct mmc *mmc, void *dst, lbaint_t blkcnt);
|
||||||
|
int (*wait_dat0)(struct mmc *mmc, int state, int timeout_us);
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline int mmc_hs400_prepare_ddr(struct mmc *mmc)
|
static inline int mmc_hs400_prepare_ddr(struct mmc *mmc)
|
||||||
|
@ -49,7 +49,13 @@ int init_func_watchdog_reset(void);
|
|||||||
*/
|
*/
|
||||||
#if defined(CONFIG_WATCHDOG)
|
#if defined(CONFIG_WATCHDOG)
|
||||||
#if defined(__ASSEMBLY__)
|
#if defined(__ASSEMBLY__)
|
||||||
#define WATCHDOG_RESET bl watchdog_reset
|
/* Don't require the watchdog to be enabled in SPL */
|
||||||
|
#if defined(CONFIG_SPL_BUILD) && \
|
||||||
|
!defined(CONFIG_SPL_WATCHDOG)
|
||||||
|
#define WATCHDOG_RESET /*XXX DO_NOT_DEL_THIS_COMMENT*/
|
||||||
|
#else
|
||||||
|
#define WATCHDOG_RESET bl watchdog_reset
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
/* Don't require the watchdog to be enabled in SPL */
|
/* Don't require the watchdog to be enabled in SPL */
|
||||||
#if defined(CONFIG_SPL_BUILD) && \
|
#if defined(CONFIG_SPL_BUILD) && \
|
||||||
|
@ -44,9 +44,8 @@ static const struct efi_runtime_services *rs;
|
|||||||
static
|
static
|
||||||
struct efi_device_path *expand_media_path(struct efi_device_path *device_path)
|
struct efi_device_path *expand_media_path(struct efi_device_path *device_path)
|
||||||
{
|
{
|
||||||
struct efi_device_path *dp, *full_path;
|
struct efi_device_path *dp, *rem, *full_path;
|
||||||
efi_handle_t handle;
|
efi_handle_t handle;
|
||||||
efi_status_t ret;
|
|
||||||
|
|
||||||
if (!device_path)
|
if (!device_path)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -57,11 +56,10 @@ struct efi_device_path *expand_media_path(struct efi_device_path *device_path)
|
|||||||
* booting from removable media.
|
* booting from removable media.
|
||||||
*/
|
*/
|
||||||
dp = device_path;
|
dp = device_path;
|
||||||
ret = EFI_CALL(efi_locate_device_path(
|
handle = efi_dp_find_obj(dp, &efi_simple_file_system_protocol_guid,
|
||||||
&efi_simple_file_system_protocol_guid,
|
&rem);
|
||||||
&dp, &handle));
|
if (handle) {
|
||||||
if (ret == EFI_SUCCESS) {
|
if (rem->type == DEVICE_PATH_TYPE_END) {
|
||||||
if (dp->type == DEVICE_PATH_TYPE_END) {
|
|
||||||
dp = efi_dp_from_file(NULL, 0,
|
dp = efi_dp_from_file(NULL, 0,
|
||||||
"/EFI/BOOT/" BOOTEFI_NAME);
|
"/EFI/BOOT/" BOOTEFI_NAME);
|
||||||
full_path = efi_dp_append(device_path, dp);
|
full_path = efi_dp_append(device_path, dp);
|
||||||
|
@ -1058,14 +1058,15 @@ static void efi_capsule_scan_done(void)
|
|||||||
*/
|
*/
|
||||||
static efi_status_t check_run_capsules(void)
|
static efi_status_t check_run_capsules(void)
|
||||||
{
|
{
|
||||||
u64 os_indications;
|
u64 os_indications = 0x0;
|
||||||
efi_uintn_t size;
|
efi_uintn_t size;
|
||||||
efi_status_t r;
|
efi_status_t r;
|
||||||
|
|
||||||
size = sizeof(os_indications);
|
size = sizeof(os_indications);
|
||||||
r = efi_get_variable_int(u"OsIndications", &efi_global_variable_guid,
|
r = efi_get_variable_int(u"OsIndications", &efi_global_variable_guid,
|
||||||
NULL, &size, &os_indications, NULL);
|
NULL, &size, &os_indications, NULL);
|
||||||
if (r != EFI_SUCCESS || size != sizeof(os_indications))
|
if (!IS_ENABLED(CONFIG_EFI_IGNORE_OSINDICATIONS) &&
|
||||||
|
(r != EFI_SUCCESS || size != sizeof(os_indications)))
|
||||||
return EFI_NOT_FOUND;
|
return EFI_NOT_FOUND;
|
||||||
|
|
||||||
if (os_indications &
|
if (os_indications &
|
||||||
@ -1084,7 +1085,7 @@ static efi_status_t check_run_capsules(void)
|
|||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
} else if (IS_ENABLED(CONFIG_EFI_IGNORE_OSINDICATIONS)) {
|
} else if (IS_ENABLED(CONFIG_EFI_IGNORE_OSINDICATIONS)) {
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
} else {
|
} else {
|
||||||
return EFI_NOT_FOUND;
|
return EFI_NOT_FOUND;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
* Copyright (c) 2016 Alexander Graf
|
* Copyright (c) 2016 Alexander Graf
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define LOG_CATEGORY LOGC_EFI
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <charset.h>
|
#include <charset.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
@ -12,6 +14,7 @@
|
|||||||
#include <dm/device.h>
|
#include <dm/device.h>
|
||||||
#include <efi_loader.h>
|
#include <efi_loader.h>
|
||||||
#include <env.h>
|
#include <env.h>
|
||||||
|
#include <log.h>
|
||||||
#include <stdio_dev.h>
|
#include <stdio_dev.h>
|
||||||
#include <video_console.h>
|
#include <video_console.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
@ -58,7 +61,12 @@ const efi_guid_t efi_guid_text_output_protocol =
|
|||||||
#define cESC '\x1b'
|
#define cESC '\x1b'
|
||||||
#define ESC "\x1b"
|
#define ESC "\x1b"
|
||||||
|
|
||||||
/* Default to mode 0 */
|
/*
|
||||||
|
* efi_con_mode - mode information of the Simple Text Output Protocol
|
||||||
|
*
|
||||||
|
* Use safe settings before efi_setup_console_size() is called.
|
||||||
|
* By default enable only the 80x25 mode which must always exist.
|
||||||
|
*/
|
||||||
static struct simple_text_output_mode efi_con_mode = {
|
static struct simple_text_output_mode efi_con_mode = {
|
||||||
.max_mode = 1,
|
.max_mode = 1,
|
||||||
.mode = 0,
|
.mode = 0,
|
||||||
@ -333,13 +341,13 @@ static int __maybe_unused query_vidconsole(int *rows, int *cols)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* query_console_size() - update the mode table.
|
* efi_setup_console_size() - update the mode table.
|
||||||
*
|
*
|
||||||
* By default the only mode available is 80x25. If the console has at least 50
|
* By default the only mode available is 80x25. If the console has at least 50
|
||||||
* lines, enable mode 80x50. If we can query the console size and it is neither
|
* lines, enable mode 80x50. If we can query the console size and it is neither
|
||||||
* 80x25 nor 80x50, set it as an additional mode.
|
* 80x25 nor 80x50, set it as an additional mode.
|
||||||
*/
|
*/
|
||||||
static void query_console_size(void)
|
void efi_setup_console_size(void)
|
||||||
{
|
{
|
||||||
int rows = 25, cols = 80;
|
int rows = 25, cols = 80;
|
||||||
int ret = -ENODEV;
|
int ret = -ENODEV;
|
||||||
@ -351,6 +359,8 @@ static void query_console_size(void)
|
|||||||
if (ret)
|
if (ret)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
log_debug("Console size %dx%d\n", rows, cols);
|
||||||
|
|
||||||
/* Test if we can have Mode 1 */
|
/* Test if we can have Mode 1 */
|
||||||
if (cols >= 80 && rows >= 50) {
|
if (cols >= 80 && rows >= 50) {
|
||||||
efi_cout_modes[1].present = 1;
|
efi_cout_modes[1].present = 1;
|
||||||
@ -371,7 +381,6 @@ static void query_console_size(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* efi_cout_query_mode() - get terminal size for a text mode
|
* efi_cout_query_mode() - get terminal size for a text mode
|
||||||
*
|
*
|
||||||
@ -1262,9 +1271,6 @@ efi_status_t efi_console_register(void)
|
|||||||
efi_status_t r;
|
efi_status_t r;
|
||||||
struct efi_device_path *dp;
|
struct efi_device_path *dp;
|
||||||
|
|
||||||
/* Set up mode information */
|
|
||||||
query_console_size();
|
|
||||||
|
|
||||||
/* Install protocols on root node */
|
/* Install protocols on root node */
|
||||||
r = EFI_CALL(efi_install_multiple_protocol_interfaces
|
r = EFI_CALL(efi_install_multiple_protocol_interfaces
|
||||||
(&efi_root,
|
(&efi_root,
|
||||||
|
@ -973,9 +973,22 @@ static void path_to_uefi(void *uefi, const char *src)
|
|||||||
*pos = 0;
|
*pos = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* If desc is NULL, this creates a path with only the file component,
|
* efi_dp_from_file() - create device path for file
|
||||||
* otherwise it creates a full path with both device and file components
|
*
|
||||||
|
* The function creates a device path from the block descriptor @desc and the
|
||||||
|
* partition number @part and appends a device path node created describing the
|
||||||
|
* file path @path.
|
||||||
|
*
|
||||||
|
* If @desc is NULL, the device path will not contain nodes describing the
|
||||||
|
* partition.
|
||||||
|
* If @path is an empty string "", the device path will not contain a node
|
||||||
|
* for the file path.
|
||||||
|
*
|
||||||
|
* @desc: block device descriptor or NULL
|
||||||
|
* @part: partition number
|
||||||
|
* @path: file path on partition or ""
|
||||||
|
* Return: device path or NULL in case of an error
|
||||||
*/
|
*/
|
||||||
struct efi_device_path *efi_dp_from_file(struct blk_desc *desc, int part,
|
struct efi_device_path *efi_dp_from_file(struct blk_desc *desc, int part,
|
||||||
const char *path)
|
const char *path)
|
||||||
@ -1002,12 +1015,14 @@ struct efi_device_path *efi_dp_from_file(struct blk_desc *desc, int part,
|
|||||||
buf = dp_part_fill(buf, desc, part);
|
buf = dp_part_fill(buf, desc, part);
|
||||||
|
|
||||||
/* add file-path: */
|
/* add file-path: */
|
||||||
fp = buf;
|
if (*path) {
|
||||||
fp->dp.type = DEVICE_PATH_TYPE_MEDIA_DEVICE;
|
fp = buf;
|
||||||
fp->dp.sub_type = DEVICE_PATH_SUB_TYPE_FILE_PATH;
|
fp->dp.type = DEVICE_PATH_TYPE_MEDIA_DEVICE;
|
||||||
fp->dp.length = (u16)fpsize;
|
fp->dp.sub_type = DEVICE_PATH_SUB_TYPE_FILE_PATH;
|
||||||
path_to_uefi(fp->str, path);
|
fp->dp.length = (u16)fpsize;
|
||||||
buf += fpsize;
|
path_to_uefi(fp->str, path);
|
||||||
|
buf += fpsize;
|
||||||
|
}
|
||||||
|
|
||||||
*((struct efi_device_path *)buf) = END;
|
*((struct efi_device_path *)buf) = END;
|
||||||
|
|
||||||
|
@ -241,18 +241,8 @@ efi_status_t efi_firmware_capsule_authenticate(const void **p_image,
|
|||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_EFI_CAPSULE_FIRMWARE_FIT
|
|
||||||
/*
|
|
||||||
* This FIRMWARE_MANAGEMENT_PROTOCOL driver provides a firmware update
|
|
||||||
* method with existing FIT image format, and handles
|
|
||||||
* - multiple regions of firmware via DFU
|
|
||||||
* but doesn't support
|
|
||||||
* - versioning of firmware image
|
|
||||||
* - package information
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* efi_firmware_fit_get_image_info - return information about the current
|
* efi_firmware_get_image_info - return information about the current
|
||||||
* firmware image
|
* firmware image
|
||||||
* @this: Protocol instance
|
* @this: Protocol instance
|
||||||
* @image_info_size: Size of @image_info
|
* @image_info_size: Size of @image_info
|
||||||
@ -270,7 +260,7 @@ efi_status_t efi_firmware_capsule_authenticate(const void **p_image,
|
|||||||
* Return status code
|
* Return status code
|
||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
efi_status_t EFIAPI efi_firmware_fit_get_image_info(
|
efi_status_t EFIAPI efi_firmware_get_image_info(
|
||||||
struct efi_firmware_management_protocol *this,
|
struct efi_firmware_management_protocol *this,
|
||||||
efi_uintn_t *image_info_size,
|
efi_uintn_t *image_info_size,
|
||||||
struct efi_firmware_image_descriptor *image_info,
|
struct efi_firmware_image_descriptor *image_info,
|
||||||
@ -303,6 +293,16 @@ efi_status_t EFIAPI efi_firmware_fit_get_image_info(
|
|||||||
return EFI_EXIT(ret);
|
return EFI_EXIT(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_EFI_CAPSULE_FIRMWARE_FIT
|
||||||
|
/*
|
||||||
|
* This FIRMWARE_MANAGEMENT_PROTOCOL driver provides a firmware update
|
||||||
|
* method with existing FIT image format, and handles
|
||||||
|
* - multiple regions of firmware via DFU
|
||||||
|
* but doesn't support
|
||||||
|
* - versioning of firmware image
|
||||||
|
* - package information
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* efi_firmware_fit_set_image - update the firmware image
|
* efi_firmware_fit_set_image - update the firmware image
|
||||||
* @this: Protocol instance
|
* @this: Protocol instance
|
||||||
@ -348,7 +348,7 @@ efi_status_t EFIAPI efi_firmware_fit_set_image(
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct efi_firmware_management_protocol efi_fmp_fit = {
|
const struct efi_firmware_management_protocol efi_fmp_fit = {
|
||||||
.get_image_info = efi_firmware_fit_get_image_info,
|
.get_image_info = efi_firmware_get_image_info,
|
||||||
.get_image = efi_firmware_get_image_unsupported,
|
.get_image = efi_firmware_get_image_unsupported,
|
||||||
.set_image = efi_firmware_fit_set_image,
|
.set_image = efi_firmware_fit_set_image,
|
||||||
.check_image = efi_firmware_check_image_unsupported,
|
.check_image = efi_firmware_check_image_unsupported,
|
||||||
@ -363,58 +363,6 @@ const struct efi_firmware_management_protocol efi_fmp_fit = {
|
|||||||
* method with raw data.
|
* method with raw data.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
|
||||||
* efi_firmware_raw_get_image_info - return information about the current
|
|
||||||
* firmware image
|
|
||||||
* @this: Protocol instance
|
|
||||||
* @image_info_size: Size of @image_info
|
|
||||||
* @image_info: Image information
|
|
||||||
* @descriptor_version: Pointer to version number
|
|
||||||
* @descriptor_count: Pointer to number of descriptors
|
|
||||||
* @descriptor_size: Pointer to descriptor size
|
|
||||||
* @package_version: Package version
|
|
||||||
* @package_version_name: Package version's name
|
|
||||||
*
|
|
||||||
* Return information bout the current firmware image in @image_info.
|
|
||||||
* @image_info will consist of a number of descriptors.
|
|
||||||
* Each descriptor will be created based on "dfu_alt_info" variable.
|
|
||||||
*
|
|
||||||
* Return status code
|
|
||||||
*/
|
|
||||||
static
|
|
||||||
efi_status_t EFIAPI efi_firmware_raw_get_image_info(
|
|
||||||
struct efi_firmware_management_protocol *this,
|
|
||||||
efi_uintn_t *image_info_size,
|
|
||||||
struct efi_firmware_image_descriptor *image_info,
|
|
||||||
u32 *descriptor_version,
|
|
||||||
u8 *descriptor_count,
|
|
||||||
efi_uintn_t *descriptor_size,
|
|
||||||
u32 *package_version,
|
|
||||||
u16 **package_version_name)
|
|
||||||
{
|
|
||||||
efi_status_t ret = EFI_SUCCESS;
|
|
||||||
|
|
||||||
EFI_ENTRY("%p %p %p %p %p %p %p %p\n", this,
|
|
||||||
image_info_size, image_info,
|
|
||||||
descriptor_version, descriptor_count, descriptor_size,
|
|
||||||
package_version, package_version_name);
|
|
||||||
|
|
||||||
if (!image_info_size)
|
|
||||||
return EFI_EXIT(EFI_INVALID_PARAMETER);
|
|
||||||
|
|
||||||
if (*image_info_size &&
|
|
||||||
(!image_info || !descriptor_version || !descriptor_count ||
|
|
||||||
!descriptor_size || !package_version || !package_version_name))
|
|
||||||
return EFI_EXIT(EFI_INVALID_PARAMETER);
|
|
||||||
|
|
||||||
ret = efi_fill_image_desc_array(image_info_size, image_info,
|
|
||||||
descriptor_version, descriptor_count,
|
|
||||||
descriptor_size, package_version,
|
|
||||||
package_version_name);
|
|
||||||
|
|
||||||
return EFI_EXIT(ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* efi_firmware_raw_set_image - update the firmware image
|
* efi_firmware_raw_set_image - update the firmware image
|
||||||
* @this: Protocol instance
|
* @this: Protocol instance
|
||||||
@ -461,7 +409,7 @@ efi_status_t EFIAPI efi_firmware_raw_set_image(
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct efi_firmware_management_protocol efi_fmp_raw = {
|
const struct efi_firmware_management_protocol efi_fmp_raw = {
|
||||||
.get_image_info = efi_firmware_raw_get_image_info,
|
.get_image_info = efi_firmware_get_image_info,
|
||||||
.get_image = efi_firmware_get_image_unsupported,
|
.get_image = efi_firmware_get_image_unsupported,
|
||||||
.set_image = efi_firmware_raw_set_image,
|
.set_image = efi_firmware_raw_set_image,
|
||||||
.check_image = efi_firmware_check_image_unsupported,
|
.check_image = efi_firmware_check_image_unsupported,
|
||||||
|
@ -243,6 +243,10 @@ efi_status_t efi_init_obj_list(void)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Set up console modes */
|
||||||
|
efi_setup_console_size();
|
||||||
|
|
||||||
|
/* Install EFI_RNG_PROTOCOL */
|
||||||
if (IS_ENABLED(CONFIG_EFI_RNG_PROTOCOL)) {
|
if (IS_ENABLED(CONFIG_EFI_RNG_PROTOCOL)) {
|
||||||
ret = efi_rng_register();
|
ret = efi_rng_register();
|
||||||
if (ret != EFI_SUCCESS)
|
if (ret != EFI_SUCCESS)
|
||||||
|
@ -158,7 +158,7 @@ config UDP_CHECKSUM
|
|||||||
default y if SANDBOX
|
default y if SANDBOX
|
||||||
help
|
help
|
||||||
Enable this to verify the checksum on UDP packets. If the checksum
|
Enable this to verify the checksum on UDP packets. If the checksum
|
||||||
is wrong then the packet is discussed and an error is shown, like
|
is wrong then the packet is discarded and an error is shown, like
|
||||||
"UDP wrong checksum 29374a23 30ff3826"
|
"UDP wrong checksum 29374a23 30ff3826"
|
||||||
|
|
||||||
config BOOTP_SERVERIP
|
config BOOTP_SERVERIP
|
||||||
|
@ -117,6 +117,7 @@ class TestEfiCapsuleFirmwareFit(object):
|
|||||||
with u_boot_console.log.section('Test Case 2-a, before reboot'):
|
with u_boot_console.log.section('Test Case 2-a, before reboot'):
|
||||||
output = u_boot_console.run_command_list([
|
output = u_boot_console.run_command_list([
|
||||||
'host bind 0 %s' % disk_img,
|
'host bind 0 %s' % disk_img,
|
||||||
|
'printenv -e PlatformLangCodes', # workaround for terminal size determination
|
||||||
'efidebug boot add -b 1 TEST host 0:1 /helloworld.efi -s ""',
|
'efidebug boot add -b 1 TEST host 0:1 /helloworld.efi -s ""',
|
||||||
'efidebug boot order 1',
|
'efidebug boot order 1',
|
||||||
'env set -e -nv -bs -rt OsIndications =0x0000000000000004',
|
'env set -e -nv -bs -rt OsIndications =0x0000000000000004',
|
||||||
|
@ -115,6 +115,7 @@ class TestEfiCapsuleFirmwareRaw:
|
|||||||
with u_boot_console.log.section('Test Case 2-a, before reboot'):
|
with u_boot_console.log.section('Test Case 2-a, before reboot'):
|
||||||
output = u_boot_console.run_command_list([
|
output = u_boot_console.run_command_list([
|
||||||
'host bind 0 %s' % disk_img,
|
'host bind 0 %s' % disk_img,
|
||||||
|
'printenv -e PlatformLangCodes', # workaround for terminal size determination
|
||||||
'efidebug boot add -b 1 TEST host 0:1 /helloworld.efi -s ""',
|
'efidebug boot add -b 1 TEST host 0:1 /helloworld.efi -s ""',
|
||||||
'efidebug boot order 1',
|
'efidebug boot order 1',
|
||||||
'env set -e OsIndications',
|
'env set -e OsIndications',
|
||||||
@ -197,6 +198,7 @@ class TestEfiCapsuleFirmwareRaw:
|
|||||||
with u_boot_console.log.section('Test Case 3-a, before reboot'):
|
with u_boot_console.log.section('Test Case 3-a, before reboot'):
|
||||||
output = u_boot_console.run_command_list([
|
output = u_boot_console.run_command_list([
|
||||||
'host bind 0 %s' % disk_img,
|
'host bind 0 %s' % disk_img,
|
||||||
|
'printenv -e PlatformLangCodes', # workaround for terminal size determination
|
||||||
'efidebug boot add -b 1 TEST host 0:1 /helloworld.efi -s ""',
|
'efidebug boot add -b 1 TEST host 0:1 /helloworld.efi -s ""',
|
||||||
'efidebug boot order 1',
|
'efidebug boot order 1',
|
||||||
'env set -e -nv -bs -rt OsIndications =0x0000000000000004',
|
'env set -e -nv -bs -rt OsIndications =0x0000000000000004',
|
||||||
|
@ -5,7 +5,7 @@ setup(name='binman',
|
|||||||
version='1.0',
|
version='1.0',
|
||||||
license='GPL-2.0+',
|
license='GPL-2.0+',
|
||||||
scripts=['binman'],
|
scripts=['binman'],
|
||||||
packages=['binman', 'binman.etype'],
|
packages=['binman', 'binman.etype', 'binman.btool'],
|
||||||
package_dir={'binman': ''},
|
package_dir={'binman': ''},
|
||||||
package_data={'binman': ['README.rst', 'entries.rst']},
|
package_data={'binman': ['README.rst', 'entries.rst']},
|
||||||
classifiers=['Environment :: Console',
|
classifiers=['Environment :: Console',
|
||||||
|
@ -151,6 +151,7 @@ class TestSrcScan(unittest.TestCase):
|
|||||||
self.assertEqual('UCLASS_I2C', drv.uclass_id)
|
self.assertEqual('UCLASS_I2C', drv.uclass_id)
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
{'nvidia,tegra114-i2c': 'TYPE_114',
|
{'nvidia,tegra114-i2c': 'TYPE_114',
|
||||||
|
'nvidia,tegra124-i2c': 'TYPE_114',
|
||||||
'nvidia,tegra20-i2c': 'TYPE_STD',
|
'nvidia,tegra20-i2c': 'TYPE_STD',
|
||||||
'nvidia,tegra20-i2c-dvc': 'TYPE_DVC'}, drv.compat)
|
'nvidia,tegra20-i2c-dvc': 'TYPE_DVC'}, drv.compat)
|
||||||
self.assertEqual('i2c_bus', drv.priv)
|
self.assertEqual('i2c_bus', drv.priv)
|
||||||
|
Loading…
Reference in New Issue
Block a user