add a temporary patch to make the wndap330's ethernet work
authorImre Kaloz <kaloz@openwrt.org>
Mon, 15 Jun 2009 20:08:22 +0000 (20:08 +0000)
committerImre Kaloz <kaloz@openwrt.org>
Mon, 15 Jun 2009 20:08:22 +0000 (20:08 +0000)
SVN-Revision: 16478

target/linux/octeon/patches/100-wndap330_hacks.patch [new file with mode: 0644]

diff --git a/target/linux/octeon/patches/100-wndap330_hacks.patch b/target/linux/octeon/patches/100-wndap330_hacks.patch
new file mode 100644 (file)
index 0000000..3de2fbb
--- /dev/null
@@ -0,0 +1,62 @@
+--- a/drivers/staging/octeon/cvmx-helper-board.c
++++ b/drivers/staging/octeon/cvmx-helper-board.c
+@@ -90,7 +90,7 @@ int cvmx_helper_board_get_mii_address(in
+       case CVMX_BOARD_TYPE_KODAMA:
+       case CVMX_BOARD_TYPE_EBH3100:
+       case CVMX_BOARD_TYPE_HIKARI:
+-      case CVMX_BOARD_TYPE_CN3010_EVB_HS5:
++      //case CVMX_BOARD_TYPE_CN3010_EVB_HS5: /* hack for the WNDAP330 */
+       case CVMX_BOARD_TYPE_CN3005_EVB_HS5:
+       case CVMX_BOARD_TYPE_CN3020_EVB_HS5:
+               /*
+@@ -103,6 +103,12 @@ int cvmx_helper_board_get_mii_address(in
+                       return 9;
+               else
+                       return -1;
++      case CVMX_BOARD_TYPE_CN3010_EVB_HS5: /* hack for the WNDAP330 */
++              /* We have only one port, using GMII */
++              if (ipd_port == 0)
++                      return 9;
++              else
++                      return -1;
+       case CVMX_BOARD_TYPE_NAC38:
+               /* Board has 8 RGMII ports PHYs are 0-7 */
+               if ((ipd_port >= 0) && (ipd_port < 4))
+@@ -205,7 +211,7 @@ cvmx_helper_link_info_t __cvmx_helper_bo
+               result.s.speed = 1000;
+               return result;
+       case CVMX_BOARD_TYPE_EBH3100:
+-      case CVMX_BOARD_TYPE_CN3010_EVB_HS5:
++      //case CVMX_BOARD_TYPE_CN3010_EVB_HS5: /* hack for the WNDAP330 */
+       case CVMX_BOARD_TYPE_CN3005_EVB_HS5:
+       case CVMX_BOARD_TYPE_CN3020_EVB_HS5:
+               /* Port 1 on these boards is always Gigabit */
+@@ -217,6 +223,9 @@ cvmx_helper_link_info_t __cvmx_helper_bo
+               }
+               /* Fall through to the generic code below */
+               break;
++      case CVMX_BOARD_TYPE_CN3010_EVB_HS5: /* hack for the WNDAP330 */
++              is_broadcom_phy = 1;
++              break;
+       case CVMX_BOARD_TYPE_CUST_NB5:
+               /* Port 1 on these boards is always Gigabit */
+               if (ipd_port == 1) {
+--- a/drivers/staging/octeon/cvmx-helper-rgmii.c
++++ b/drivers/staging/octeon/cvmx-helper-rgmii.c
+@@ -66,13 +66,15 @@ int __cvmx_helper_rgmii_probe(int interf
+                       cvmx_dprintf("ERROR: RGMII initialize called in "
+                                    "SPI interface\n");
+               } else if (OCTEON_IS_MODEL(OCTEON_CN31XX)
+-                         || OCTEON_IS_MODEL(OCTEON_CN30XX)
++                         //|| OCTEON_IS_MODEL(OCTEON_CN30XX)
+                          || OCTEON_IS_MODEL(OCTEON_CN50XX)) {
+                       /*
+                        * On these chips "type" says we're in
+                        * GMII/MII mode. This limits us to 2 ports
+                        */
+                       num_ports = 2;
++              } else if (OCTEON_IS_MODEL(OCTEON_CN30XX)) {
++                      num_ports = 1;
+               } else {
+                       cvmx_dprintf("ERROR: Unsupported Octeon model in %s\n",
+                                    __func__);