Commit 2d2a514c authored by Chris Packham's avatar Chris Packham Committed by Paolo Abeni

net: mvneta: Add support for 98DX2530 Ethernet port

The 98DX2530 SoC is similar to the Armada 3700 except it needs a
different MBUS window configuration. Add a new compatible string to
identify this device and the required MBUS window configuration.
Signed-off-by: default avatarChris Packham <chris.packham@alliedtelesis.co.nz>
Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent 270a9596
...@@ -76,6 +76,8 @@ ...@@ -76,6 +76,8 @@
#define MVNETA_WIN_SIZE(w) (0x2204 + ((w) << 3)) #define MVNETA_WIN_SIZE(w) (0x2204 + ((w) << 3))
#define MVNETA_WIN_REMAP(w) (0x2280 + ((w) << 2)) #define MVNETA_WIN_REMAP(w) (0x2280 + ((w) << 2))
#define MVNETA_BASE_ADDR_ENABLE 0x2290 #define MVNETA_BASE_ADDR_ENABLE 0x2290
#define MVNETA_AC5_CNM_DDR_TARGET 0x2
#define MVNETA_AC5_CNM_DDR_ATTR 0xb
#define MVNETA_ACCESS_PROTECT_ENABLE 0x2294 #define MVNETA_ACCESS_PROTECT_ENABLE 0x2294
#define MVNETA_PORT_CONFIG 0x2400 #define MVNETA_PORT_CONFIG 0x2400
#define MVNETA_UNI_PROMISC_MODE BIT(0) #define MVNETA_UNI_PROMISC_MODE BIT(0)
...@@ -544,6 +546,7 @@ struct mvneta_port { ...@@ -544,6 +546,7 @@ struct mvneta_port {
/* Flags for special SoC configurations */ /* Flags for special SoC configurations */
bool neta_armada3700; bool neta_armada3700;
bool neta_ac5;
u16 rx_offset_correction; u16 rx_offset_correction;
const struct mbus_dram_target_info *dram_target_info; const struct mbus_dram_target_info *dram_target_info;
}; };
...@@ -5324,6 +5327,10 @@ static void mvneta_conf_mbus_windows(struct mvneta_port *pp, ...@@ -5324,6 +5327,10 @@ static void mvneta_conf_mbus_windows(struct mvneta_port *pp,
win_protect |= 3 << (2 * i); win_protect |= 3 << (2 * i);
} }
} else { } else {
if (pp->neta_ac5)
mvreg_write(pp, MVNETA_WIN_BASE(0),
(MVNETA_AC5_CNM_DDR_ATTR << 8) |
MVNETA_AC5_CNM_DDR_TARGET);
/* For Armada3700 open default 4GB Mbus window, leaving /* For Armada3700 open default 4GB Mbus window, leaving
* arbitration of target/attribute to a different layer * arbitration of target/attribute to a different layer
* of configuration. * of configuration.
...@@ -5409,6 +5416,10 @@ static int mvneta_probe(struct platform_device *pdev) ...@@ -5409,6 +5416,10 @@ static int mvneta_probe(struct platform_device *pdev)
/* Get special SoC configurations */ /* Get special SoC configurations */
if (of_device_is_compatible(dn, "marvell,armada-3700-neta")) if (of_device_is_compatible(dn, "marvell,armada-3700-neta"))
pp->neta_armada3700 = true; pp->neta_armada3700 = true;
if (of_device_is_compatible(dn, "marvell,armada-ac5-neta")) {
pp->neta_armada3700 = true;
pp->neta_ac5 = true;
}
dev->irq = irq_of_parse_and_map(dn, 0); dev->irq = irq_of_parse_and_map(dn, 0);
if (dev->irq == 0) if (dev->irq == 0)
...@@ -5769,6 +5780,7 @@ static const struct of_device_id mvneta_match[] = { ...@@ -5769,6 +5780,7 @@ static const struct of_device_id mvneta_match[] = {
{ .compatible = "marvell,armada-370-neta" }, { .compatible = "marvell,armada-370-neta" },
{ .compatible = "marvell,armada-xp-neta" }, { .compatible = "marvell,armada-xp-neta" },
{ .compatible = "marvell,armada-3700-neta" }, { .compatible = "marvell,armada-3700-neta" },
{ .compatible = "marvell,armada-ac5-neta" },
{ } { }
}; };
MODULE_DEVICE_TABLE(of, mvneta_match); MODULE_DEVICE_TABLE(of, mvneta_match);
......
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