mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-04-21 12:27:27 +03:00
[backfire] merge r22702, r22703 and r22704
git-svn-id: svn://svn.openwrt.org/openwrt/branches/backfire@22994 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
@@ -554,19 +554,24 @@ static int rtl8366rb_set_mc_index(struct rtl8366_smi *smi, int port, int index)
|
||||
|
||||
static int rtl8366rb_is_vlan_valid(struct rtl8366_smi *smi, unsigned vlan)
|
||||
{
|
||||
if (vlan == 0 || vlan >= RTL8366RB_NUM_VLANS)
|
||||
unsigned max = RTL8366RB_NUM_VLANS;
|
||||
|
||||
if (smi->vlan4k_enabled)
|
||||
max = RTL8366RB_NUM_VIDS - 1;
|
||||
|
||||
if (vlan == 0 || vlan >= max)
|
||||
return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int rtl8366rb_vlan_set_vlan(struct rtl8366_smi *smi, int enable)
|
||||
static int rtl8366rb_enable_vlan(struct rtl8366_smi *smi, int enable)
|
||||
{
|
||||
return rtl8366_smi_rmwr(smi, RTL8366RB_SGCR, RTL8366RB_SGCR_EN_VLAN,
|
||||
(enable) ? RTL8366RB_SGCR_EN_VLAN : 0);
|
||||
}
|
||||
|
||||
static int rtl8366rb_vlan_set_4ktable(struct rtl8366_smi *smi, int enable)
|
||||
static int rtl8366rb_enable_vlan4k(struct rtl8366_smi *smi, int enable)
|
||||
{
|
||||
return rtl8366_smi_rmwr(smi, RTL8366RB_SGCR,
|
||||
RTL8366RB_SGCR_EN_VLAN_4KTB,
|
||||
@@ -583,32 +588,6 @@ static int rtl8366rb_sw_reset_mibs(struct switch_dev *dev,
|
||||
RTL8366RB_MIB_CTRL_GLOBAL_RESET);
|
||||
}
|
||||
|
||||
static int rtl8366rb_sw_get_vlan_enable(struct switch_dev *dev,
|
||||
const struct switch_attr *attr,
|
||||
struct switch_val *val)
|
||||
{
|
||||
struct rtl8366_smi *smi = sw_to_rtl8366_smi(dev);
|
||||
u32 data;
|
||||
|
||||
if (attr->ofs == 1) {
|
||||
rtl8366_smi_read_reg(smi, RTL8366RB_SGCR, &data);
|
||||
|
||||
if (data & RTL8366RB_SGCR_EN_VLAN)
|
||||
val->value.i = 1;
|
||||
else
|
||||
val->value.i = 0;
|
||||
} else if (attr->ofs == 2) {
|
||||
rtl8366_smi_read_reg(smi, RTL8366RB_SGCR, &data);
|
||||
|
||||
if (data & RTL8366RB_SGCR_EN_VLAN_4KTB)
|
||||
val->value.i = 1;
|
||||
else
|
||||
val->value.i = 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rtl8366rb_sw_get_blinkrate(struct switch_dev *dev,
|
||||
const struct switch_attr *attr,
|
||||
struct switch_val *val)
|
||||
@@ -637,18 +616,6 @@ static int rtl8366rb_sw_set_blinkrate(struct switch_dev *dev,
|
||||
val->value.i);
|
||||
}
|
||||
|
||||
static int rtl8366rb_sw_set_vlan_enable(struct switch_dev *dev,
|
||||
const struct switch_attr *attr,
|
||||
struct switch_val *val)
|
||||
{
|
||||
struct rtl8366_smi *smi = sw_to_rtl8366_smi(dev);
|
||||
|
||||
if (attr->ofs == 1)
|
||||
return rtl8366rb_vlan_set_vlan(smi, val->value.i);
|
||||
else
|
||||
return rtl8366rb_vlan_set_4ktable(smi, val->value.i);
|
||||
}
|
||||
|
||||
static int rtl8366rb_sw_get_learning_enable(struct switch_dev *dev,
|
||||
const struct switch_attr *attr,
|
||||
struct switch_val *val)
|
||||
@@ -822,16 +789,16 @@ static struct switch_attr rtl8366rb_globals[] = {
|
||||
.type = SWITCH_TYPE_INT,
|
||||
.name = "enable_vlan",
|
||||
.description = "Enable VLAN mode",
|
||||
.set = rtl8366rb_sw_set_vlan_enable,
|
||||
.get = rtl8366rb_sw_get_vlan_enable,
|
||||
.set = rtl8366_sw_set_vlan_enable,
|
||||
.get = rtl8366_sw_get_vlan_enable,
|
||||
.max = 1,
|
||||
.ofs = 1
|
||||
}, {
|
||||
.type = SWITCH_TYPE_INT,
|
||||
.name = "enable_vlan4k",
|
||||
.description = "Enable VLAN 4K mode",
|
||||
.set = rtl8366rb_sw_set_vlan_enable,
|
||||
.get = rtl8366rb_sw_get_vlan_enable,
|
||||
.set = rtl8366_sw_set_vlan_enable,
|
||||
.get = rtl8366_sw_get_vlan_enable,
|
||||
.max = 1,
|
||||
.ofs = 2
|
||||
}, {
|
||||
@@ -920,7 +887,7 @@ static int rtl8366rb_switch_init(struct rtl8366_smi *smi)
|
||||
dev->name = "RTL8366RB";
|
||||
dev->cpu_port = RTL8366RB_PORT_NUM_CPU;
|
||||
dev->ports = RTL8366RB_NUM_PORTS;
|
||||
dev->vlans = RTL8366RB_NUM_VLANS;
|
||||
dev->vlans = RTL8366RB_NUM_VIDS;
|
||||
dev->ops = &rtl8366_ops;
|
||||
dev->devname = dev_name(smi->parent);
|
||||
|
||||
@@ -1028,6 +995,8 @@ static struct rtl8366_smi_ops rtl8366rb_smi_ops = {
|
||||
.set_mc_index = rtl8366rb_set_mc_index,
|
||||
.get_mib_counter = rtl8366rb_get_mib_counter,
|
||||
.is_vlan_valid = rtl8366rb_is_vlan_valid,
|
||||
.enable_vlan = rtl8366rb_enable_vlan,
|
||||
.enable_vlan4k = rtl8366rb_enable_vlan4k,
|
||||
};
|
||||
|
||||
static int __init rtl8366rb_probe(struct platform_device *pdev)
|
||||
|
||||
Reference in New Issue
Block a user