From 04144c111c1a4ff9b25f1e23414b483ce014a0a1 Mon Sep 17 00:00:00 2001 From: juhosg Date: Sun, 30 Jan 2011 21:15:02 +0000 Subject: [PATCH] backfire: generic: rtl8366s: allow initial register values to be passed via platform_data (backport of r25120) git-svn-id: svn://svn.openwrt.org/openwrt/branches/backfire@25256 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../generic-2.6/files/drivers/net/phy/rtl8366s.c | 11 +++++++++++ .../linux/generic-2.6/files/include/linux/rtl8366s.h | 7 +++++++ 2 files changed, 18 insertions(+) diff --git a/target/linux/generic-2.6/files/drivers/net/phy/rtl8366s.c b/target/linux/generic-2.6/files/drivers/net/phy/rtl8366s.c index 3b7fcce32..7e7216413 100644 --- a/target/linux/generic-2.6/files/drivers/net/phy/rtl8366s.c +++ b/target/linux/generic-2.6/files/drivers/net/phy/rtl8366s.c @@ -251,8 +251,19 @@ static int rtl8366s_reset_chip(struct rtl8366_smi *smi) static int rtl8366s_hw_init(struct rtl8366_smi *smi) { + struct rtl8366s_platform_data *pdata; int err; + pdata = smi->parent->platform_data; + if (pdata->num_initvals && pdata->initvals) { + unsigned i; + + dev_info(smi->parent, "applying initvals\n"); + for (i = 0; i < pdata->num_initvals; i++) + REG_WR(smi, pdata->initvals[i].reg, + pdata->initvals[i].val); + } + /* set maximum packet length to 1536 bytes */ REG_RMW(smi, RTL8366S_SGCR, RTL8366S_SGCR_MAX_LENGTH_MASK, RTL8366S_SGCR_MAX_LENGTH_1536); diff --git a/target/linux/generic-2.6/files/include/linux/rtl8366s.h b/target/linux/generic-2.6/files/include/linux/rtl8366s.h index 09173ec20..7d5daa481 100644 --- a/target/linux/generic-2.6/files/include/linux/rtl8366s.h +++ b/target/linux/generic-2.6/files/include/linux/rtl8366s.h @@ -13,9 +13,16 @@ #define RTL8366S_DRIVER_NAME "rtl8366s" +struct rtl8366s_initval { + unsigned reg; + u16 val; +}; + struct rtl8366s_platform_data { unsigned gpio_sda; unsigned gpio_sck; + unsigned num_initvals; + struct rtl8366s_initval *initvals; }; #endif /* _RTL8366_SMI_H */