Commit 218afa10 authored by David S. Miller's avatar David S. Miller

Merge branch 'hns-debug-dsaf'

Yisen Zhuang says:

====================
net: hns: add support of debug dsaf device

There are two kinds of dsaf device in hns, one is for service ports,
contains crossbar in it, can work under different mode. Another is for
debug port, only can work under single port mode. The current code only
declares a dsaf device for both service ports and debug ports.It is not so
readability. This patch separates it to three platform devices to make the
code more simple and readability.

The diagram of all port in one platform device(old):
                                        CPU
                                         |
                                         |        DSAF(one platform device)
    --------------------------------------------------------------      /
    |                           |                  |      |      |     /
    |                          PPE                PPE    PPE     |    /
    |                           |                  |      |      |   /
    |                           |                  |      |      |  /
    |                        crossbar              |      |      | /
    |                           |                  |      |      |/
    |    -----------------------------------       |      |      |
    |    |      |      |      |      |      |      |      |      |
    |    |      |      |      |      |      |      |      |      |
    |   MAC    MAC    MAC    MAC    MAC    MAC    MAC    MAC     |
    |    |      |      |      |      |      |      |      |      |
    --------------------------------------------------------------
         |      |      |      |      |      |      |      |
        PHY    PHY    PHY    PHY    PHY    PHY    PHY    PHY

The diagram of separating ports to three platform(new):
                                                         CPU
                                                          |
                                    -----------------------------------
                                    |                     |           |
    ----------------------------------------------    ---------   ---------
    |                         |                  |    |       |   |   |   |
    |                        PPE                 |    |  PPE  |   |  PPE  |
    |                         |                  |    |   |   |   |   |   |
    |                         |                  |    |   |   |   |   |   |
    |                      crossbar              |    |   |   |   |   |   |
    |                         |                  |    |   |   |   |   |   |
    |   ----------------------------------       |    |   |   |   |   |   |
    |   |     |     |      |      |      |       |    |   |   |   |   |   |
    |   |     |     |      |      |      |       |    |   |   |   |   |   |
    |  MAC   MAC   MAC    MAC    MAC    MAC      |    |  MAC  |   |  MAC  |
    |   |     |     |      |      |      |       |    |   |   |   |   |   |
    ----------------------------------------------    ---------   ---------
        |     |     |      |      |      |    \        /  |        /  |
       PHY   PHY   PHY    PHY    PHY    PHY    \      /  PHY      /  PHY
                                                \    /           /
                                                 \  /           /
                                             DSAF(three platform device)

We take the compatibility into consideration, and it works well by using the
old dts file(tested on d02 board).

For more details, please see individual patches.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents 5a5f0792 218afd68
...@@ -7,19 +7,47 @@ Required properties: ...@@ -7,19 +7,47 @@ Required properties:
- mode: dsa fabric mode string. only support one of dsaf modes like these: - mode: dsa fabric mode string. only support one of dsaf modes like these:
"2port-64vf", "2port-64vf",
"6port-16rss", "6port-16rss",
"6port-16vf". "6port-16vf",
"single-port".
- interrupt-parent: the interrupt parent of this device. - interrupt-parent: the interrupt parent of this device.
- interrupts: should contain the DSA Fabric and rcb interrupt. - interrupts: should contain the DSA Fabric and rcb interrupt.
- reg: specifies base physical address(es) and size of the device registers. - reg: specifies base physical address(es) and size of the device registers.
The first region is external interface control register base and size. The first region is external interface control register base and size(optional,
The second region is SerDes base register and size. only be used when subctrl-syscon is not exists). It is recommended using
subctrl-syscon rather than this address.
The second region is SerDes base register and size(optional, only be used when
serdes-syscon in port node is not exists. It is recommended using
serdes-syscon rather than this address.
The third region is the PPE register base and size. The third region is the PPE register base and size.
The fourth region is dsa fabric base register and size. The fourth region is dsa fabric base register and size. It is not required for
The fifth region is cpld base register and size, it is not required if do not use cpld. single-port mode.
- phy-handle: phy handle of physicl port, 0 if not any phy device. see ethernet.txt [1]. - reg-names: may be ppe-base and(or) dsaf-base. It is used to find the
corresponding reg's index.
- phy-handle: phy handle of physicl port, 0 if not any phy device. It is optional
attribute. If port node is exists, phy-handle in each port node will be used.
see ethernet.txt [1].
- subctrl-syscon: is syscon handle for external interface control register.
- reset-field-offset: is offset of reset field. Its value depends on the hardware
user manual.
- buf-size: rx buffer size, should be 16-1024. - buf-size: rx buffer size, should be 16-1024.
- desc-num: number of description in TX and RX queue, should be 512, 1024, 2048 or 4096. - desc-num: number of description in TX and RX queue, should be 512, 1024, 2048 or 4096.
- port: subnodes of dsaf. A dsaf node may contain several port nodes(Depending
on mode of dsaf). Port node contain some attributes listed below:
- port-id: is physical port index in one dsaf.
- phy-handle: phy handle of physicl port. It is not required if there isn't
phy device. see ethernet.txt [1].
- serdes-syscon: is syscon handle for SerDes register.
- cpld-syscon: is syscon handle for cpld register. It is not required if there
isn't cpld device.
- cpld-ctrl-reg: is cpld register offset. It is not required if there isn't
cpld-syscon.
- port-rst-offset: is offset of reset field for each port in dsaf. Its value
depends on the hardware user manual.
- port-mode-offset: is offset of port mode field for each port in dsaf. Its
value depends on the hardware user manual.
[1] Documentation/devicetree/bindings/net/phy.txt [1] Documentation/devicetree/bindings/net/phy.txt
Example: Example:
...@@ -28,11 +56,11 @@ dsaf0: dsa@c7000000 { ...@@ -28,11 +56,11 @@ dsaf0: dsa@c7000000 {
compatible = "hisilicon,hns-dsaf-v1"; compatible = "hisilicon,hns-dsaf-v1";
mode = "6port-16rss"; mode = "6port-16rss";
interrupt-parent = <&mbigen_dsa>; interrupt-parent = <&mbigen_dsa>;
reg = <0x0 0xC0000000 0x0 0x420000 reg = <0x0 0xc5000000 0x0 0x890000
0x0 0xC2000000 0x0 0x300000
0x0 0xc5000000 0x0 0x890000
0x0 0xc7000000 0x0 0x60000>; 0x0 0xc7000000 0x0 0x60000>;
phy-handle = <0 0 0 0 &soc0_phy4 &soc0_phy5 0 0>; reg-names = "ppe-base", "dsaf-base";
subctrl-syscon = <&subctrl>;
reset-field-offset = 0;
interrupts = <131 4>,<132 4>, <133 4>,<134 4>, interrupts = <131 4>,<132 4>, <133 4>,<134 4>,
<135 4>,<136 4>, <137 4>,<138 4>, <135 4>,<136 4>, <137 4>,<138 4>,
<139 4>,<140 4>, <141 4>,<142 4>, <139 4>,<140 4>, <141 4>,<142 4>,
...@@ -43,4 +71,15 @@ dsaf0: dsa@c7000000 { ...@@ -43,4 +71,15 @@ dsaf0: dsa@c7000000 {
buf-size = <4096>; buf-size = <4096>;
desc-num = <1024>; desc-num = <1024>;
dma-coherent; dma-coherent;
prot@0 {
port-id = 0;
phy-handle = <&phy0>;
serdes-syscon = <&serdes>;
};
prot@1 {
port-id = 1;
serdes-syscon = <&serdes>;
};
}; };
...@@ -36,6 +36,34 @@ Required properties: ...@@ -36,6 +36,34 @@ Required properties:
| | | | | | | | | | | |
external port external port
This attribute is remained for compatible purpose. It is not recommended to
use it in new code.
- port-idx-in-ae: is the index of port provided by AE.
In NIC mode of DSAF, all 6 PHYs of service DSAF are taken as ethernet ports
to the CPU. The port-idx-in-ae can be 0 to 5. Here is the diagram:
+-----+---------------+
| CPU |
+-+-+-+---+-+-+-+-+-+-+
| | | | | | | |
debug debug service
port port port
(0) (0) (0-5)
In Switch mode of DSAF, all 6 PHYs of service DSAF are taken as physical
ports connected to a LAN Switch while the CPU side assume itself have one
single NIC connected to this switch. In this case, the port-idx-in-ae
will be 0 only.
+-----+-----+------+------+
| CPU |
+-+-+-+-+-+-+-+-+-+-+-+-+-+
| | service| port(0)
debug debug +------------+
port port | switch |
(0) (0) +-+-+-+-+-+-++
| | | | | |
external port
- local-mac-address: mac addr of the ethernet interface - local-mac-address: mac addr of the ethernet interface
Example: Example:
...@@ -43,6 +71,6 @@ Example: ...@@ -43,6 +71,6 @@ Example:
ethernet@0{ ethernet@0{
compatible = "hisilicon,hns-nic-v1"; compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>; ae-handle = <&dsaf0>;
port-id = <0>; port-idx-in-ae = <0>;
local-mac-address = [a2 14 e4 4b 56 76]; local-mac-address = [a2 14 e4 4b 56 76];
}; };
...@@ -28,13 +28,13 @@ dsaf0: dsa@c7000000 { ...@@ -28,13 +28,13 @@ dsaf0: dsa@c7000000 {
mode = "6port-16rss"; mode = "6port-16rss";
interrupt-parent = <&mbigen_dsa>; interrupt-parent = <&mbigen_dsa>;
reg = <0x0 0xC0000000 0x0 0x420000 reg = <0x0 0xc5000000 0x0 0x890000
0x0 0xC2000000 0x0 0x300000
0x0 0xc5000000 0x0 0x890000
0x0 0xc7000000 0x0 0x60000 0x0 0xc7000000 0x0 0x60000
>; >;
phy-handle = <0 0 0 0 &soc0_phy0 &soc0_phy1 0 0>; reg-names = "ppe-base","dsaf-base";
subctrl-syscon = <&dsaf_subctrl>;
reset-field-offset = <0>;
interrupts = < interrupts = <
/* [14] ge fifo err 8 / xge 6**/ /* [14] ge fifo err 8 / xge 6**/
149 0x4 150 0x4 151 0x4 152 0x4 149 0x4 150 0x4 151 0x4 152 0x4
...@@ -122,68 +122,56 @@ dsaf0: dsa@c7000000 { ...@@ -122,68 +122,56 @@ dsaf0: dsa@c7000000 {
buf-size = <4096>; buf-size = <4096>;
desc-num = <1024>; desc-num = <1024>;
dma-coherent; dma-coherent;
};
eth0: ethernet@0{ port@0 {
compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>;
port-id = <0>; port-id = <0>;
local-mac-address = [00 00 00 01 00 58]; serdes-syscon = <&serdes_ctrl0>;
status = "disabled";
dma-coherent;
}; };
eth1: ethernet@1{ port@1 {
compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>;
port-id = <1>; port-id = <1>;
status = "disabled"; serdes-syscon = <&serdes_ctrl0>;
dma-coherent;
}; };
eth2: ethernet@2{ port@4 {
compatible = "hisilicon,hns-nic-v1"; port-id = <4>;
ae-handle = <&dsaf0>; phy-handle = <&soc0_phy0>;
port-id = <2>; serdes-syscon = <&serdes_ctrl1>;
local-mac-address = [00 00 00 01 00 5a]; };
status = "disabled"; port@5 {
dma-coherent; port-id = <5>;
phy-handle = <&soc0_phy1>;
serdes-syscon = <&serdes_ctrl1>;
}; };
eth3: ethernet@3{
compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>;
port-id = <3>;
local-mac-address = [00 00 00 01 00 5b];
status = "disabled";
dma-coherent;
}; };
eth4: ethernet@4{
eth0: ethernet@0{
compatible = "hisilicon,hns-nic-v1"; compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>; ae-handle = <&dsaf0>;
port-id = <4>; port-idx-in-ae = <0>;
local-mac-address = [00 00 00 01 00 5c]; local-mac-address = [00 00 00 01 00 58];
status = "disabled"; status = "disabled";
dma-coherent; dma-coherent;
}; };
eth5: ethernet@5{ eth1: ethernet@1{
compatible = "hisilicon,hns-nic-v1"; compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>; ae-handle = <&dsaf0>;
port-id = <5>; port-idx-in-ae = <1>;
local-mac-address = [00 00 00 01 00 5d]; local-mac-address = [00 00 00 01 00 59];
status = "disabled"; status = "disabled";
dma-coherent; dma-coherent;
}; };
eth6: ethernet@6{ eth2: ethernet@4{
compatible = "hisilicon,hns-nic-v1"; compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>; ae-handle = <&dsaf0>;
port-id = <6>; port-idx-in-ae = <4>;
local-mac-address = [00 00 00 01 00 5e]; local-mac-address = [00 00 00 01 00 5a];
status = "disabled"; status = "disabled";
dma-coherent; dma-coherent;
}; };
eth7: ethernet@7{ eth3: ethernet@5{
compatible = "hisilicon,hns-nic-v1"; compatible = "hisilicon,hns-nic-v1";
ae-handle = <&dsaf0>; ae-handle = <&dsaf0>;
port-id = <7>; port-idx-in-ae = <5>;
local-mac-address = [00 00 00 01 00 5f]; local-mac-address = [00 00 00 01 00 5b];
status = "disabled"; status = "disabled";
dma-coherent; dma-coherent;
}; };
......
...@@ -29,25 +29,6 @@ static struct hns_mac_cb *hns_get_mac_cb(struct hnae_handle *handle) ...@@ -29,25 +29,6 @@ static struct hns_mac_cb *hns_get_mac_cb(struct hnae_handle *handle)
return vf_cb->mac_cb; return vf_cb->mac_cb;
} }
/**
* hns_ae_map_eport_to_dport - translate enet port id to dsaf port id
* @port_id: enet port id
*: debug port 0-1, service port 2 -7 (dsaf mode only 2)
* return: dsaf port id
*: service ports 0 - 5, debug port 6-7
**/
static int hns_ae_map_eport_to_dport(u32 port_id)
{
int port_index;
if (port_id < DSAF_DEBUG_NW_NUM)
port_index = port_id + DSAF_SERVICE_PORT_NUM_PER_DSAF;
else
port_index = port_id - DSAF_DEBUG_NW_NUM;
return port_index;
}
static struct dsaf_device *hns_ae_get_dsaf_dev(struct hnae_ae_dev *dev) static struct dsaf_device *hns_ae_get_dsaf_dev(struct hnae_ae_dev *dev)
{ {
return container_of(dev, struct dsaf_device, ae_dev); return container_of(dev, struct dsaf_device, ae_dev);
...@@ -56,50 +37,35 @@ static struct dsaf_device *hns_ae_get_dsaf_dev(struct hnae_ae_dev *dev) ...@@ -56,50 +37,35 @@ static struct dsaf_device *hns_ae_get_dsaf_dev(struct hnae_ae_dev *dev)
static struct hns_ppe_cb *hns_get_ppe_cb(struct hnae_handle *handle) static struct hns_ppe_cb *hns_get_ppe_cb(struct hnae_handle *handle)
{ {
int ppe_index; int ppe_index;
int ppe_common_index;
struct ppe_common_cb *ppe_comm; struct ppe_common_cb *ppe_comm;
struct hnae_vf_cb *vf_cb = hns_ae_get_vf_cb(handle); struct hnae_vf_cb *vf_cb = hns_ae_get_vf_cb(handle);
if (vf_cb->port_index < DSAF_SERVICE_PORT_NUM_PER_DSAF) { ppe_comm = vf_cb->dsaf_dev->ppe_common[0];
ppe_index = vf_cb->port_index; ppe_index = vf_cb->port_index;
ppe_common_index = 0;
} else {
ppe_index = 0;
ppe_common_index =
vf_cb->port_index - DSAF_SERVICE_PORT_NUM_PER_DSAF + 1;
}
ppe_comm = vf_cb->dsaf_dev->ppe_common[ppe_common_index];
return &ppe_comm->ppe_cb[ppe_index]; return &ppe_comm->ppe_cb[ppe_index];
} }
static int hns_ae_get_q_num_per_vf( static int hns_ae_get_q_num_per_vf(
struct dsaf_device *dsaf_dev, int port) struct dsaf_device *dsaf_dev, int port)
{ {
int common_idx = hns_dsaf_get_comm_idx_by_port(port); return dsaf_dev->rcb_common[0]->max_q_per_vf;
return dsaf_dev->rcb_common[common_idx]->max_q_per_vf;
} }
static int hns_ae_get_vf_num_per_port( static int hns_ae_get_vf_num_per_port(
struct dsaf_device *dsaf_dev, int port) struct dsaf_device *dsaf_dev, int port)
{ {
int common_idx = hns_dsaf_get_comm_idx_by_port(port); return dsaf_dev->rcb_common[0]->max_vfn;
return dsaf_dev->rcb_common[common_idx]->max_vfn;
} }
static struct ring_pair_cb *hns_ae_get_base_ring_pair( static struct ring_pair_cb *hns_ae_get_base_ring_pair(
struct dsaf_device *dsaf_dev, int port) struct dsaf_device *dsaf_dev, int port)
{ {
int common_idx = hns_dsaf_get_comm_idx_by_port(port); struct rcb_common_cb *rcb_comm = dsaf_dev->rcb_common[0];
struct rcb_common_cb *rcb_comm = dsaf_dev->rcb_common[common_idx];
int q_num = rcb_comm->max_q_per_vf; int q_num = rcb_comm->max_q_per_vf;
int vf_num = rcb_comm->max_vfn; int vf_num = rcb_comm->max_vfn;
if (common_idx == HNS_DSAF_COMM_SERVICE_NW_IDX)
return &rcb_comm->ring_pair_cb[port * q_num * vf_num]; return &rcb_comm->ring_pair_cb[port * q_num * vf_num];
else
return &rcb_comm->ring_pair_cb[0];
} }
static struct ring_pair_cb *hns_ae_get_ring_pair(struct hnae_queue *q) static struct ring_pair_cb *hns_ae_get_ring_pair(struct hnae_queue *q)
...@@ -110,7 +76,6 @@ static struct ring_pair_cb *hns_ae_get_ring_pair(struct hnae_queue *q) ...@@ -110,7 +76,6 @@ static struct ring_pair_cb *hns_ae_get_ring_pair(struct hnae_queue *q)
struct hnae_handle *hns_ae_get_handle(struct hnae_ae_dev *dev, struct hnae_handle *hns_ae_get_handle(struct hnae_ae_dev *dev,
u32 port_id) u32 port_id)
{ {
int port_idx;
int vfnum_per_port; int vfnum_per_port;
int qnum_per_vf; int qnum_per_vf;
int i; int i;
...@@ -120,11 +85,10 @@ struct hnae_handle *hns_ae_get_handle(struct hnae_ae_dev *dev, ...@@ -120,11 +85,10 @@ struct hnae_handle *hns_ae_get_handle(struct hnae_ae_dev *dev,
struct hnae_vf_cb *vf_cb; struct hnae_vf_cb *vf_cb;
dsaf_dev = hns_ae_get_dsaf_dev(dev); dsaf_dev = hns_ae_get_dsaf_dev(dev);
port_idx = hns_ae_map_eport_to_dport(port_id);
ring_pair_cb = hns_ae_get_base_ring_pair(dsaf_dev, port_idx); ring_pair_cb = hns_ae_get_base_ring_pair(dsaf_dev, port_id);
vfnum_per_port = hns_ae_get_vf_num_per_port(dsaf_dev, port_idx); vfnum_per_port = hns_ae_get_vf_num_per_port(dsaf_dev, port_id);
qnum_per_vf = hns_ae_get_q_num_per_vf(dsaf_dev, port_idx); qnum_per_vf = hns_ae_get_q_num_per_vf(dsaf_dev, port_id);
vf_cb = kzalloc(sizeof(*vf_cb) + vf_cb = kzalloc(sizeof(*vf_cb) +
qnum_per_vf * sizeof(struct hnae_queue *), GFP_KERNEL); qnum_per_vf * sizeof(struct hnae_queue *), GFP_KERNEL);
...@@ -163,14 +127,14 @@ struct hnae_handle *hns_ae_get_handle(struct hnae_ae_dev *dev, ...@@ -163,14 +127,14 @@ struct hnae_handle *hns_ae_get_handle(struct hnae_ae_dev *dev,
} }
vf_cb->dsaf_dev = dsaf_dev; vf_cb->dsaf_dev = dsaf_dev;
vf_cb->port_index = port_idx; vf_cb->port_index = port_id;
vf_cb->mac_cb = &dsaf_dev->mac_cb[port_idx]; vf_cb->mac_cb = dsaf_dev->mac_cb[port_id];
ae_handle->phy_if = vf_cb->mac_cb->phy_if; ae_handle->phy_if = vf_cb->mac_cb->phy_if;
ae_handle->phy_node = vf_cb->mac_cb->phy_node; ae_handle->phy_node = vf_cb->mac_cb->phy_node;
ae_handle->if_support = vf_cb->mac_cb->if_support; ae_handle->if_support = vf_cb->mac_cb->if_support;
ae_handle->port_type = vf_cb->mac_cb->mac_type; ae_handle->port_type = vf_cb->mac_cb->mac_type;
ae_handle->dport_id = port_idx; ae_handle->dport_id = port_id;
return ae_handle; return ae_handle;
vf_id_err: vf_id_err:
...@@ -320,11 +284,8 @@ static void hns_ae_reset(struct hnae_handle *handle) ...@@ -320,11 +284,8 @@ static void hns_ae_reset(struct hnae_handle *handle)
struct hnae_vf_cb *vf_cb = hns_ae_get_vf_cb(handle); struct hnae_vf_cb *vf_cb = hns_ae_get_vf_cb(handle);
if (vf_cb->mac_cb->mac_type == HNAE_PORT_DEBUG) { if (vf_cb->mac_cb->mac_type == HNAE_PORT_DEBUG) {
u8 ppe_common_index =
vf_cb->port_index - DSAF_SERVICE_PORT_NUM_PER_DSAF + 1;
hns_mac_reset(vf_cb->mac_cb); hns_mac_reset(vf_cb->mac_cb);
hns_ppe_reset_common(vf_cb->dsaf_dev, ppe_common_index); hns_ppe_reset_common(vf_cb->dsaf_dev, 0);
} }
} }
...@@ -703,7 +664,7 @@ void hns_ae_update_led_status(struct hnae_handle *handle) ...@@ -703,7 +664,7 @@ void hns_ae_update_led_status(struct hnae_handle *handle)
assert(handle); assert(handle);
mac_cb = hns_get_mac_cb(handle); mac_cb = hns_get_mac_cb(handle);
if (!mac_cb->cpld_vaddr) if (!mac_cb->cpld_ctrl)
return; return;
hns_set_led_opt(mac_cb); hns_set_led_opt(mac_cb);
} }
...@@ -723,7 +684,6 @@ int hns_ae_cpld_set_led_id(struct hnae_handle *handle, ...@@ -723,7 +684,6 @@ int hns_ae_cpld_set_led_id(struct hnae_handle *handle,
void hns_ae_get_regs(struct hnae_handle *handle, void *data) void hns_ae_get_regs(struct hnae_handle *handle, void *data)
{ {
u32 *p = data; u32 *p = data;
u32 rcb_com_idx;
int i; int i;
struct hnae_vf_cb *vf_cb = hns_ae_get_vf_cb(handle); struct hnae_vf_cb *vf_cb = hns_ae_get_vf_cb(handle);
struct hns_ppe_cb *ppe_cb = hns_get_ppe_cb(handle); struct hns_ppe_cb *ppe_cb = hns_get_ppe_cb(handle);
...@@ -731,8 +691,7 @@ void hns_ae_get_regs(struct hnae_handle *handle, void *data) ...@@ -731,8 +691,7 @@ void hns_ae_get_regs(struct hnae_handle *handle, void *data)
hns_ppe_get_regs(ppe_cb, p); hns_ppe_get_regs(ppe_cb, p);
p += hns_ppe_get_regs_count(); p += hns_ppe_get_regs_count();
rcb_com_idx = hns_dsaf_get_comm_idx_by_port(vf_cb->port_index); hns_rcb_get_common_regs(vf_cb->dsaf_dev->rcb_common[0], p);
hns_rcb_get_common_regs(vf_cb->dsaf_dev->rcb_common[rcb_com_idx], p);
p += hns_rcb_get_common_regs_count(); p += hns_rcb_get_common_regs_count();
for (i = 0; i < handle->q_num; i++) { for (i = 0; i < handle->q_num; i++) {
......
...@@ -10,9 +10,10 @@ ...@@ -10,9 +10,10 @@
#ifndef _HNS_DSAF_MAC_H #ifndef _HNS_DSAF_MAC_H
#define _HNS_DSAF_MAC_H #define _HNS_DSAF_MAC_H
#include <linux/phy.h>
#include <linux/kernel.h>
#include <linux/if_vlan.h> #include <linux/if_vlan.h>
#include <linux/kernel.h>
#include <linux/phy.h>
#include <linux/regmap.h>
#include "hns_dsaf_main.h" #include "hns_dsaf_main.h"
struct dsaf_device; struct dsaf_device;
...@@ -310,10 +311,15 @@ struct hns_mac_cb { ...@@ -310,10 +311,15 @@ struct hns_mac_cb {
struct device *dev; struct device *dev;
struct dsaf_device *dsaf_dev; struct dsaf_device *dsaf_dev;
struct mac_priv priv; struct mac_priv priv;
struct fwnode_handle *fw_port;
u8 __iomem *vaddr; u8 __iomem *vaddr;
u8 __iomem *cpld_vaddr;
u8 __iomem *sys_ctl_vaddr; u8 __iomem *sys_ctl_vaddr;
u8 __iomem *serdes_vaddr; u8 __iomem *serdes_vaddr;
struct regmap *serdes_ctrl;
struct regmap *cpld_ctrl;
u32 cpld_ctrl_reg;
u32 port_rst_off;
u32 port_mode_off;
struct mac_entry_idx addr_entry_idx[DSAF_MAX_VM_NUM]; struct mac_entry_idx addr_entry_idx[DSAF_MAX_VM_NUM];
u8 sfp_prsnt; u8 sfp_prsnt;
u8 cpld_led_value; u8 cpld_led_value;
......
...@@ -7,27 +7,29 @@ ...@@ -7,27 +7,29 @@
* (at your option) any later version. * (at your option) any later version.
*/ */
#include <linux/module.h> #include <linux/device.h>
#include <linux/kernel.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/netdevice.h> #include <linux/netdevice.h>
#include <linux/platform_device.h> #include <linux/mfd/syscon.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <linux/of_irq.h> #include <linux/of_irq.h>
#include <linux/device.h> #include <linux/platform_device.h>
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
#include "hns_dsaf_mac.h"
#include "hns_dsaf_main.h" #include "hns_dsaf_main.h"
#include "hns_dsaf_rcb.h"
#include "hns_dsaf_ppe.h" #include "hns_dsaf_ppe.h"
#include "hns_dsaf_mac.h" #include "hns_dsaf_rcb.h"
const char *g_dsaf_mode_match[DSAF_MODE_MAX] = { const char *g_dsaf_mode_match[DSAF_MODE_MAX] = {
[DSAF_MODE_DISABLE_2PORT_64VM] = "2port-64vf", [DSAF_MODE_DISABLE_2PORT_64VM] = "2port-64vf",
[DSAF_MODE_DISABLE_6PORT_0VM] = "6port-16rss", [DSAF_MODE_DISABLE_6PORT_0VM] = "6port-16rss",
[DSAF_MODE_DISABLE_6PORT_16VM] = "6port-16vf", [DSAF_MODE_DISABLE_6PORT_16VM] = "6port-16vf",
[DSAF_MODE_DISABLE_SP] = "single-port",
}; };
int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev) int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev)
...@@ -35,8 +37,13 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev) ...@@ -35,8 +37,13 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev)
int ret, i; int ret, i;
u32 desc_num; u32 desc_num;
u32 buf_size; u32 buf_size;
u32 reset_offset = 0;
u32 res_idx = 0;
const char *mode_str; const char *mode_str;
struct regmap *syscon;
struct resource *res;
struct device_node *np = dsaf_dev->dev->of_node; struct device_node *np = dsaf_dev->dev->of_node;
struct platform_device *pdev = to_platform_device(dsaf_dev->dev);
if (of_device_is_compatible(np, "hisilicon,hns-dsaf-v1")) if (of_device_is_compatible(np, "hisilicon,hns-dsaf-v1"))
dsaf_dev->dsaf_ver = AE_VERSION_1; dsaf_dev->dsaf_ver = AE_VERSION_1;
...@@ -73,41 +80,67 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev) ...@@ -73,41 +80,67 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev)
else else
dsaf_dev->dsaf_tc_mode = HRD_DSAF_4TC_MODE; dsaf_dev->dsaf_tc_mode = HRD_DSAF_4TC_MODE;
dsaf_dev->sc_base = of_iomap(np, 0); syscon = syscon_node_to_regmap(
of_parse_phandle(np, "subctrl-syscon", 0));
if (IS_ERR_OR_NULL(syscon)) {
res = platform_get_resource(pdev, IORESOURCE_MEM, res_idx++);
if (!res) {
dev_err(dsaf_dev->dev, "subctrl info is needed!\n");
return -ENOMEM;
}
dsaf_dev->sc_base = devm_ioremap_resource(&pdev->dev, res);
if (!dsaf_dev->sc_base) { if (!dsaf_dev->sc_base) {
dev_err(dsaf_dev->dev, dev_err(dsaf_dev->dev, "subctrl can not map!\n");
"%s of_iomap 0 fail!\n", dsaf_dev->ae_dev.name); return -ENOMEM;
ret = -ENOMEM;
goto unmap_base_addr;
} }
dsaf_dev->sds_base = of_iomap(np, 1); res = platform_get_resource(pdev, IORESOURCE_MEM, res_idx++);
if (!res) {
dev_err(dsaf_dev->dev, "serdes-ctrl info is needed!\n");
return -ENOMEM;
}
dsaf_dev->sds_base = devm_ioremap_resource(&pdev->dev, res);
if (!dsaf_dev->sds_base) { if (!dsaf_dev->sds_base) {
dev_err(dsaf_dev->dev, dev_err(dsaf_dev->dev, "serdes-ctrl can not map!\n");
"%s of_iomap 1 fail!\n", dsaf_dev->ae_dev.name); return -ENOMEM;
ret = -ENOMEM; }
goto unmap_base_addr; } else {
dsaf_dev->sub_ctrl = syscon;
} }
dsaf_dev->ppe_base = of_iomap(np, 2); res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "ppe-base");
if (!res) {
res = platform_get_resource(pdev, IORESOURCE_MEM, res_idx++);
if (!res) {
dev_err(dsaf_dev->dev, "ppe-base info is needed!\n");
return -ENOMEM;
}
}
dsaf_dev->ppe_base = devm_ioremap_resource(&pdev->dev, res);
if (!dsaf_dev->ppe_base) { if (!dsaf_dev->ppe_base) {
dev_err(dsaf_dev->dev, "ppe-base resource can not map!\n");
return -ENOMEM;
}
dsaf_dev->ppe_paddr = res->start;
if (!HNS_DSAF_IS_DEBUG(dsaf_dev)) {
res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
"dsaf-base");
if (!res) {
res = platform_get_resource(pdev, IORESOURCE_MEM,
res_idx);
if (!res) {
dev_err(dsaf_dev->dev, dev_err(dsaf_dev->dev,
"%s of_iomap 2 fail!\n", dsaf_dev->ae_dev.name); "dsaf-base info is needed!\n");
ret = -ENOMEM; return -ENOMEM;
goto unmap_base_addr;
} }
}
dsaf_dev->io_base = of_iomap(np, 3); dsaf_dev->io_base = devm_ioremap_resource(&pdev->dev, res);
if (!dsaf_dev->io_base) { if (!dsaf_dev->io_base) {
dev_err(dsaf_dev->dev, dev_err(dsaf_dev->dev, "dsaf-base resource can not map!\n");
"%s of_iomap 3 fail!\n", dsaf_dev->ae_dev.name); return -ENOMEM;
ret = -ENOMEM; }
goto unmap_base_addr;
} }
dsaf_dev->cpld_base = of_iomap(np, 4);
if (!dsaf_dev->cpld_base)
dev_dbg(dsaf_dev->dev, "NO CPLD ADDR");
ret = of_property_read_u32(np, "desc-num", &desc_num); ret = of_property_read_u32(np, "desc-num", &desc_num);
if (ret < 0 || desc_num < HNS_DSAF_MIN_DESC_CNT || if (ret < 0 || desc_num < HNS_DSAF_MIN_DESC_CNT ||
...@@ -118,6 +151,13 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev) ...@@ -118,6 +151,13 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev)
} }
dsaf_dev->desc_num = desc_num; dsaf_dev->desc_num = desc_num;
ret = of_property_read_u32(np, "reset-field-offset", &reset_offset);
if (ret < 0) {
dev_dbg(dsaf_dev->dev,
"get reset-field-offset fail, ret=%d!\r\n", ret);
}
dsaf_dev->reset_offset = reset_offset;
ret = of_property_read_u32(np, "buf-size", &buf_size); ret = of_property_read_u32(np, "buf-size", &buf_size);
if (ret < 0) { if (ret < 0) {
dev_err(dsaf_dev->dev, dev_err(dsaf_dev->dev,
...@@ -149,8 +189,6 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev) ...@@ -149,8 +189,6 @@ int hns_dsaf_get_cfg(struct dsaf_device *dsaf_dev)
iounmap(dsaf_dev->sds_base); iounmap(dsaf_dev->sds_base);
if (dsaf_dev->sc_base) if (dsaf_dev->sc_base)
iounmap(dsaf_dev->sc_base); iounmap(dsaf_dev->sc_base);
if (dsaf_dev->cpld_base)
iounmap(dsaf_dev->cpld_base);
return ret; return ret;
} }
...@@ -167,9 +205,6 @@ static void hns_dsaf_free_cfg(struct dsaf_device *dsaf_dev) ...@@ -167,9 +205,6 @@ static void hns_dsaf_free_cfg(struct dsaf_device *dsaf_dev)
if (dsaf_dev->sc_base) if (dsaf_dev->sc_base)
iounmap(dsaf_dev->sc_base); iounmap(dsaf_dev->sc_base);
if (dsaf_dev->cpld_base)
iounmap(dsaf_dev->cpld_base);
} }
/** /**
...@@ -217,9 +252,7 @@ static void hns_dsaf_mix_def_qid_cfg(struct dsaf_device *dsaf_dev) ...@@ -217,9 +252,7 @@ static void hns_dsaf_mix_def_qid_cfg(struct dsaf_device *dsaf_dev)
u32 q_id, q_num_per_port; u32 q_id, q_num_per_port;
u32 i; u32 i;
hns_rcb_get_queue_mode(dsaf_dev->dsaf_mode, hns_rcb_get_queue_mode(dsaf_dev->dsaf_mode, &max_vfn, &max_q_per_vf);
HNS_DSAF_COMM_SERVICE_NW_IDX,
&max_vfn, &max_q_per_vf);
q_num_per_port = max_vfn * max_q_per_vf; q_num_per_port = max_vfn * max_q_per_vf;
for (i = 0, q_id = 0; i < DSAF_SERVICE_NW_NUM; i++) { for (i = 0, q_id = 0; i < DSAF_SERVICE_NW_NUM; i++) {
...@@ -239,9 +272,7 @@ static void hns_dsaf_inner_qid_cfg(struct dsaf_device *dsaf_dev) ...@@ -239,9 +272,7 @@ static void hns_dsaf_inner_qid_cfg(struct dsaf_device *dsaf_dev)
if (AE_IS_VER1(dsaf_dev->dsaf_ver)) if (AE_IS_VER1(dsaf_dev->dsaf_ver))
return; return;
hns_rcb_get_queue_mode(dsaf_dev->dsaf_mode, hns_rcb_get_queue_mode(dsaf_dev->dsaf_mode, &max_vfn, &max_q_per_vf);
HNS_DSAF_COMM_SERVICE_NW_IDX,
&max_vfn, &max_q_per_vf);
q_num_per_port = max_vfn * max_q_per_vf; q_num_per_port = max_vfn * max_q_per_vf;
for (mac_id = 0, q_id = 0; mac_id < DSAF_SERVICE_NW_NUM; mac_id++) { for (mac_id = 0, q_id = 0; mac_id < DSAF_SERVICE_NW_NUM; mac_id++) {
...@@ -712,13 +743,15 @@ static void hns_dsaf_tbl_tcam_data_ucast_pul( ...@@ -712,13 +743,15 @@ static void hns_dsaf_tbl_tcam_data_ucast_pul(
void hns_dsaf_set_promisc_mode(struct dsaf_device *dsaf_dev, u32 en) void hns_dsaf_set_promisc_mode(struct dsaf_device *dsaf_dev, u32 en)
{ {
dsaf_set_dev_bit(dsaf_dev, DSAF_CFG_0_REG, DSAF_CFG_MIX_MODE_S, !!en); if (!HNS_DSAF_IS_DEBUG(dsaf_dev))
dsaf_set_dev_bit(dsaf_dev, DSAF_CFG_0_REG,
DSAF_CFG_MIX_MODE_S, !!en);
} }
void hns_dsaf_set_inner_lb(struct dsaf_device *dsaf_dev, u32 mac_id, u32 en) void hns_dsaf_set_inner_lb(struct dsaf_device *dsaf_dev, u32 mac_id, u32 en)
{ {
if (AE_IS_VER1(dsaf_dev->dsaf_ver) || if (AE_IS_VER1(dsaf_dev->dsaf_ver) ||
dsaf_dev->mac_cb[mac_id].mac_type == HNAE_PORT_DEBUG) dsaf_dev->mac_cb[mac_id]->mac_type == HNAE_PORT_DEBUG)
return; return;
dsaf_set_dev_bit(dsaf_dev, DSAFV2_SERDES_LBK_0_REG + 4 * mac_id, dsaf_set_dev_bit(dsaf_dev, DSAFV2_SERDES_LBK_0_REG + 4 * mac_id,
...@@ -1307,6 +1340,9 @@ static int hns_dsaf_init(struct dsaf_device *dsaf_dev) ...@@ -1307,6 +1340,9 @@ static int hns_dsaf_init(struct dsaf_device *dsaf_dev)
u32 i; u32 i;
int ret; int ret;
if (HNS_DSAF_IS_DEBUG(dsaf_dev))
return 0;
ret = hns_dsaf_init_hw(dsaf_dev); ret = hns_dsaf_init_hw(dsaf_dev);
if (ret) if (ret)
return ret; return ret;
......
...@@ -41,6 +41,7 @@ struct hns_mac_cb; ...@@ -41,6 +41,7 @@ struct hns_mac_cb;
#define DSAF_STATIC_NUM 28 #define DSAF_STATIC_NUM 28
#define DSAF_STATS_READ(p, offset) (*((u64 *)((u8 *)(p) + (offset)))) #define DSAF_STATS_READ(p, offset) (*((u64 *)((u8 *)(p) + (offset))))
#define HNS_DSAF_IS_DEBUG(dev) (dev->dsaf_mode == DSAF_MODE_DISABLE_SP)
enum hal_dsaf_mode { enum hal_dsaf_mode {
HRD_DSAF_NO_DSAF_MODE = 0x0, HRD_DSAF_NO_DSAF_MODE = 0x0,
...@@ -117,6 +118,7 @@ enum dsaf_mode { ...@@ -117,6 +118,7 @@ enum dsaf_mode {
DSAF_MODE_ENABLE_32VM, /**< en DSAF-mode, support 32 VM */ DSAF_MODE_ENABLE_32VM, /**< en DSAF-mode, support 32 VM */
DSAF_MODE_ENABLE_128VM, /**< en DSAF-mode, support 128 VM */ DSAF_MODE_ENABLE_128VM, /**< en DSAF-mode, support 128 VM */
DSAF_MODE_ENABLE, /**< before is enable DSAF mode*/ DSAF_MODE_ENABLE, /**< before is enable DSAF mode*/
DSAF_MODE_DISABLE_SP, /* <non-dsaf, single port mode */
DSAF_MODE_DISABLE_FIX, /**< non-dasf, fixed to queue*/ DSAF_MODE_DISABLE_FIX, /**< non-dasf, fixed to queue*/
DSAF_MODE_DISABLE_2PORT_8VM, /**< non-dasf, 2port 8VM */ DSAF_MODE_DISABLE_2PORT_8VM, /**< non-dasf, 2port 8VM */
DSAF_MODE_DISABLE_2PORT_16VM, /**< non-dasf, 2port 16VM */ DSAF_MODE_DISABLE_2PORT_16VM, /**< non-dasf, 2port 16VM */
...@@ -275,10 +277,12 @@ struct dsaf_device { ...@@ -275,10 +277,12 @@ struct dsaf_device {
u8 __iomem *sds_base; u8 __iomem *sds_base;
u8 __iomem *ppe_base; u8 __iomem *ppe_base;
u8 __iomem *io_base; u8 __iomem *io_base;
u8 __iomem *cpld_base; struct regmap *sub_ctrl;
phys_addr_t ppe_paddr;
u32 desc_num; /* desc num per queue*/ u32 desc_num; /* desc num per queue*/
u32 buf_size; /* ring buffer size */ u32 buf_size; /* ring buffer size */
u32 reset_offset; /* reset field offset in sub sysctrl */
int buf_size_type; /* ring buffer size-type */ int buf_size_type; /* ring buffer size-type */
enum dsaf_mode dsaf_mode; /* dsaf mode */ enum dsaf_mode dsaf_mode; /* dsaf mode */
enum hal_dsaf_mode dsaf_en; enum hal_dsaf_mode dsaf_en;
...@@ -287,7 +291,7 @@ struct dsaf_device { ...@@ -287,7 +291,7 @@ struct dsaf_device {
struct ppe_common_cb *ppe_common[DSAF_COMM_DEV_NUM]; struct ppe_common_cb *ppe_common[DSAF_COMM_DEV_NUM];
struct rcb_common_cb *rcb_common[DSAF_COMM_DEV_NUM]; struct rcb_common_cb *rcb_common[DSAF_COMM_DEV_NUM];
struct hns_mac_cb *mac_cb; struct hns_mac_cb *mac_cb[DSAF_MAX_PORT_NUM];
struct dsaf_hw_stats hw_stats[DSAF_NODE_NUM]; struct dsaf_hw_stats hw_stats[DSAF_NODE_NUM];
struct dsaf_int_stat int_stat; struct dsaf_int_stat int_stat;
...@@ -359,14 +363,6 @@ static inline void hns_dsaf_tbl_line_addr_cfg(struct dsaf_device *dsaf_dev, ...@@ -359,14 +363,6 @@ static inline void hns_dsaf_tbl_line_addr_cfg(struct dsaf_device *dsaf_dev,
tab_line_addr); tab_line_addr);
} }
static inline int hns_dsaf_get_comm_idx_by_port(int port)
{
if ((port < DSAF_COMM_CHN) || (port == DSAF_MAX_PORT_NUM_PER_CHIP))
return 0;
else
return (port - DSAF_COMM_CHN + 1);
}
static inline struct hnae_vf_cb *hns_ae_get_vf_cb( static inline struct hnae_vf_cb *hns_ae_get_vf_cb(
struct hnae_handle *handle) struct hnae_handle *handle)
{ {
......
...@@ -61,22 +61,10 @@ void hns_ppe_set_indir_table(struct hns_ppe_cb *ppe_cb, ...@@ -61,22 +61,10 @@ void hns_ppe_set_indir_table(struct hns_ppe_cb *ppe_cb,
} }
} }
static void __iomem *hns_ppe_common_get_ioaddr( static void __iomem *
struct ppe_common_cb *ppe_common) hns_ppe_common_get_ioaddr(struct ppe_common_cb *ppe_common)
{ {
void __iomem *base_addr; return ppe_common->dsaf_dev->ppe_base + PPE_COMMON_REG_OFFSET;
int idx = ppe_common->comm_index;
if (idx == HNS_DSAF_COMM_SERVICE_NW_IDX)
base_addr = ppe_common->dsaf_dev->ppe_base
+ PPE_COMMON_REG_OFFSET;
else
base_addr = ppe_common->dsaf_dev->sds_base
+ (idx - 1) * HNS_DSAF_DEBUG_NW_REG_OFFSET
+ PPE_COMMON_REG_OFFSET;
return base_addr;
} }
/** /**
...@@ -90,7 +78,7 @@ int hns_ppe_common_get_cfg(struct dsaf_device *dsaf_dev, int comm_index) ...@@ -90,7 +78,7 @@ int hns_ppe_common_get_cfg(struct dsaf_device *dsaf_dev, int comm_index)
struct ppe_common_cb *ppe_common; struct ppe_common_cb *ppe_common;
int ppe_num; int ppe_num;
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) if (!HNS_DSAF_IS_DEBUG(dsaf_dev))
ppe_num = HNS_PPE_SERVICE_NW_ENGINE_NUM; ppe_num = HNS_PPE_SERVICE_NW_ENGINE_NUM;
else else
ppe_num = HNS_PPE_DEBUG_NW_ENGINE_NUM; ppe_num = HNS_PPE_DEBUG_NW_ENGINE_NUM;
...@@ -103,7 +91,7 @@ int hns_ppe_common_get_cfg(struct dsaf_device *dsaf_dev, int comm_index) ...@@ -103,7 +91,7 @@ int hns_ppe_common_get_cfg(struct dsaf_device *dsaf_dev, int comm_index)
ppe_common->ppe_num = ppe_num; ppe_common->ppe_num = ppe_num;
ppe_common->dsaf_dev = dsaf_dev; ppe_common->dsaf_dev = dsaf_dev;
ppe_common->comm_index = comm_index; ppe_common->comm_index = comm_index;
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) if (!HNS_DSAF_IS_DEBUG(dsaf_dev))
ppe_common->ppe_mode = PPE_COMMON_MODE_SERVICE; ppe_common->ppe_mode = PPE_COMMON_MODE_SERVICE;
else else
ppe_common->ppe_mode = PPE_COMMON_MODE_DEBUG; ppe_common->ppe_mode = PPE_COMMON_MODE_DEBUG;
...@@ -124,32 +112,8 @@ void hns_ppe_common_free_cfg(struct dsaf_device *dsaf_dev, u32 comm_index) ...@@ -124,32 +112,8 @@ void hns_ppe_common_free_cfg(struct dsaf_device *dsaf_dev, u32 comm_index)
static void __iomem *hns_ppe_get_iobase(struct ppe_common_cb *ppe_common, static void __iomem *hns_ppe_get_iobase(struct ppe_common_cb *ppe_common,
int ppe_idx) int ppe_idx)
{ {
void __iomem *base_addr;
int common_idx = ppe_common->comm_index;
if (ppe_common->ppe_mode == PPE_COMMON_MODE_SERVICE) {
base_addr = ppe_common->dsaf_dev->ppe_base +
ppe_idx * PPE_REG_OFFSET;
} else {
base_addr = ppe_common->dsaf_dev->sds_base +
(common_idx - 1) * HNS_DSAF_DEBUG_NW_REG_OFFSET;
}
return base_addr; return ppe_common->dsaf_dev->ppe_base + ppe_idx * PPE_REG_OFFSET;
}
static int hns_ppe_get_port(struct ppe_common_cb *ppe_common, int idx)
{
int port;
if (ppe_common->ppe_mode == PPE_COMMON_MODE_SERVICE)
port = idx;
else
port = HNS_PPE_SERVICE_NW_ENGINE_NUM
+ ppe_common->comm_index - 1;
return port;
} }
static void hns_ppe_get_cfg(struct ppe_common_cb *ppe_common) static void hns_ppe_get_cfg(struct ppe_common_cb *ppe_common)
...@@ -164,7 +128,6 @@ static void hns_ppe_get_cfg(struct ppe_common_cb *ppe_common) ...@@ -164,7 +128,6 @@ static void hns_ppe_get_cfg(struct ppe_common_cb *ppe_common)
ppe_cb->next = NULL; ppe_cb->next = NULL;
ppe_cb->ppe_common_cb = ppe_common; ppe_cb->ppe_common_cb = ppe_common;
ppe_cb->index = i; ppe_cb->index = i;
ppe_cb->port = hns_ppe_get_port(ppe_common, i);
ppe_cb->io_base = hns_ppe_get_iobase(ppe_common, i); ppe_cb->io_base = hns_ppe_get_iobase(ppe_common, i);
ppe_cb->virq = 0; ppe_cb->virq = 0;
} }
...@@ -318,7 +281,7 @@ static void hns_ppe_exc_irq_en(struct hns_ppe_cb *ppe_cb, int en) ...@@ -318,7 +281,7 @@ static void hns_ppe_exc_irq_en(struct hns_ppe_cb *ppe_cb, int en)
static void hns_ppe_init_hw(struct hns_ppe_cb *ppe_cb) static void hns_ppe_init_hw(struct hns_ppe_cb *ppe_cb)
{ {
struct ppe_common_cb *ppe_common_cb = ppe_cb->ppe_common_cb; struct ppe_common_cb *ppe_common_cb = ppe_cb->ppe_common_cb;
u32 port = ppe_cb->port; u32 port = ppe_cb->index;
struct dsaf_device *dsaf_dev = ppe_common_cb->dsaf_dev; struct dsaf_device *dsaf_dev = ppe_common_cb->dsaf_dev;
int i; int i;
...@@ -377,6 +340,7 @@ void hns_ppe_uninit_ex(struct ppe_common_cb *ppe_common) ...@@ -377,6 +340,7 @@ void hns_ppe_uninit_ex(struct ppe_common_cb *ppe_common)
u32 i; u32 i;
for (i = 0; i < ppe_common->ppe_num; i++) { for (i = 0; i < ppe_common->ppe_num; i++) {
if (ppe_common->dsaf_dev->mac_cb[i])
hns_ppe_uninit_hw(&ppe_common->ppe_cb[i]); hns_ppe_uninit_hw(&ppe_common->ppe_cb[i]);
memset(&ppe_common->ppe_cb[i], 0, sizeof(struct hns_ppe_cb)); memset(&ppe_common->ppe_cb[i], 0, sizeof(struct hns_ppe_cb));
} }
...@@ -410,8 +374,11 @@ void hns_ppe_reset_common(struct dsaf_device *dsaf_dev, u8 ppe_common_index) ...@@ -410,8 +374,11 @@ void hns_ppe_reset_common(struct dsaf_device *dsaf_dev, u8 ppe_common_index)
if (ret) if (ret)
return; return;
for (i = 0; i < ppe_common->ppe_num; i++) for (i = 0; i < ppe_common->ppe_num; i++) {
/* We only need to initiate ppe when the port exists */
if (dsaf_dev->mac_cb[i])
hns_ppe_init_hw(&ppe_common->ppe_cb[i]); hns_ppe_init_hw(&ppe_common->ppe_cb[i]);
}
ret = hns_rcb_common_init_hw(dsaf_dev->rcb_common[ppe_common_index]); ret = hns_rcb_common_init_hw(dsaf_dev->rcb_common[ppe_common_index]);
if (ret) if (ret)
......
...@@ -80,7 +80,6 @@ struct hns_ppe_cb { ...@@ -80,7 +80,6 @@ struct hns_ppe_cb {
struct hns_ppe_hw_stats hw_stats; struct hns_ppe_hw_stats hw_stats;
u8 index; /* index in a ppe common device */ u8 index; /* index in a ppe common device */
u8 port; /* port id in dsaf */
void __iomem *io_base; void __iomem *io_base;
int virq; int virq;
u32 rss_indir_table[HNS_PPEV2_RSS_IND_TBL_SIZE]; /*shadow indir tab */ u32 rss_indir_table[HNS_PPEV2_RSS_IND_TBL_SIZE]; /*shadow indir tab */
......
...@@ -270,7 +270,7 @@ static void hns_rcb_set_port_timeout( ...@@ -270,7 +270,7 @@ static void hns_rcb_set_port_timeout(
static int hns_rcb_common_get_port_num(struct rcb_common_cb *rcb_common) static int hns_rcb_common_get_port_num(struct rcb_common_cb *rcb_common)
{ {
if (rcb_common->comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) if (!HNS_DSAF_IS_DEBUG(rcb_common->dsaf_dev))
return HNS_RCB_SERVICE_NW_ENGINE_NUM; return HNS_RCB_SERVICE_NW_ENGINE_NUM;
else else
return HNS_RCB_DEBUG_NW_ENGINE_NUM; return HNS_RCB_DEBUG_NW_ENGINE_NUM;
...@@ -430,36 +430,20 @@ static void hns_rcb_ring_pair_get_cfg(struct ring_pair_cb *ring_pair_cb) ...@@ -430,36 +430,20 @@ static void hns_rcb_ring_pair_get_cfg(struct ring_pair_cb *ring_pair_cb)
static int hns_rcb_get_port_in_comm( static int hns_rcb_get_port_in_comm(
struct rcb_common_cb *rcb_common, int ring_idx) struct rcb_common_cb *rcb_common, int ring_idx)
{ {
int comm_index = rcb_common->comm_index;
int port;
int q_num;
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) { return ring_idx / (rcb_common->max_q_per_vf * rcb_common->max_vfn);
q_num = (int)rcb_common->max_q_per_vf * rcb_common->max_vfn;
port = ring_idx / q_num;
} else {
port = 0; /* config debug-ports port_id_in_comm to 0*/
}
return port;
} }
#define SERVICE_RING_IRQ_IDX(v1) \ #define SERVICE_RING_IRQ_IDX(v1) \
((v1) ? HNS_SERVICE_RING_IRQ_IDX : HNSV2_SERVICE_RING_IRQ_IDX) ((v1) ? HNS_SERVICE_RING_IRQ_IDX : HNSV2_SERVICE_RING_IRQ_IDX)
#define DEBUG_RING_IRQ_IDX(v1) \
((v1) ? HNS_DEBUG_RING_IRQ_IDX : HNSV2_DEBUG_RING_IRQ_IDX)
#define DEBUG_RING_IRQ_OFFSET(v1) \
((v1) ? HNS_DEBUG_RING_IRQ_OFFSET : HNSV2_DEBUG_RING_IRQ_OFFSET)
static int hns_rcb_get_base_irq_idx(struct rcb_common_cb *rcb_common) static int hns_rcb_get_base_irq_idx(struct rcb_common_cb *rcb_common)
{ {
int comm_index = rcb_common->comm_index;
bool is_ver1 = AE_IS_VER1(rcb_common->dsaf_dev->dsaf_ver); bool is_ver1 = AE_IS_VER1(rcb_common->dsaf_dev->dsaf_ver);
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) if (!HNS_DSAF_IS_DEBUG(rcb_common->dsaf_dev))
return SERVICE_RING_IRQ_IDX(is_ver1); return SERVICE_RING_IRQ_IDX(is_ver1);
else else
return DEBUG_RING_IRQ_IDX(is_ver1) + return HNS_DEBUG_RING_IRQ_IDX;
(comm_index - 1) * DEBUG_RING_IRQ_OFFSET(is_ver1);
} }
#define RCB_COMM_BASE_TO_RING_BASE(base, ringid)\ #define RCB_COMM_BASE_TO_RING_BASE(base, ringid)\
...@@ -549,7 +533,7 @@ int hns_rcb_set_coalesce_usecs( ...@@ -549,7 +533,7 @@ int hns_rcb_set_coalesce_usecs(
return 0; return 0;
if (AE_IS_VER1(rcb_common->dsaf_dev->dsaf_ver)) { if (AE_IS_VER1(rcb_common->dsaf_dev->dsaf_ver)) {
if (rcb_common->comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) { if (!HNS_DSAF_IS_DEBUG(rcb_common->dsaf_dev)) {
dev_err(rcb_common->dsaf_dev->dev, dev_err(rcb_common->dsaf_dev->dev,
"error: not support coalesce_usecs setting!\n"); "error: not support coalesce_usecs setting!\n");
return -EINVAL; return -EINVAL;
...@@ -601,16 +585,16 @@ int hns_rcb_set_coalesced_frames( ...@@ -601,16 +585,16 @@ int hns_rcb_set_coalesced_frames(
*@max_vfn : max vfn number *@max_vfn : max vfn number
*@max_q_per_vf:max ring number per vm *@max_q_per_vf:max ring number per vm
*/ */
void hns_rcb_get_queue_mode(enum dsaf_mode dsaf_mode, int comm_index, void hns_rcb_get_queue_mode(enum dsaf_mode dsaf_mode, u16 *max_vfn,
u16 *max_vfn, u16 *max_q_per_vf) u16 *max_q_per_vf)
{ {
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) {
switch (dsaf_mode) { switch (dsaf_mode) {
case DSAF_MODE_DISABLE_6PORT_0VM: case DSAF_MODE_DISABLE_6PORT_0VM:
*max_vfn = 1; *max_vfn = 1;
*max_q_per_vf = 16; *max_q_per_vf = 16;
break; break;
case DSAF_MODE_DISABLE_FIX: case DSAF_MODE_DISABLE_FIX:
case DSAF_MODE_DISABLE_SP:
*max_vfn = 1; *max_vfn = 1;
*max_q_per_vf = 1; *max_q_per_vf = 1;
break; break;
...@@ -627,17 +611,13 @@ void hns_rcb_get_queue_mode(enum dsaf_mode dsaf_mode, int comm_index, ...@@ -627,17 +611,13 @@ void hns_rcb_get_queue_mode(enum dsaf_mode dsaf_mode, int comm_index,
*max_q_per_vf = 16; *max_q_per_vf = 16;
break; break;
} }
} else {
*max_vfn = 1;
*max_q_per_vf = 1;
}
} }
int hns_rcb_get_ring_num(struct dsaf_device *dsaf_dev, int comm_index) int hns_rcb_get_ring_num(struct dsaf_device *dsaf_dev)
{ {
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) {
switch (dsaf_dev->dsaf_mode) { switch (dsaf_dev->dsaf_mode) {
case DSAF_MODE_ENABLE_FIX: case DSAF_MODE_ENABLE_FIX:
case DSAF_MODE_DISABLE_SP:
return 1; return 1;
case DSAF_MODE_DISABLE_FIX: case DSAF_MODE_DISABLE_FIX:
...@@ -667,47 +647,20 @@ int hns_rcb_get_ring_num(struct dsaf_device *dsaf_dev, int comm_index) ...@@ -667,47 +647,20 @@ int hns_rcb_get_ring_num(struct dsaf_device *dsaf_dev, int comm_index)
dsaf_dev->dsaf_mode); dsaf_dev->dsaf_mode);
return 128; return 128;
} }
} else {
return 1;
}
} }
void __iomem *hns_rcb_common_get_vaddr(struct dsaf_device *dsaf_dev, void __iomem *hns_rcb_common_get_vaddr(struct rcb_common_cb *rcb_common)
int comm_index)
{ {
void __iomem *base_addr; struct dsaf_device *dsaf_dev = rcb_common->dsaf_dev;
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX)
base_addr = dsaf_dev->ppe_base + RCB_COMMON_REG_OFFSET;
else
base_addr = dsaf_dev->sds_base
+ (comm_index - 1) * HNS_DSAF_DEBUG_NW_REG_OFFSET
+ RCB_COMMON_REG_OFFSET;
return base_addr; return dsaf_dev->ppe_base + RCB_COMMON_REG_OFFSET;
} }
static phys_addr_t hns_rcb_common_get_paddr(struct dsaf_device *dsaf_dev, static phys_addr_t hns_rcb_common_get_paddr(struct rcb_common_cb *rcb_common)
int comm_index)
{ {
struct device_node *np = dsaf_dev->dev->of_node; struct dsaf_device *dsaf_dev = rcb_common->dsaf_dev;
phys_addr_t phy_addr;
const __be32 *tmp_addr; return dsaf_dev->ppe_paddr + RCB_COMMON_REG_OFFSET;
u64 addr_offset = 0;
u64 size = 0;
int index = 0;
if (comm_index == HNS_DSAF_COMM_SERVICE_NW_IDX) {
index = 2;
addr_offset = RCB_COMMON_REG_OFFSET;
} else {
index = 1;
addr_offset = (comm_index - 1) * HNS_DSAF_DEBUG_NW_REG_OFFSET +
RCB_COMMON_REG_OFFSET;
}
tmp_addr = of_get_address(np, index, &size, NULL);
phy_addr = of_translate_address(np, tmp_addr);
return phy_addr + addr_offset;
} }
int hns_rcb_common_get_cfg(struct dsaf_device *dsaf_dev, int hns_rcb_common_get_cfg(struct dsaf_device *dsaf_dev,
...@@ -717,7 +670,7 @@ int hns_rcb_common_get_cfg(struct dsaf_device *dsaf_dev, ...@@ -717,7 +670,7 @@ int hns_rcb_common_get_cfg(struct dsaf_device *dsaf_dev,
enum dsaf_mode dsaf_mode = dsaf_dev->dsaf_mode; enum dsaf_mode dsaf_mode = dsaf_dev->dsaf_mode;
u16 max_vfn; u16 max_vfn;
u16 max_q_per_vf; u16 max_q_per_vf;
int ring_num = hns_rcb_get_ring_num(dsaf_dev, comm_index); int ring_num = hns_rcb_get_ring_num(dsaf_dev);
rcb_common = rcb_common =
devm_kzalloc(dsaf_dev->dev, sizeof(*rcb_common) + devm_kzalloc(dsaf_dev->dev, sizeof(*rcb_common) +
...@@ -732,12 +685,12 @@ int hns_rcb_common_get_cfg(struct dsaf_device *dsaf_dev, ...@@ -732,12 +685,12 @@ int hns_rcb_common_get_cfg(struct dsaf_device *dsaf_dev,
rcb_common->desc_num = dsaf_dev->desc_num; rcb_common->desc_num = dsaf_dev->desc_num;
hns_rcb_get_queue_mode(dsaf_mode, comm_index, &max_vfn, &max_q_per_vf); hns_rcb_get_queue_mode(dsaf_mode, &max_vfn, &max_q_per_vf);
rcb_common->max_vfn = max_vfn; rcb_common->max_vfn = max_vfn;
rcb_common->max_q_per_vf = max_q_per_vf; rcb_common->max_q_per_vf = max_q_per_vf;
rcb_common->io_base = hns_rcb_common_get_vaddr(dsaf_dev, comm_index); rcb_common->io_base = hns_rcb_common_get_vaddr(rcb_common);
rcb_common->phy_base = hns_rcb_common_get_paddr(dsaf_dev, comm_index); rcb_common->phy_base = hns_rcb_common_get_paddr(rcb_common);
dsaf_dev->rcb_common[comm_index] = rcb_common; dsaf_dev->rcb_common[comm_index] = rcb_common;
return 0; return 0;
...@@ -932,7 +885,7 @@ void hns_rcb_get_common_regs(struct rcb_common_cb *rcb_com, void *data) ...@@ -932,7 +885,7 @@ void hns_rcb_get_common_regs(struct rcb_common_cb *rcb_com, void *data)
{ {
u32 *regs = data; u32 *regs = data;
bool is_ver1 = AE_IS_VER1(rcb_com->dsaf_dev->dsaf_ver); bool is_ver1 = AE_IS_VER1(rcb_com->dsaf_dev->dsaf_ver);
bool is_dbg = (rcb_com->comm_index != HNS_DSAF_COMM_SERVICE_NW_IDX); bool is_dbg = HNS_DSAF_IS_DEBUG(rcb_com->dsaf_dev);
u32 reg_tmp; u32 reg_tmp;
u32 reg_num_tmp; u32 reg_num_tmp;
u32 i = 0; u32 i = 0;
......
...@@ -111,7 +111,7 @@ void hns_rcb_common_free_cfg(struct dsaf_device *dsaf_dev, u32 comm_index); ...@@ -111,7 +111,7 @@ void hns_rcb_common_free_cfg(struct dsaf_device *dsaf_dev, u32 comm_index);
int hns_rcb_common_init_hw(struct rcb_common_cb *rcb_common); int hns_rcb_common_init_hw(struct rcb_common_cb *rcb_common);
void hns_rcb_start(struct hnae_queue *q, u32 val); void hns_rcb_start(struct hnae_queue *q, u32 val);
void hns_rcb_get_cfg(struct rcb_common_cb *rcb_common); void hns_rcb_get_cfg(struct rcb_common_cb *rcb_common);
void hns_rcb_get_queue_mode(enum dsaf_mode dsaf_mode, int comm_index, void hns_rcb_get_queue_mode(enum dsaf_mode dsaf_mode,
u16 *max_vfn, u16 *max_q_per_vf); u16 *max_vfn, u16 *max_q_per_vf);
void hns_rcb_common_init_commit_hw(struct rcb_common_cb *rcb_common); void hns_rcb_common_init_commit_hw(struct rcb_common_cb *rcb_common);
......
...@@ -10,25 +10,20 @@ ...@@ -10,25 +10,20 @@
#ifndef _DSAF_REG_H_ #ifndef _DSAF_REG_H_
#define _DSAF_REG_H_ #define _DSAF_REG_H_
#define HNS_DEBUG_RING_IRQ_IDX 55 #include <linux/regmap.h>
#define HNS_DEBUG_RING_IRQ_IDX 0
#define HNS_SERVICE_RING_IRQ_IDX 59 #define HNS_SERVICE_RING_IRQ_IDX 59
#define HNS_DEBUG_RING_IRQ_OFFSET 2
#define HNSV2_DEBUG_RING_IRQ_IDX 409
#define HNSV2_SERVICE_RING_IRQ_IDX 25 #define HNSV2_SERVICE_RING_IRQ_IDX 25
#define HNSV2_DEBUG_RING_IRQ_OFFSET 9
#define DSAF_MAX_PORT_NUM_PER_CHIP 8 #define DSAF_MAX_PORT_NUM 6
#define DSAF_SERVICE_PORT_NUM_PER_DSAF 6
#define DSAF_MAX_VM_NUM 128 #define DSAF_MAX_VM_NUM 128
#define DSAF_COMM_DEV_NUM 3 #define DSAF_COMM_DEV_NUM 1
#define DSAF_PPE_INODE_BASE 6 #define DSAF_PPE_INODE_BASE 6
#define HNS_DSAF_COMM_SERVICE_NW_IDX 0
#define DSAF_DEBUG_NW_NUM 2 #define DSAF_DEBUG_NW_NUM 2
#define DSAF_SERVICE_NW_NUM 6 #define DSAF_SERVICE_NW_NUM 6
#define DSAF_COMM_CHN DSAF_SERVICE_NW_NUM #define DSAF_COMM_CHN DSAF_SERVICE_NW_NUM
#define DSAF_GE_NUM ((DSAF_SERVICE_NW_NUM) + (DSAF_DEBUG_NW_NUM)) #define DSAF_GE_NUM ((DSAF_SERVICE_NW_NUM) + (DSAF_DEBUG_NW_NUM))
#define DSAF_PORT_NUM ((DSAF_SERVICE_NW_NUM) + (DSAF_DEBUG_NW_NUM))
#define DSAF_XGE_NUM DSAF_SERVICE_NW_NUM #define DSAF_XGE_NUM DSAF_SERVICE_NW_NUM
#define DSAF_PORT_TYPE_NUM 3 #define DSAF_PORT_TYPE_NUM 3
#define DSAF_NODE_NUM 18 #define DSAF_NODE_NUM 18
...@@ -994,6 +989,19 @@ static inline u32 dsaf_read_reg(u8 __iomem *base, u32 reg) ...@@ -994,6 +989,19 @@ static inline u32 dsaf_read_reg(u8 __iomem *base, u32 reg)
return readl(reg_addr + reg); return readl(reg_addr + reg);
} }
static inline void dsaf_write_syscon(struct regmap *base, u32 reg, u32 value)
{
regmap_write(base, reg, value);
}
static inline u32 dsaf_read_syscon(struct regmap *base, u32 reg)
{
unsigned int val;
regmap_read(base, reg, &val);
return val;
}
#define dsaf_read_dev(a, reg) \ #define dsaf_read_dev(a, reg) \
dsaf_read_reg((a)->io_base, (reg)) dsaf_read_reg((a)->io_base, (reg))
......
...@@ -1873,6 +1873,7 @@ static int hns_nic_dev_probe(struct platform_device *pdev) ...@@ -1873,6 +1873,7 @@ static int hns_nic_dev_probe(struct platform_device *pdev)
struct net_device *ndev; struct net_device *ndev;
struct hns_nic_priv *priv; struct hns_nic_priv *priv;
struct device_node *node = dev->of_node; struct device_node *node = dev->of_node;
u32 port_id;
int ret; int ret;
ndev = alloc_etherdev_mq(sizeof(struct hns_nic_priv), NIC_MAX_Q_PER_VF); ndev = alloc_etherdev_mq(sizeof(struct hns_nic_priv), NIC_MAX_Q_PER_VF);
...@@ -1896,10 +1897,18 @@ static int hns_nic_dev_probe(struct platform_device *pdev) ...@@ -1896,10 +1897,18 @@ static int hns_nic_dev_probe(struct platform_device *pdev)
dev_err(dev, "not find ae-handle\n"); dev_err(dev, "not find ae-handle\n");
goto out_read_prop_fail; goto out_read_prop_fail;
} }
/* try to find port-idx-in-ae first */
ret = of_property_read_u32(node, "port-id", &priv->port_id); ret = of_property_read_u32(node, "port-idx-in-ae", &port_id);
if (ret) {
/* only for old code compatible */
ret = of_property_read_u32(node, "port-id", &port_id);
if (ret) if (ret)
goto out_read_prop_fail; goto out_read_prop_fail;
/* for old dts, we need to caculate the port offset */
port_id = port_id < HNS_SRV_OFFSET ? port_id + HNS_DEBUG_OFFSET
: port_id - HNS_SRV_OFFSET;
}
priv->port_id = port_id;
hns_init_mac_addr(ndev); hns_init_mac_addr(ndev);
......
...@@ -18,6 +18,9 @@ ...@@ -18,6 +18,9 @@
#include "hnae.h" #include "hnae.h"
#define HNS_DEBUG_OFFSET 6
#define HNS_SRV_OFFSET 2
enum hns_nic_state { enum hns_nic_state {
NIC_STATE_TESTING = 0, NIC_STATE_TESTING = 0,
NIC_STATE_RESETTING, NIC_STATE_RESETTING,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment