Re: pch_uart and pch_phub clock selection

From: Feng Tang
Date: Sun Feb 19 2012 - 23:44:27 EST


Hi Tomoya,

On Mon, Feb 20, 2012 at 01:28:33PM +0900, Tomoya MORINAGA wrote:
> Hi
>
> Considering Feng's/Darren's proposal/question,
> I should have set 192MHz as default uart clock setting.
> So, I created the following patch. (not formal patch but for review)
> Let me know your opinion.
>
> ---
> drivers/misc/pch_phub.c | 17 ++++++-----------
> drivers/tty/serial/pch_uart.c | 15 +++++++--------
> 2 files changed, 13 insertions(+), 19 deletions(-)
>
> diff --git a/drivers/misc/pch_phub.c b/drivers/misc/pch_phub.c
> index 10fc478..8f9c1db 100644
> --- a/drivers/misc/pch_phub.c
> +++ b/drivers/misc/pch_phub.c
> @@ -55,7 +55,7 @@
> #define CLKCFG_CANCLK_MASK 0xFF000000
> #define CLKCFG_UART_MASK 0xFFFFFF
>
> -/* CM-iTC */
> +/* 192MHz Clock configuration. USB_48MHz / 2 * 8 = 192 */
> #define CLKCFG_UART_48MHZ (1 << 16)
> #define CLKCFG_BAUDDIV (2 << 20)
> #define CLKCFG_PLL2VCO (8 << 9)
> @@ -715,8 +715,6 @@ static int __devinit pch_phub_probe(struct pci_dev *pdev,
> chip->pdev = pdev; /* Save pci device struct */
>
> if (id->driver_data == 1) { /* EG20T PCH */
> - const char *board_name;
> -
> retval = sysfs_create_file(&pdev->dev.kobj,
> &dev_attr_pch_mac.attr);
> if (retval)
> @@ -731,14 +729,11 @@ static int __devinit pch_phub_probe(struct pci_dev *pdev,
> CLKCFG_CAN_50MHZ,
> CLKCFG_CANCLK_MASK);
>
> - /* quirk for CM-iTC board */
> - board_name = dmi_get_system_info(DMI_BOARD_NAME);
> - if (board_name && strstr(board_name, "CM-iTC"))
> - pch_phub_read_modify_write_reg(chip,
> - (unsigned int)CLKCFG_REG_OFFSET,
> - CLKCFG_UART_48MHZ | CLKCFG_BAUDDIV |
> - CLKCFG_PLL2VCO | CLKCFG_UARTCLKSEL,
> - CLKCFG_UART_MASK);
> + pch_phub_read_modify_write_reg(chip,
> + (unsigned int)CLKCFG_REG_OFFSET,
> + CLKCFG_UART_48MHZ | CLKCFG_BAUDDIV |
> + CLKCFG_PLL2VCO | CLKCFG_UARTCLKSEL,
> + CLKCFG_UART_MASK);

All the code looks fine to me except one point: Can we also set ML7213/7223's
default clk to 192MHz? 192MHz works fine on my ML7213 board. And using an
unified default clock rate for all EG20T compatible IOHs will save extra
effort of setting the uart clock.

Thanks,
Feng

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/