mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-29 08:01:08 +00:00
msm_serial: Read bit rate register value from DT
IPQ40xx and currently supported Snapdragon boards don't use the same one so enable reading it from DT, if no DT property is found default value is the same as the previous define. Signed-off-by: Robert Marko <robert.marko@sartura.hr> Reviewed-By: Ramon Fried <rfried.dev@gmail.com>
This commit is contained in:
parent
e479a7d52e
commit
185dcf7f56
2 changed files with 9 additions and 1 deletions
|
@ -4,3 +4,7 @@ Required properties:
|
||||||
- compatible: must be "qcom,msm-uartdm-v1.4"
|
- compatible: must be "qcom,msm-uartdm-v1.4"
|
||||||
- reg: start address and size of the registers
|
- reg: start address and size of the registers
|
||||||
- clock: interface clock (must accept baudrate as a frequency)
|
- clock: interface clock (must accept baudrate as a frequency)
|
||||||
|
|
||||||
|
Optional properties:
|
||||||
|
- bit-rate: Data Mover bit rate register value
|
||||||
|
(If not defined then 0xCC is used as default)
|
||||||
|
|
|
@ -61,6 +61,7 @@ struct msm_serial_data {
|
||||||
phys_addr_t base;
|
phys_addr_t base;
|
||||||
unsigned chars_cnt; /* number of buffered chars */
|
unsigned chars_cnt; /* number of buffered chars */
|
||||||
uint32_t chars_buf; /* buffered chars */
|
uint32_t chars_buf; /* buffered chars */
|
||||||
|
uint32_t clk_bit_rate; /* data mover mode bit rate register value */
|
||||||
};
|
};
|
||||||
|
|
||||||
static int msm_serial_fetch(struct udevice *dev)
|
static int msm_serial_fetch(struct udevice *dev)
|
||||||
|
@ -190,7 +191,7 @@ static int msm_uart_clk_init(struct udevice *dev)
|
||||||
|
|
||||||
static void uart_dm_init(struct msm_serial_data *priv)
|
static void uart_dm_init(struct msm_serial_data *priv)
|
||||||
{
|
{
|
||||||
writel(UART_DM_CLK_RX_TX_BIT_RATE, priv->base + UARTDM_CSR);
|
writel(priv->clk_bit_rate, priv->base + UARTDM_CSR);
|
||||||
writel(0x0, priv->base + UARTDM_MR1);
|
writel(0x0, priv->base + UARTDM_MR1);
|
||||||
writel(MSM_BOOT_UART_DM_8_N_1_MODE, priv->base + UARTDM_MR2);
|
writel(MSM_BOOT_UART_DM_8_N_1_MODE, priv->base + UARTDM_MR2);
|
||||||
writel(MSM_BOOT_UART_DM_CMD_RESET_RX, priv->base + UARTDM_CR);
|
writel(MSM_BOOT_UART_DM_CMD_RESET_RX, priv->base + UARTDM_CR);
|
||||||
|
@ -223,6 +224,9 @@ static int msm_serial_ofdata_to_platdata(struct udevice *dev)
|
||||||
if (priv->base == FDT_ADDR_T_NONE)
|
if (priv->base == FDT_ADDR_T_NONE)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
priv->clk_bit_rate = fdtdec_get_int(gd->fdt_blob, dev_of_offset(dev),
|
||||||
|
"bit-rate", UART_DM_CLK_RX_TX_BIT_RATE);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue