diff options
Diffstat (limited to 'drivers/net/ethernet/mscc/ocelot_io.c')
| -rw-r--r-- | drivers/net/ethernet/mscc/ocelot_io.c | 104 |
1 files changed, 80 insertions, 24 deletions
diff --git a/drivers/net/ethernet/mscc/ocelot_io.c b/drivers/net/ethernet/mscc/ocelot_io.c index b229b1cb68ef..3aa7dc29ebe1 100644 --- a/drivers/net/ethernet/mscc/ocelot_io.c +++ b/drivers/net/ethernet/mscc/ocelot_io.c @@ -10,54 +10,108 @@ #include "ocelot.h" -u32 __ocelot_read_ix(struct ocelot *ocelot, u32 reg, u32 offset) +int __ocelot_bulk_read_ix(struct ocelot *ocelot, enum ocelot_reg reg, + u32 offset, void *buf, int count) { - u16 target = reg >> TARGET_OFFSET; - u32 val; + enum ocelot_target target; + u32 addr; + ocelot_reg_to_target_addr(ocelot, reg, &target, &addr); WARN_ON(!target); - regmap_read(ocelot->targets[target], - ocelot->map[target][reg & REG_MASK] + offset, &val); + return regmap_bulk_read(ocelot->targets[target], addr + offset, + buf, count); +} +EXPORT_SYMBOL_GPL(__ocelot_bulk_read_ix); + +u32 __ocelot_read_ix(struct ocelot *ocelot, enum ocelot_reg reg, u32 offset) +{ + enum ocelot_target target; + u32 addr, val; + + ocelot_reg_to_target_addr(ocelot, reg, &target, &addr); + WARN_ON(!target); + + regmap_read(ocelot->targets[target], addr + offset, &val); return val; } -EXPORT_SYMBOL(__ocelot_read_ix); +EXPORT_SYMBOL_GPL(__ocelot_read_ix); -void __ocelot_write_ix(struct ocelot *ocelot, u32 val, u32 reg, u32 offset) +void __ocelot_write_ix(struct ocelot *ocelot, u32 val, enum ocelot_reg reg, + u32 offset) { + enum ocelot_target target; + u32 addr; + + ocelot_reg_to_target_addr(ocelot, reg, &target, &addr); + WARN_ON(!target); + + regmap_write(ocelot->targets[target], addr + offset, val); +} +EXPORT_SYMBOL_GPL(__ocelot_write_ix); + +void __ocelot_rmw_ix(struct ocelot *ocelot, u32 val, u32 mask, + enum ocelot_reg reg, u32 offset) +{ + enum ocelot_target target; + u32 addr; + + ocelot_reg_to_target_addr(ocelot, reg, &target, &addr); + WARN_ON(!target); + + regmap_update_bits(ocelot->targets[target], addr + offset, mask, val); +} +EXPORT_SYMBOL_GPL(__ocelot_rmw_ix); + +u32 ocelot_port_readl(struct ocelot_port *port, enum ocelot_reg reg) +{ + struct ocelot *ocelot = port->ocelot; u16 target = reg >> TARGET_OFFSET; + u32 val; WARN_ON(!target); - regmap_write(ocelot->targets[target], - ocelot->map[target][reg & REG_MASK] + offset, val); + regmap_read(port->target, ocelot->map[target][reg & REG_MASK], &val); + return val; } -EXPORT_SYMBOL(__ocelot_write_ix); +EXPORT_SYMBOL_GPL(ocelot_port_readl); -void __ocelot_rmw_ix(struct ocelot *ocelot, u32 val, u32 mask, u32 reg, - u32 offset) +void ocelot_port_writel(struct ocelot_port *port, u32 val, enum ocelot_reg reg) { + struct ocelot *ocelot = port->ocelot; u16 target = reg >> TARGET_OFFSET; WARN_ON(!target); - regmap_update_bits(ocelot->targets[target], - ocelot->map[target][reg & REG_MASK] + offset, - mask, val); + regmap_write(port->target, ocelot->map[target][reg & REG_MASK], val); +} +EXPORT_SYMBOL_GPL(ocelot_port_writel); + +void ocelot_port_rmwl(struct ocelot_port *port, u32 val, u32 mask, + enum ocelot_reg reg) +{ + u32 cur = ocelot_port_readl(port, reg); + + ocelot_port_writel(port, (cur & (~mask)) | val, reg); } -EXPORT_SYMBOL(__ocelot_rmw_ix); +EXPORT_SYMBOL_GPL(ocelot_port_rmwl); -u32 ocelot_port_readl(struct ocelot_port *port, u32 reg) +u32 __ocelot_target_read_ix(struct ocelot *ocelot, enum ocelot_target target, + u32 reg, u32 offset) { - return readl(port->regs + reg); + u32 val; + + regmap_read(ocelot->targets[target], + ocelot->map[target][reg] + offset, &val); + return val; } -EXPORT_SYMBOL(ocelot_port_readl); -void ocelot_port_writel(struct ocelot_port *port, u32 val, u32 reg) +void __ocelot_target_write_ix(struct ocelot *ocelot, enum ocelot_target target, + u32 val, u32 reg, u32 offset) { - writel(val, port->regs + reg); + regmap_write(ocelot->targets[target], + ocelot->map[target][reg] + offset, val); } -EXPORT_SYMBOL(ocelot_port_writel); int ocelot_regfields_init(struct ocelot *ocelot, const struct reg_field *const regfields) @@ -77,6 +131,8 @@ int ocelot_regfields_init(struct ocelot *ocelot, regfield.reg = ocelot->map[target][reg & REG_MASK]; regfield.lsb = regfields[i].lsb; regfield.msb = regfields[i].msb; + regfield.id_size = regfields[i].id_size; + regfield.id_offset = regfields[i].id_offset; ocelot->regfields[i] = devm_regmap_field_alloc(ocelot->dev, @@ -89,7 +145,7 @@ int ocelot_regfields_init(struct ocelot *ocelot, return 0; } -EXPORT_SYMBOL(ocelot_regfields_init); +EXPORT_SYMBOL_GPL(ocelot_regfields_init); static struct regmap_config ocelot_regmap_config = { .reg_bits = 32, @@ -109,4 +165,4 @@ struct regmap *ocelot_regmap_init(struct ocelot *ocelot, struct resource *res) return devm_regmap_init_mmio(ocelot->dev, regs, &ocelot_regmap_config); } -EXPORT_SYMBOL(ocelot_regmap_init); +EXPORT_SYMBOL_GPL(ocelot_regmap_init); |
