Browse Source

Fix VLYNQ device enable for DG834Gv1

This patch allows VLYNQ devices on the DG834Gv1 to be successfully
enabled.

Currently the "__vlynq_enable_device" function attempts to set the VLYNQ
device clock divisor to values from 1 through 8 until a link is
successfully established. On the DG834Gv1 (but not the DG834Gv2),
setting the VLYNQ device clock divisor to 1 (full rate) results in all
further VLYNQ operations failing (including software reset), so the
device is never enabled. This patches changes the function to only
attempt divisors 2 through 8, and hence the device is successfully
enabled.

Signed-off-by: Nick Forbes <[email protected]>

---------

SVN-Revision: 9656
Felix Fietkau 18 years ago
parent
commit
5dc134c542
1 changed files with 1 additions and 1 deletions
  1. 1 1
      target/linux/ar7/files/drivers/vlynq/vlynq.c

+ 1 - 1
target/linux/ar7/files/drivers/vlynq/vlynq.c

@@ -373,7 +373,7 @@ static int __vlynq_enable_device(struct vlynq_device *dev)
 	case vlynq_div_auto:
 		/* Only try locally supplied clock, others cause problems */
 		vlynq_reg_write(dev->remote->control, 0);
-		for (i = vlynq_ldiv1; i <= vlynq_ldiv8; i++) {
+		for (i = vlynq_ldiv2; i <= vlynq_ldiv8; i++) {
 			vlynq_reg_write(dev->local->control,
 					VLYNQ_CTRL_CLOCK_INT |
 					VLYNQ_CTRL_CLOCK_DIV(i - vlynq_ldiv1));