Merge branch 'master' of git://git.denx.de/u-boot-sunxi
This commit is contained in:
commit
c06088b360
@ -230,6 +230,7 @@ config MACH_SUN8I_A83T
|
|||||||
select PHY_SUN4I_USB
|
select PHY_SUN4I_USB
|
||||||
select SUNXI_GEN_SUN6I
|
select SUNXI_GEN_SUN6I
|
||||||
select MMC_SUNXI_HAS_NEW_MODE
|
select MMC_SUNXI_HAS_NEW_MODE
|
||||||
|
select MMC_SUNXI_HAS_MODE_SWITCH
|
||||||
select SUPPORT_SPL
|
select SUPPORT_SPL
|
||||||
|
|
||||||
config MACH_SUN8I_H3
|
config MACH_SUN8I_H3
|
||||||
@ -281,6 +282,7 @@ config MACH_SUN50I
|
|||||||
select SUN6I_PRCM
|
select SUN6I_PRCM
|
||||||
select SUNXI_DE2
|
select SUNXI_DE2
|
||||||
select SUNXI_GEN_SUN6I
|
select SUNXI_GEN_SUN6I
|
||||||
|
select MMC_SUNXI_HAS_NEW_MODE
|
||||||
select SUPPORT_SPL
|
select SUPPORT_SPL
|
||||||
select SUNXI_DRAM_DW
|
select SUNXI_DRAM_DW
|
||||||
select SUNXI_DRAM_DW_32BIT
|
select SUNXI_DRAM_DW_32BIT
|
||||||
|
@ -334,7 +334,7 @@ unsigned long sunxi_dram_init(void)
|
|||||||
struct dram_para para = {
|
struct dram_para para = {
|
||||||
.cs1 = 0,
|
.cs1 = 0,
|
||||||
.bank = 1,
|
.bank = 1,
|
||||||
.rank = 1,
|
.rank = 2,
|
||||||
.rows = 15,
|
.rows = 15,
|
||||||
.bus_width = 16,
|
.bus_width = 16,
|
||||||
.page_size = 2048,
|
.page_size = 2048,
|
||||||
|
@ -569,6 +569,10 @@ config MMC_SUNXI_HAS_NEW_MODE
|
|||||||
bool
|
bool
|
||||||
depends on MMC_SUNXI
|
depends on MMC_SUNXI
|
||||||
|
|
||||||
|
config MMC_SUNXI_HAS_MODE_SWITCH
|
||||||
|
bool
|
||||||
|
depends on MMC_SUNXI
|
||||||
|
|
||||||
config GENERIC_ATMEL_MCI
|
config GENERIC_ATMEL_MCI
|
||||||
bool "Atmel Multimedia Card Interface support"
|
bool "Atmel Multimedia Card Interface support"
|
||||||
depends on DM_MMC && BLK && ARCH_AT91
|
depends on DM_MMC && BLK && ARCH_AT91
|
||||||
|
@ -98,24 +98,21 @@ static int mmc_resource_init(int sdc_no)
|
|||||||
static int mmc_set_mod_clk(struct sunxi_mmc_priv *priv, unsigned int hz)
|
static int mmc_set_mod_clk(struct sunxi_mmc_priv *priv, unsigned int hz)
|
||||||
{
|
{
|
||||||
unsigned int pll, pll_hz, div, n, oclk_dly, sclk_dly;
|
unsigned int pll, pll_hz, div, n, oclk_dly, sclk_dly;
|
||||||
bool new_mode = false;
|
bool new_mode = true;
|
||||||
bool calibrate = false;
|
bool calibrate = false;
|
||||||
u32 val = 0;
|
u32 val = 0;
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_MMC_SUNXI_HAS_NEW_MODE) && (priv->mmc_no == 2))
|
if (!IS_ENABLED(CONFIG_MMC_SUNXI_HAS_NEW_MODE))
|
||||||
new_mode = true;
|
new_mode = false;
|
||||||
|
|
||||||
|
/* A83T support new mode only on eMMC */
|
||||||
|
if (IS_ENABLED(CONFIG_MACH_SUN8I_A83T) && priv->mmc_no != 2)
|
||||||
|
new_mode = false;
|
||||||
|
|
||||||
#if defined(CONFIG_MACH_SUN50I) || defined(CONFIG_MACH_SUN50I_H6)
|
#if defined(CONFIG_MACH_SUN50I) || defined(CONFIG_MACH_SUN50I_H6)
|
||||||
calibrate = true;
|
calibrate = true;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
|
||||||
* The MMC clock has an extra /2 post-divider when operating in the new
|
|
||||||
* mode.
|
|
||||||
*/
|
|
||||||
if (new_mode)
|
|
||||||
hz = hz * 2;
|
|
||||||
|
|
||||||
if (hz <= 24000000) {
|
if (hz <= 24000000) {
|
||||||
pll = CCM_MMC_CTRL_OSCM24;
|
pll = CCM_MMC_CTRL_OSCM24;
|
||||||
pll_hz = 24000000;
|
pll_hz = 24000000;
|
||||||
@ -176,7 +173,9 @@ static int mmc_set_mod_clk(struct sunxi_mmc_priv *priv, unsigned int hz)
|
|||||||
|
|
||||||
if (new_mode) {
|
if (new_mode) {
|
||||||
#ifdef CONFIG_MMC_SUNXI_HAS_NEW_MODE
|
#ifdef CONFIG_MMC_SUNXI_HAS_NEW_MODE
|
||||||
|
#ifdef CONFIG_MMC_SUNXI_HAS_MODE_SWITCH
|
||||||
val = CCM_MMC_CTRL_MODE_SEL_NEW;
|
val = CCM_MMC_CTRL_MODE_SEL_NEW;
|
||||||
|
#endif
|
||||||
setbits_le32(&priv->reg->ntsr, SUNXI_MMC_NTSR_MODE_SEL_NEW);
|
setbits_le32(&priv->reg->ntsr, SUNXI_MMC_NTSR_MODE_SEL_NEW);
|
||||||
#endif
|
#endif
|
||||||
} else if (!calibrate) {
|
} else if (!calibrate) {
|
||||||
|
@ -60,6 +60,10 @@
|
|||||||
#define SC_ETCS_MASK GENMASK(1, 0)
|
#define SC_ETCS_MASK GENMASK(1, 0)
|
||||||
#define SC_ETCS_EXT_GMII 0x1
|
#define SC_ETCS_EXT_GMII 0x1
|
||||||
#define SC_ETCS_INT_GMII 0x2
|
#define SC_ETCS_INT_GMII 0x2
|
||||||
|
#define SC_ETXDC_MASK GENMASK(12, 10)
|
||||||
|
#define SC_ETXDC_OFFSET 10
|
||||||
|
#define SC_ERXDC_MASK GENMASK(9, 5)
|
||||||
|
#define SC_ERXDC_OFFSET 5
|
||||||
|
|
||||||
#define CONFIG_MDIO_TIMEOUT (3 * CONFIG_SYS_HZ)
|
#define CONFIG_MDIO_TIMEOUT (3 * CONFIG_SYS_HZ)
|
||||||
|
|
||||||
@ -140,6 +144,8 @@ struct emac_eth_dev {
|
|||||||
struct sun8i_eth_pdata {
|
struct sun8i_eth_pdata {
|
||||||
struct eth_pdata eth_pdata;
|
struct eth_pdata eth_pdata;
|
||||||
u32 reset_delays[3];
|
u32 reset_delays[3];
|
||||||
|
int tx_delay_ps;
|
||||||
|
int rx_delay_ps;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -273,7 +279,8 @@ static int sun8i_emac_set_syscon_ephy(struct emac_eth_dev *priv, u32 *reg)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sun8i_emac_set_syscon(struct emac_eth_dev *priv)
|
static int sun8i_emac_set_syscon(struct sun8i_eth_pdata *pdata,
|
||||||
|
struct emac_eth_dev *priv)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u32 reg;
|
u32 reg;
|
||||||
@ -312,6 +319,14 @@ static int sun8i_emac_set_syscon(struct emac_eth_dev *priv)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pdata->tx_delay_ps)
|
||||||
|
reg |= ((pdata->tx_delay_ps / 100) << SC_ETXDC_OFFSET)
|
||||||
|
& SC_ETXDC_MASK;
|
||||||
|
|
||||||
|
if (pdata->rx_delay_ps)
|
||||||
|
reg |= ((pdata->rx_delay_ps / 100) << SC_ERXDC_OFFSET)
|
||||||
|
& SC_ERXDC_MASK;
|
||||||
|
|
||||||
writel(reg, priv->sysctl_reg + 0x30);
|
writel(reg, priv->sysctl_reg + 0x30);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -784,13 +799,14 @@ static void sun8i_emac_eth_stop(struct udevice *dev)
|
|||||||
|
|
||||||
static int sun8i_emac_eth_probe(struct udevice *dev)
|
static int sun8i_emac_eth_probe(struct udevice *dev)
|
||||||
{
|
{
|
||||||
struct eth_pdata *pdata = dev_get_platdata(dev);
|
struct sun8i_eth_pdata *sun8i_pdata = dev_get_platdata(dev);
|
||||||
|
struct eth_pdata *pdata = &sun8i_pdata->eth_pdata;
|
||||||
struct emac_eth_dev *priv = dev_get_priv(dev);
|
struct emac_eth_dev *priv = dev_get_priv(dev);
|
||||||
|
|
||||||
priv->mac_reg = (void *)pdata->iobase;
|
priv->mac_reg = (void *)pdata->iobase;
|
||||||
|
|
||||||
sun8i_emac_board_setup(priv);
|
sun8i_emac_board_setup(priv);
|
||||||
sun8i_emac_set_syscon(priv);
|
sun8i_emac_set_syscon(sun8i_pdata, priv);
|
||||||
|
|
||||||
sun8i_mdio_init(dev->name, dev);
|
sun8i_mdio_init(dev->name, dev);
|
||||||
priv->bus = miiphy_get_dev_by_name(dev->name);
|
priv->bus = miiphy_get_dev_by_name(dev->name);
|
||||||
@ -891,6 +907,18 @@ static int sun8i_emac_eth_ofdata_to_platdata(struct udevice *dev)
|
|||||||
if (!priv->use_internal_phy)
|
if (!priv->use_internal_phy)
|
||||||
parse_phy_pins(dev);
|
parse_phy_pins(dev);
|
||||||
|
|
||||||
|
sun8i_pdata->tx_delay_ps = fdtdec_get_int(gd->fdt_blob, node,
|
||||||
|
"allwinner,tx-delay-ps", 0);
|
||||||
|
if (sun8i_pdata->tx_delay_ps < 0 || sun8i_pdata->tx_delay_ps > 700)
|
||||||
|
printf("%s: Invalid TX delay value %d\n", __func__,
|
||||||
|
sun8i_pdata->tx_delay_ps);
|
||||||
|
|
||||||
|
sun8i_pdata->rx_delay_ps = fdtdec_get_int(gd->fdt_blob, node,
|
||||||
|
"allwinner,rx-delay-ps", 0);
|
||||||
|
if (sun8i_pdata->rx_delay_ps < 0 || sun8i_pdata->rx_delay_ps > 3100)
|
||||||
|
printf("%s: Invalid RX delay value %d\n", __func__,
|
||||||
|
sun8i_pdata->rx_delay_ps);
|
||||||
|
|
||||||
#ifdef CONFIG_DM_GPIO
|
#ifdef CONFIG_DM_GPIO
|
||||||
if (fdtdec_get_bool(gd->fdt_blob, dev_of_offset(dev),
|
if (fdtdec_get_bool(gd->fdt_blob, dev_of_offset(dev),
|
||||||
"snps,reset-active-low"))
|
"snps,reset-active-low"))
|
||||||
|
Loading…
Reference in New Issue
Block a user