mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-29 08:01:08 +00:00
Merge branch 'master' of git://git.denx.de/u-boot-x86
This commit is contained in:
commit
b57129dbda
10 changed files with 78 additions and 29 deletions
|
@ -24,6 +24,7 @@
|
|||
#include <dm.h>
|
||||
#include <errno.h>
|
||||
#include <malloc.h>
|
||||
#include <syscon.h>
|
||||
#include <asm/control_regs.h>
|
||||
#include <asm/coreboot_tables.h>
|
||||
#include <asm/cpu.h>
|
||||
|
@ -751,6 +752,10 @@ int cpu_init_r(void)
|
|||
uclass_first_device(UCLASS_PCH, &dev);
|
||||
uclass_first_device(UCLASS_LPC, &dev);
|
||||
|
||||
/* Set up pin control if available */
|
||||
ret = syscon_get_by_driver_data(X86_SYSCON_PINCONF, &dev);
|
||||
debug("%s, pinctrl=%p, ret=%d\n", __func__, dev, ret);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -65,6 +65,26 @@
|
|||
};
|
||||
};
|
||||
|
||||
pch_pinctrl {
|
||||
compatible = "intel,x86-pinctrl";
|
||||
reg = <0 0>;
|
||||
|
||||
/*
|
||||
* As of today, the latest version FSP (gold4) for BayTrail
|
||||
* misses the PAD configuration of the SD controller's Card
|
||||
* Detect signal. The default PAD value for the CD pin sets
|
||||
* the pin to work in GPIO mode, which causes card detect
|
||||
* status cannot be reflected by the Present State register
|
||||
* in the SD controller (bit 16 & bit 18 are always zero).
|
||||
*
|
||||
* Configure this pin to function 1 (SD controller).
|
||||
*/
|
||||
sdmmc3_cd@0 {
|
||||
pad-offset = <0x3a0>;
|
||||
mode-func = <1>;
|
||||
};
|
||||
};
|
||||
|
||||
pci {
|
||||
compatible = "pci-x86";
|
||||
#address-cells = <3>;
|
||||
|
@ -213,7 +233,7 @@
|
|||
fsp,mrc-init-mmio-size = <0x800>;
|
||||
fsp,mrc-init-spd-addr1 = <0xa0>;
|
||||
fsp,mrc-init-spd-addr2 = <0xa2>;
|
||||
fsp,emmc-boot-mode = <2>;
|
||||
fsp,emmc-boot-mode = <1>;
|
||||
fsp,enable-sdio;
|
||||
fsp,enable-sdcard;
|
||||
fsp,enable-hsuart1;
|
||||
|
|
|
@ -30,6 +30,22 @@
|
|||
|
||||
pch_pinctrl {
|
||||
compatible = "intel,x86-pinctrl";
|
||||
reg = <0 0>;
|
||||
|
||||
/*
|
||||
* As of today, the latest version FSP (gold4) for BayTrail
|
||||
* misses the PAD configuration of the SD controller's Card
|
||||
* Detect signal. The default PAD value for the CD pin sets
|
||||
* the pin to work in GPIO mode, which causes card detect
|
||||
* status cannot be reflected by the Present State register
|
||||
* in the SD controller (bit 16 & bit 18 are always zero).
|
||||
*
|
||||
* Configure this pin to function 1 (SD controller).
|
||||
*/
|
||||
sdmmc3_cd@0 {
|
||||
pad-offset = <0x3a0>;
|
||||
mode-func = <1>;
|
||||
};
|
||||
};
|
||||
|
||||
chosen {
|
||||
|
@ -217,7 +233,7 @@
|
|||
fsp,mrc-init-mmio-size = <0x800>;
|
||||
fsp,mrc-init-spd-addr1 = <0xa0>;
|
||||
fsp,mrc-init-spd-addr2 = <0xa2>;
|
||||
fsp,emmc-boot-mode = <2>;
|
||||
fsp,emmc-boot-mode = <1>;
|
||||
fsp,enable-sdio;
|
||||
fsp,enable-sdcard;
|
||||
fsp,enable-hsuart1;
|
||||
|
|
|
@ -29,6 +29,7 @@
|
|||
|
||||
pch_pinctrl {
|
||||
compatible = "intel,x86-pinctrl";
|
||||
reg = <0 0>;
|
||||
|
||||
/* GPIO E0 */
|
||||
soc_gpio_s5_0@0 {
|
||||
|
@ -72,6 +73,21 @@
|
|||
output-value = <1>;
|
||||
direction = <PIN_OUTPUT>;
|
||||
};
|
||||
|
||||
/*
|
||||
* As of today, the latest version FSP (gold4) for BayTrail
|
||||
* misses the PAD configuration of the SD controller's Card
|
||||
* Detect signal. The default PAD value for the CD pin sets
|
||||
* the pin to work in GPIO mode, which causes card detect
|
||||
* status cannot be reflected by the Present State register
|
||||
* in the SD controller (bit 16 & bit 18 are always zero).
|
||||
*
|
||||
* Configure this pin to function 1 (SD controller).
|
||||
*/
|
||||
sdmmc3_cd@0 {
|
||||
pad-offset = <0x3a0>;
|
||||
mode-func = <1>;
|
||||
};
|
||||
};
|
||||
|
||||
chosen {
|
||||
|
@ -246,7 +262,7 @@
|
|||
fsp,mrc-init-mmio-size = <0x800>;
|
||||
fsp,mrc-init-spd-addr1 = <0xa0>;
|
||||
fsp,mrc-init-spd-addr2 = <0xa2>;
|
||||
fsp,emmc-boot-mode = <2>;
|
||||
fsp,emmc-boot-mode = <1>;
|
||||
fsp,enable-sdio;
|
||||
fsp,enable-sdcard;
|
||||
fsp,enable-hsuart1;
|
||||
|
|
|
@ -183,20 +183,20 @@ static int acpi_create_madt_lapic(struct acpi_madt_lapic *lapic,
|
|||
int acpi_create_madt_lapics(u32 current)
|
||||
{
|
||||
struct udevice *dev;
|
||||
int length = 0;
|
||||
int total_length = 0;
|
||||
|
||||
for (uclass_find_first_device(UCLASS_CPU, &dev);
|
||||
dev;
|
||||
uclass_find_next_device(&dev)) {
|
||||
struct cpu_platdata *plat = dev_get_parent_platdata(dev);
|
||||
|
||||
length += acpi_create_madt_lapic(
|
||||
(struct acpi_madt_lapic *)current,
|
||||
plat->cpu_id, plat->cpu_id);
|
||||
int length = acpi_create_madt_lapic(
|
||||
(struct acpi_madt_lapic *)current,
|
||||
plat->cpu_id, plat->cpu_id);
|
||||
current += length;
|
||||
total_length += length;
|
||||
}
|
||||
|
||||
return length;
|
||||
return total_length;
|
||||
}
|
||||
|
||||
int acpi_create_madt_ioapic(struct acpi_madt_ioapic *ioapic, u8 id,
|
||||
|
|
|
@ -24,6 +24,8 @@ CONFIG_CMD_EXT4_WRITE=y
|
|||
CONFIG_CMD_FAT=y
|
||||
CONFIG_CMD_FS_GENERIC=y
|
||||
CONFIG_OF_CONTROL=y
|
||||
CONFIG_REGMAP=y
|
||||
CONFIG_SYSCON=y
|
||||
CONFIG_SPI_FLASH=y
|
||||
CONFIG_SPI_FLASH_GIGADEVICE=y
|
||||
CONFIG_SPI_FLASH_MACRONIX=y
|
||||
|
|
|
@ -28,6 +28,8 @@ CONFIG_CMD_EXT4_WRITE=y
|
|||
CONFIG_CMD_FAT=y
|
||||
CONFIG_CMD_FS_GENERIC=y
|
||||
CONFIG_OF_CONTROL=y
|
||||
CONFIG_REGMAP=y
|
||||
CONFIG_SYSCON=y
|
||||
CONFIG_CPU=y
|
||||
CONFIG_SPI_FLASH=y
|
||||
CONFIG_SPI_FLASH_GIGADEVICE=y
|
||||
|
|
|
@ -9,7 +9,7 @@ The PINCTRL master node requires the following properties:
|
|||
Pin nodes must be children of the pinctrl master node and can
|
||||
contain the following properties:
|
||||
- pad-offset - (required) offset in the IOBASE for the pin to configure
|
||||
- gpio-offset - (required) 2 cells
|
||||
- gpio-offset - (required only when 'mode-gpio' is set) 2 cells
|
||||
- offset in the GPIOBASE for the pin to configure
|
||||
- the bit shift in this register (4 = bit 4)
|
||||
- mode-gpio - (optional) standalone property to force the pin into GPIO mode
|
||||
|
@ -18,16 +18,16 @@ contain the following properties:
|
|||
in case of 'mode-gpio' property set:
|
||||
- output-value - (optional) this set the default output value of the GPIO
|
||||
- direction - (optional) this set the direction of the gpio
|
||||
- pull-str - (optional) this set the pull strength of the pin
|
||||
- pull-strength - (optional) this set the pull strength of the pin
|
||||
- pull-assign - (optional) this set the pull assignement (up/down) of the pin
|
||||
- invert - (optional) this input pin is inverted
|
||||
- invert - (optional) this input pin is inverted
|
||||
|
||||
Example:
|
||||
|
||||
pin_usb_host_en0@0 {
|
||||
gpio-offset = <0x80 8>;
|
||||
pad-offset = <0x260>;
|
||||
mode-gpio;
|
||||
output-value = <1>;
|
||||
direction = <PIN_OUTPUT>;
|
||||
gpio-offset = <0x80 8>;
|
||||
pad-offset = <0x260>;
|
||||
mode-gpio;
|
||||
output-value = <1>;
|
||||
direction = <PIN_OUTPUT>;
|
||||
};
|
||||
|
|
|
@ -9,7 +9,6 @@
|
|||
#include <fdtdec.h>
|
||||
#include <pch.h>
|
||||
#include <pci.h>
|
||||
#include <syscon.h>
|
||||
#include <asm/cpu.h>
|
||||
#include <asm/gpio.h>
|
||||
#include <asm/io.h>
|
||||
|
@ -119,12 +118,6 @@ static int broadwell_gpio_probe(struct udevice *dev)
|
|||
struct broadwell_bank_platdata *plat = dev_get_platdata(dev);
|
||||
struct gpio_dev_priv *uc_priv = dev_get_uclass_priv(dev);
|
||||
struct broadwell_bank_priv *priv = dev_get_priv(dev);
|
||||
struct udevice *pinctrl;
|
||||
int ret;
|
||||
|
||||
/* Set up pin control if available */
|
||||
ret = syscon_get_by_driver_data(X86_SYSCON_PINCONF, &pinctrl);
|
||||
debug("%s, pinctrl=%p, ret=%d\n", __func__, pinctrl, ret);
|
||||
|
||||
uc_priv->gpio_count = GPIO_PER_BANK;
|
||||
uc_priv->bank_name = plat->bank_name;
|
||||
|
|
|
@ -32,7 +32,6 @@
|
|||
#include <fdtdec.h>
|
||||
#include <pch.h>
|
||||
#include <pci.h>
|
||||
#include <syscon.h>
|
||||
#include <asm/cpu.h>
|
||||
#include <asm/gpio.h>
|
||||
#include <asm/io.h>
|
||||
|
@ -113,10 +112,6 @@ static int ich6_gpio_probe(struct udevice *dev)
|
|||
struct ich6_bank_platdata *plat = dev_get_platdata(dev);
|
||||
struct gpio_dev_priv *uc_priv = dev_get_uclass_priv(dev);
|
||||
struct ich6_bank_priv *bank = dev_get_priv(dev);
|
||||
struct udevice *pinctrl;
|
||||
|
||||
/* Set up pin control if available */
|
||||
syscon_get_by_driver_data(X86_SYSCON_PINCONF, &pinctrl);
|
||||
|
||||
uc_priv->gpio_count = GPIO_PER_BANK;
|
||||
uc_priv->bank_name = plat->bank_name;
|
||||
|
|
Loading…
Reference in a new issue