]> git.karo-electronics.de Git - karo-tx-linux.git/commit
ARM: imx: fix vf610 enet module clock selection
authorShawn Guo <shawn.guo@freescale.com>
Wed, 10 Jul 2013 06:05:44 +0000 (14:05 +0800)
committerJason Liu <r64343@freescale.com>
Wed, 30 Oct 2013 01:53:43 +0000 (09:53 +0800)
commit87d93b62fa0b5de9c2a87eceb54325f933e6846d
treec0865f77ff2e43776c80b34ae6aae2e6d7c402af
parent90f067e049105e96c5053c9288c2cb8a7296061a
ARM: imx: fix vf610 enet module clock selection

The fec/enet driver calculates MDC rate with the formula below.

  ref_freq / ((MII_SPEED + 1) x 2)

The ref_freq here is the fec internal module clock, which is missing
from clk-vf610 clock driver right now.  And clk-vf610 driver mistakenly
supplies RMII clock (50 MHz) as the source to fec.  This results in the
situation that fec driver gets ref_freq as 50 MHz, while physically it
runs at 66 MHz (fec module clock physically sources from ipg which runs
at 66 MHz).  That's why software expects MDC runs at 2.5 MHz, while the
measurement tells it runs at 3.3 MHz.  And this causes the PHY KSZ8041
keeps swithing between Full and Half mode as below.

  libphy: 400d0000.etherne:00 - Link is Up - 100/Full
  libphy: 400d0000.etherne:00 - Link is Up - 100/Half
  libphy: 400d0000.etherne:00 - Link is Up - 100/Full
  libphy: 400d0000.etherne:00 - Link is Up - 100/Half
  libphy: 400d0000.etherne:00 - Link is Up - 100/Full
  libphy: 400d0000.etherne:00 - Link is Up - 100/Half

Add the missing module clock for ENET0 and ENET1, and correct the clock
supplying in device tree to fix above issue.

Thanks to Alison Wang <b18965@freescale.com> for debugging the issue.

Signed-off-by: Shawn Guo <shawn.guo@freescale.com>
arch/arm/boot/dts/vf610.dtsi
arch/arm/mach-imx/clk-vf610.c
include/dt-bindings/clock/vf610-clock.h