[edk2-devel] [edk2-platforms: PATCH v2 1/3] Marvell/Library: UtmiLib: update USB2.0 analog settings
Leif Lindholm
leif at nuviainc.com
Mon May 18 17:12:21 UTC 2020
On Fri, May 15, 2020 at 23:05:56 +0200, Marcin Wojtas wrote:
> This patch introduce following modifications, allowing to
> overcome the instabilities observed with certain USB2.0 endpoints:
> * Add additional step which enables the Impedance and PLL calibration.
> * Enable old squelch detector instead of the new analog squelch detector
> circuit and update host disconnect threshold value.
> * Update LS TX driver strength coarse and fine adjustment values.
>
> Signed-off-by: Grzegorz Jaszczyk <jaz at semihalf.com>
> Signed-off-by: Marcin Wojtas <mw at semihalf.com>
I'm OK with the current version of the code, but just noticed this.
No one can give Signed-off-by for another.
If Grzegorz is the author, that should be noted in a From: tag. Git
format-patch does this automatically if the commit's Author metadata
is set.
This applies to all 3 patches.
/
Leif
> ---
> Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.h | 10 +++++++++-
> Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.c | 18 ++++++++++++++----
> 2 files changed, 23 insertions(+), 5 deletions(-)
>
> diff --git a/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.h b/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.h
> index 20e3133..8659110 100644
> --- a/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.h
> +++ b/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.h
> @@ -44,6 +44,10 @@ SPDX-License-Identifier: BSD-2-Clause-Patent
> #define UTMI_CALIB_CTRL_REG 0x8
> #define UTMI_CALIB_CTRL_IMPCAL_VTH_OFFSET 8
> #define UTMI_CALIB_CTRL_IMPCAL_VTH_MASK (0x7 << UTMI_CALIB_CTRL_IMPCAL_VTH_OFFSET)
> +#define UTMI_CALIB_CTRL_IMPCAL_START_OFFSET 13
> +#define UTMI_CALIB_CTRL_IMPCAL_START_MASK (0x1 << UTMI_CALIB_CTRL_IMPCAL_START_OFFSET)
> +#define UTMI_CALIB_CTRL_PLLCAL_START_OFFSET 22
> +#define UTMI_CALIB_CTRL_PLLCAL_START_MASK (0x1 << UTMI_CALIB_CTRL_PLLCAL_START_OFFSET)
> #define UTMI_CALIB_CTRL_IMPCAL_DONE_OFFSET 23
> #define UTMI_CALIB_CTRL_IMPCAL_DONE_MASK (0x1 << UTMI_CALIB_CTRL_IMPCAL_DONE_OFFSET)
> #define UTMI_CALIB_CTRL_PLLCAL_DONE_OFFSET 31
> @@ -54,8 +58,12 @@ SPDX-License-Identifier: BSD-2-Clause-Patent
> #define UTMI_TX_CH_CTRL_DRV_EN_LS_MASK (0xf << UTMI_TX_CH_CTRL_DRV_EN_LS_OFFSET)
> #define UTMI_TX_CH_CTRL_IMP_SEL_LS_OFFSET 16
> #define UTMI_TX_CH_CTRL_IMP_SEL_LS_MASK (0xf << UTMI_TX_CH_CTRL_IMP_SEL_LS_OFFSET)
> +#define UTMI_TX_CH_CTRL_AMP_OFFSET 20
> +#define UTMI_TX_CH_CTRL_AMP_MASK (0x7 << UTMI_TX_CH_CTRL_AMP_OFFSET)
>
> #define UTMI_RX_CH_CTRL0_REG 0x14
> +#define UTMI_RX_CH_CTRL0_DISCON_THRESH_OFFSET 8
> +#define UTMI_RX_CH_CTRL0_DISCON_THRESH_MASK (0x3 << UTMI_RX_CH_CTRL0_DISCON_THRESH_OFFSET)
> #define UTMI_RX_CH_CTRL0_SQ_DET_OFFSET 15
> #define UTMI_RX_CH_CTRL0_SQ_DET_MASK (0x1 << UTMI_RX_CH_CTRL0_SQ_DET_OFFSET)
> #define UTMI_RX_CH_CTRL0_SQ_ANA_DTC_OFFSET 28
> @@ -63,7 +71,7 @@ SPDX-License-Identifier: BSD-2-Clause-Patent
>
> #define UTMI_RX_CH_CTRL1_REG 0x18
> #define UTMI_RX_CH_CTRL1_SQ_AMP_CAL_OFFSET 0
> -#define UTMI_RX_CH_CTRL1_SQ_AMP_CAL_MASK (0x3 << UTMI_RX_CH_CTRL1_SQ_AMP_CAL_OFFSET)
> +#define UTMI_RX_CH_CTRL1_SQ_AMP_CAL_MASK (0x7 << UTMI_RX_CH_CTRL1_SQ_AMP_CAL_OFFSET)
> #define UTMI_RX_CH_CTRL1_SQ_AMP_CAL_EN_OFFSET 3
> #define UTMI_RX_CH_CTRL1_SQ_AMP_CAL_EN_MASK (0x1 << UTMI_RX_CH_CTRL1_SQ_AMP_CAL_EN_OFFSET)
>
> diff --git a/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.c b/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.c
> index 3881ebd..42f38db 100644
> --- a/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.c
> +++ b/Silicon/Marvell/Library/UtmiPhyLib/UtmiPhyLib.c
> @@ -118,23 +118,33 @@ UtmiPhyConfig (
>
> /* Impedance Calibration Threshold Setting */
> RegSet (UtmiBaseAddr + UTMI_CALIB_CTRL_REG,
> - 0x6 << UTMI_CALIB_CTRL_IMPCAL_VTH_OFFSET,
> + 0x7 << UTMI_CALIB_CTRL_IMPCAL_VTH_OFFSET,
> UTMI_CALIB_CTRL_IMPCAL_VTH_MASK);
>
> + /* Start Impedance and PLL Calibration */
> + Mask = UTMI_CALIB_CTRL_PLLCAL_START_MASK;
> + Data = (0x1 << UTMI_CALIB_CTRL_PLLCAL_START_OFFSET);
> + Mask |= UTMI_CALIB_CTRL_IMPCAL_START_MASK;
> + Data |= (0x1 << UTMI_CALIB_CTRL_IMPCAL_START_OFFSET);
> + RegSet (UtmiBaseAddr + UTMI_CALIB_CTRL_REG, Data, Mask);
> +
> /* Set LS TX driver strength coarse control */
> Mask = UTMI_TX_CH_CTRL_DRV_EN_LS_MASK;
> Data = 0x3 << UTMI_TX_CH_CTRL_DRV_EN_LS_OFFSET;
> - /* Set LS TX driver fine adjustment */
> + Mask |= UTMI_TX_CH_CTRL_AMP_MASK;
> + Data |= 0x4 << UTMI_TX_CH_CTRL_AMP_OFFSET;
> Mask |= UTMI_TX_CH_CTRL_IMP_SEL_LS_MASK;
> Data |= 0x3 << UTMI_TX_CH_CTRL_IMP_SEL_LS_OFFSET;
> RegSet (UtmiBaseAddr + UTMI_TX_CH_CTRL_REG, Data, Mask);
>
> /* Enable SQ */
> Mask = UTMI_RX_CH_CTRL0_SQ_DET_MASK;
> - Data = 0x0 << UTMI_RX_CH_CTRL0_SQ_DET_OFFSET;
> + Data = 0x1 << UTMI_RX_CH_CTRL0_SQ_DET_OFFSET;
> /* Enable analog squelch detect */
> Mask |= UTMI_RX_CH_CTRL0_SQ_ANA_DTC_MASK;
> - Data |= 0x1 << UTMI_RX_CH_CTRL0_SQ_ANA_DTC_OFFSET;
> + Data |= 0x0 << UTMI_RX_CH_CTRL0_SQ_ANA_DTC_OFFSET;
> + Mask |= UTMI_RX_CH_CTRL0_DISCON_THRESH_MASK;
> + Data |= 0x0 << UTMI_RX_CH_CTRL0_DISCON_THRESH_OFFSET;
> RegSet (UtmiBaseAddr + UTMI_RX_CH_CTRL0_REG, Data, Mask);
>
> /* Set External squelch calibration number */
> --
> 2.7.4
>
-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#59754): https://edk2.groups.io/g/devel/message/59754
Mute This Topic: https://groups.io/mt/74237155/1813853
Group Owner: devel+owner at edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [edk2-devel-archive at redhat.com]
-=-=-=-=-=-=-=-=-=-=-=-
More information about the edk2-devel-archive
mailing list