|
|
|
@ -819,39 +819,6 @@ static int rtl8366s_sw_reset_port_mibs(struct switch_dev *dev,
|
|
|
|
|
0, (1 << (val->port_vlan + 3)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int rtl8366s_sw_get_port_mib(struct switch_dev *dev,
|
|
|
|
|
const struct switch_attr *attr,
|
|
|
|
|
struct switch_val *val)
|
|
|
|
|
{
|
|
|
|
|
struct rtl8366_smi *smi = sw_to_rtl8366_smi(dev);
|
|
|
|
|
int i, len = 0;
|
|
|
|
|
unsigned long long counter = 0;
|
|
|
|
|
char *buf = smi->buf;
|
|
|
|
|
|
|
|
|
|
if (val->port_vlan >= smi->num_ports)
|
|
|
|
|
return -EINVAL;
|
|
|
|
|
|
|
|
|
|
len += snprintf(buf + len, sizeof(smi->buf) - len,
|
|
|
|
|
"Port %d MIB counters\n",
|
|
|
|
|
val->port_vlan);
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < smi->num_mib_counters; ++i) {
|
|
|
|
|
len += snprintf(buf + len, sizeof(smi->buf) - len,
|
|
|
|
|
"%-36s: ", smi->mib_counters[i].name);
|
|
|
|
|
if (!smi->ops->get_mib_counter(smi, i, val->port_vlan,
|
|
|
|
|
&counter))
|
|
|
|
|
len += snprintf(buf + len, sizeof(smi->buf) - len,
|
|
|
|
|
"%llu\n", counter);
|
|
|
|
|
else
|
|
|
|
|
len += snprintf(buf + len, sizeof(smi->buf) - len,
|
|
|
|
|
"%s\n", "error");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
val->value.s = buf;
|
|
|
|
|
val->len = len;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int rtl8366s_sw_get_vlan_ports(struct switch_dev *dev,
|
|
|
|
|
struct switch_val *val)
|
|
|
|
|
{
|
|
|
|
@ -971,7 +938,7 @@ static struct switch_attr rtl8366s_port[] = {
|
|
|
|
|
.description = "Get MIB counters for port",
|
|
|
|
|
.max = 33,
|
|
|
|
|
.set = NULL,
|
|
|
|
|
.get = rtl8366s_sw_get_port_mib,
|
|
|
|
|
.get = rtl8366_sw_get_port_mib,
|
|
|
|
|
}, {
|
|
|
|
|
.type = SWITCH_TYPE_INT,
|
|
|
|
|
.name = "led",
|
|
|
|
|