diff options
Diffstat (limited to 'target/linux/octeon/patches/100-wndap330_hacks.patch')
| -rw-r--r-- | target/linux/octeon/patches/100-wndap330_hacks.patch | 62 | 
1 files changed, 62 insertions, 0 deletions
| diff --git a/target/linux/octeon/patches/100-wndap330_hacks.patch b/target/linux/octeon/patches/100-wndap330_hacks.patch new file mode 100644 index 000000000..3de2fbbab --- /dev/null +++ b/target/linux/octeon/patches/100-wndap330_hacks.patch @@ -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__); | 
