Lines Matching +full:eeprom +full:- +full:data
1 // SPDX-License-Identifier: GPL-2.0-or-later
7 * Copyright (c) 2016-2017 Savoir-faire Linux Inc.
21 return mv88e6xxx_read(chip, chip->info->global2_addr, reg, val); in mv88e6xxx_g2_read()
26 return mv88e6xxx_write(chip, chip->info->global2_addr, reg, val); in mv88e6xxx_g2_write()
32 return mv88e6xxx_wait_bit(chip, chip->info->global2_addr, reg, in mv88e6xxx_g2_wait_bit()
146 const u16 port_mask = BIT(mv88e6xxx_num_ports(chip)) - 1; in mv88e6xxx_g2_trunk_mapping_write()
155 const u16 port_mask = BIT(mv88e6xxx_num_ports(chip)) - 1; in mv88e6xxx_g2_trunk_clear()
176 * Offset 0x0A: Ingress Rate Data register
212 /* Offset 0x0B: Cross-chip Port VLAN (Addr) Register
213 * Offset 0x0C: Cross-chip Port VLAN Data Register
228 /* 9-bit Cross-chip PVT pointer: with MV88E6XXX_G2_MISC_5_BIT_PORT in mv88e6xxx_g2_pvt_op()
229 * cleared, source device is 5-bit, source port is 4-bit. in mv88e6xxx_g2_pvt_op()
243 int src_port, u16 *data) in mv88e6xxx_g2_pvt_read() argument
256 return mv88e6xxx_g2_read(chip, MV88E6XXX_G2_PVT_DATA, data); in mv88e6xxx_g2_pvt_read()
260 int src_port, u16 data) in mv88e6xxx_g2_pvt_write() argument
268 err = mv88e6xxx_g2_write(chip, MV88E6XXX_G2_PVT_DATA, data); in mv88e6xxx_g2_pvt_write()
279 unsigned int pointer, u8 data) in mv88e6xxx_g2_switch_mac_write() argument
281 u16 val = (pointer << 8) | data; in mv88e6xxx_g2_switch_mac_write()
316 u8 data) in mv88e6xxx_g2_pot_write() argument
318 u16 val = (pointer << 8) | (data & 0x7); in mv88e6xxx_g2_pot_write()
338 /* Offset 0x14: EEPROM Command
339 * Offset 0x15: EEPROM Data (for 16-bit data access)
340 * Offset 0x15: EEPROM Addr (for 8-bit data access)
370 u16 addr, u8 *data) in mv88e6xxx_g2_eeprom_read8() argument
391 *data = cmd & 0xff; in mv88e6xxx_g2_eeprom_read8()
397 u16 addr, u8 data) in mv88e6xxx_g2_eeprom_write8() argument
411 return mv88e6xxx_g2_eeprom_cmd(chip, cmd | data); in mv88e6xxx_g2_eeprom_write8()
415 u8 addr, u16 *data) in mv88e6xxx_g2_eeprom_read16() argument
428 return mv88e6xxx_g2_read(chip, MV88E6352_G2_EEPROM_DATA, data); in mv88e6xxx_g2_eeprom_read16()
432 u8 addr, u16 data) in mv88e6xxx_g2_eeprom_write16() argument
441 err = mv88e6xxx_g2_write(chip, MV88E6352_G2_EEPROM_DATA, data); in mv88e6xxx_g2_eeprom_write16()
449 struct ethtool_eeprom *eeprom, u8 *data) in mv88e6xxx_g2_get_eeprom8() argument
451 unsigned int offset = eeprom->offset; in mv88e6xxx_g2_get_eeprom8()
452 unsigned int len = eeprom->len; in mv88e6xxx_g2_get_eeprom8()
455 eeprom->len = 0; in mv88e6xxx_g2_get_eeprom8()
458 err = mv88e6xxx_g2_eeprom_read8(chip, offset, data); in mv88e6xxx_g2_get_eeprom8()
462 eeprom->len++; in mv88e6xxx_g2_get_eeprom8()
464 data++; in mv88e6xxx_g2_get_eeprom8()
465 len--; in mv88e6xxx_g2_get_eeprom8()
472 struct ethtool_eeprom *eeprom, u8 *data) in mv88e6xxx_g2_set_eeprom8() argument
474 unsigned int offset = eeprom->offset; in mv88e6xxx_g2_set_eeprom8()
475 unsigned int len = eeprom->len; in mv88e6xxx_g2_set_eeprom8()
478 eeprom->len = 0; in mv88e6xxx_g2_set_eeprom8()
481 err = mv88e6xxx_g2_eeprom_write8(chip, offset, *data); in mv88e6xxx_g2_set_eeprom8()
485 eeprom->len++; in mv88e6xxx_g2_set_eeprom8()
487 data++; in mv88e6xxx_g2_set_eeprom8()
488 len--; in mv88e6xxx_g2_set_eeprom8()
495 struct ethtool_eeprom *eeprom, u8 *data) in mv88e6xxx_g2_get_eeprom16() argument
497 unsigned int offset = eeprom->offset; in mv88e6xxx_g2_get_eeprom16()
498 unsigned int len = eeprom->len; in mv88e6xxx_g2_get_eeprom16()
502 eeprom->len = 0; in mv88e6xxx_g2_get_eeprom16()
509 *data++ = (val >> 8) & 0xff; in mv88e6xxx_g2_get_eeprom16()
512 len--; in mv88e6xxx_g2_get_eeprom16()
513 eeprom->len++; in mv88e6xxx_g2_get_eeprom16()
521 *data++ = val & 0xff; in mv88e6xxx_g2_get_eeprom16()
522 *data++ = (val >> 8) & 0xff; in mv88e6xxx_g2_get_eeprom16()
525 len -= 2; in mv88e6xxx_g2_get_eeprom16()
526 eeprom->len += 2; in mv88e6xxx_g2_get_eeprom16()
534 *data++ = val & 0xff; in mv88e6xxx_g2_get_eeprom16()
537 len--; in mv88e6xxx_g2_get_eeprom16()
538 eeprom->len++; in mv88e6xxx_g2_get_eeprom16()
545 struct ethtool_eeprom *eeprom, u8 *data) in mv88e6xxx_g2_set_eeprom16() argument
547 unsigned int offset = eeprom->offset; in mv88e6xxx_g2_set_eeprom16()
548 unsigned int len = eeprom->len; in mv88e6xxx_g2_set_eeprom16()
558 return -EROFS; in mv88e6xxx_g2_set_eeprom16()
560 eeprom->len = 0; in mv88e6xxx_g2_set_eeprom16()
567 val = (*data++ << 8) | (val & 0xff); in mv88e6xxx_g2_set_eeprom16()
574 len--; in mv88e6xxx_g2_set_eeprom16()
575 eeprom->len++; in mv88e6xxx_g2_set_eeprom16()
579 val = *data++; in mv88e6xxx_g2_set_eeprom16()
580 val |= *data++ << 8; in mv88e6xxx_g2_set_eeprom16()
587 len -= 2; in mv88e6xxx_g2_set_eeprom16()
588 eeprom->len += 2; in mv88e6xxx_g2_set_eeprom16()
596 val = (val & 0xff00) | *data++; in mv88e6xxx_g2_set_eeprom16()
603 len--; in mv88e6xxx_g2_set_eeprom16()
604 eeprom->len++; in mv88e6xxx_g2_set_eeprom16()
611 * Offset 0x19: SMI PHY Data Register
663 /* IEEE 802.3 Clause 22 Read Data Register */
666 u16 *data) in mv88e6xxx_g2_smi_phy_read_data_c22() argument
679 return mv88e6xxx_g2_read(chip, MV88E6XXX_G2_SMI_PHY_DATA, data); in mv88e6xxx_g2_smi_phy_read_data_c22()
682 /* IEEE 802.3 Clause 22 Write Data Register */
685 u16 data) in mv88e6xxx_g2_smi_phy_write_data_c22() argument
694 err = mv88e6xxx_g2_write(chip, MV88E6XXX_G2_SMI_PHY_DATA, data); in mv88e6xxx_g2_smi_phy_write_data_c22()
727 /* IEEE 802.3 Clause 45 Read Data Register */
730 u16 *data) in mv88e6xxx_g2_smi_phy_read_data_c45() argument
739 return mv88e6xxx_g2_read(chip, MV88E6XXX_G2_SMI_PHY_DATA, data); in mv88e6xxx_g2_smi_phy_read_data_c45()
744 int reg, u16 *data) in _mv88e6xxx_g2_smi_phy_read_c45() argument
754 data); in _mv88e6xxx_g2_smi_phy_read_c45()
757 /* IEEE 802.3 Clause 45 Write Data Register */
760 u16 data) in mv88e6xxx_g2_smi_phy_write_data_c45() argument
765 err = mv88e6xxx_g2_write(chip, MV88E6XXX_G2_SMI_PHY_DATA, data); in mv88e6xxx_g2_smi_phy_write_data_c45()
774 int reg, u16 data) in _mv88e6xxx_g2_smi_phy_write_c45() argument
784 data); in _mv88e6xxx_g2_smi_phy_write_c45()
791 struct mv88e6xxx_mdio_bus *mdio_bus = bus->priv; in mv88e6xxx_g2_smi_phy_read_c22()
792 bool external = mdio_bus->external; in mv88e6xxx_g2_smi_phy_read_c22()
802 struct mv88e6xxx_mdio_bus *mdio_bus = bus->priv; in mv88e6xxx_g2_smi_phy_read_c45()
803 bool external = mdio_bus->external; in mv88e6xxx_g2_smi_phy_read_c45()
813 struct mv88e6xxx_mdio_bus *mdio_bus = bus->priv; in mv88e6xxx_g2_smi_phy_write_c22()
814 bool external = mdio_bus->external; in mv88e6xxx_g2_smi_phy_write_c22()
824 struct mv88e6xxx_mdio_bus *mdio_bus = bus->priv; in mv88e6xxx_g2_smi_phy_write_c45()
825 bool external = mdio_bus->external; in mv88e6xxx_g2_smi_phy_write_c45()
838 dev_info(chip->dev, "Watchdog event: 0x%04x", reg); in mv88e6097_watchdog_action()
914 dev_info(chip->dev, "Watchdog event: 0x%04x", in mv88e6390_watchdog_action()
921 dev_info(chip->dev, "Watchdog history: 0x%04x", in mv88e6390_watchdog_action()
925 if (chip->info->ops->reset) in mv88e6390_watchdog_action()
926 chip->info->ops->reset(chip); in mv88e6390_watchdog_action()
972 if (chip->info->ops->watchdog_ops->irq_action) in mv88e6xxx_g2_watchdog_thread_fn()
973 ret = chip->info->ops->watchdog_ops->irq_action(chip, irq); in mv88e6xxx_g2_watchdog_thread_fn()
982 if (chip->info->ops->watchdog_ops->irq_free) in mv88e6xxx_g2_watchdog_free()
983 chip->info->ops->watchdog_ops->irq_free(chip); in mv88e6xxx_g2_watchdog_free()
986 free_irq(chip->watchdog_irq, chip); in mv88e6xxx_g2_watchdog_free()
987 irq_dispose_mapping(chip->watchdog_irq); in mv88e6xxx_g2_watchdog_free()
994 chip->watchdog_irq = irq_find_mapping(chip->g2_irq.domain, in mv88e6xxx_g2_watchdog_setup()
996 if (chip->watchdog_irq < 0) in mv88e6xxx_g2_watchdog_setup()
997 return chip->watchdog_irq; in mv88e6xxx_g2_watchdog_setup()
999 snprintf(chip->watchdog_irq_name, sizeof(chip->watchdog_irq_name), in mv88e6xxx_g2_watchdog_setup()
1000 "mv88e6xxx-%s-watchdog", dev_name(chip->dev)); in mv88e6xxx_g2_watchdog_setup()
1002 err = request_threaded_irq(chip->watchdog_irq, NULL, in mv88e6xxx_g2_watchdog_setup()
1005 chip->watchdog_irq_name, chip); in mv88e6xxx_g2_watchdog_setup()
1010 if (chip->info->ops->watchdog_ops->irq_setup) in mv88e6xxx_g2_watchdog_setup()
1011 err = chip->info->ops->watchdog_ops->irq_setup(chip); in mv88e6xxx_g2_watchdog_setup()
1045 unsigned int n = d->hwirq; in mv88e6xxx_g2_irq_mask()
1047 chip->g2_irq.masked |= (1 << n); in mv88e6xxx_g2_irq_mask()
1053 unsigned int n = d->hwirq; in mv88e6xxx_g2_irq_unmask()
1055 chip->g2_irq.masked &= ~(1 << n); in mv88e6xxx_g2_irq_unmask()
1075 sub_irq = irq_find_mapping(chip->g2_irq.domain, n); in mv88e6xxx_g2_irq_thread_fn()
1096 err = mv88e6xxx_g2_int_mask(chip, ~chip->g2_irq.masked); in mv88e6xxx_g2_irq_bus_sync_unlock()
1098 dev_err(chip->dev, "failed to mask interrupts\n"); in mv88e6xxx_g2_irq_bus_sync_unlock()
1104 .name = "mv88e6xxx-g2",
1115 struct mv88e6xxx_chip *chip = d->host_data; in mv88e6xxx_g2_irq_domain_map()
1117 irq_set_chip_data(irq, d->host_data); in mv88e6xxx_g2_irq_domain_map()
1118 irq_set_chip_and_handler(irq, &chip->g2_irq.chip, handle_level_irq); in mv88e6xxx_g2_irq_domain_map()
1135 free_irq(chip->device_irq, chip); in mv88e6xxx_g2_irq_free()
1136 irq_dispose_mapping(chip->device_irq); in mv88e6xxx_g2_irq_free()
1139 virq = irq_find_mapping(chip->g2_irq.domain, irq); in mv88e6xxx_g2_irq_free()
1143 irq_domain_remove(chip->g2_irq.domain); in mv88e6xxx_g2_irq_free()
1150 chip->g2_irq.masked = ~0; in mv88e6xxx_g2_irq_setup()
1152 err = mv88e6xxx_g2_int_mask(chip, ~chip->g2_irq.masked); in mv88e6xxx_g2_irq_setup()
1157 chip->g2_irq.domain = irq_domain_add_simple( in mv88e6xxx_g2_irq_setup()
1158 chip->dev->of_node, 16, 0, &mv88e6xxx_g2_irq_domain_ops, chip); in mv88e6xxx_g2_irq_setup()
1159 if (!chip->g2_irq.domain) in mv88e6xxx_g2_irq_setup()
1160 return -ENOMEM; in mv88e6xxx_g2_irq_setup()
1163 irq_create_mapping(chip->g2_irq.domain, irq); in mv88e6xxx_g2_irq_setup()
1165 chip->g2_irq.chip = mv88e6xxx_g2_irq_chip; in mv88e6xxx_g2_irq_setup()
1167 chip->device_irq = irq_find_mapping(chip->g1_irq.domain, in mv88e6xxx_g2_irq_setup()
1169 if (chip->device_irq < 0) { in mv88e6xxx_g2_irq_setup()
1170 err = chip->device_irq; in mv88e6xxx_g2_irq_setup()
1174 snprintf(chip->device_irq_name, sizeof(chip->device_irq_name), in mv88e6xxx_g2_irq_setup()
1175 "mv88e6xxx-%s-g2", dev_name(chip->dev)); in mv88e6xxx_g2_irq_setup()
1177 err = request_threaded_irq(chip->device_irq, NULL, in mv88e6xxx_g2_irq_setup()
1179 IRQF_ONESHOT, chip->device_irq_name, chip); in mv88e6xxx_g2_irq_setup()
1187 virq = irq_find_mapping(chip->g2_irq.domain, irq); in mv88e6xxx_g2_irq_setup()
1191 irq_domain_remove(chip->g2_irq.domain); in mv88e6xxx_g2_irq_setup()
1199 int phy_start = chip->info->internal_phys_offset; in mv88e6xxx_g2_irq_mdio_setup()
1200 int phy_end = chip->info->internal_phys_offset + in mv88e6xxx_g2_irq_mdio_setup()
1201 chip->info->num_internal_phys; in mv88e6xxx_g2_irq_mdio_setup()
1205 irq = irq_find_mapping(chip->g2_irq.domain, phy); in mv88e6xxx_g2_irq_mdio_setup()
1209 bus->irq[chip->info->phy_base_addr + phy] = irq; in mv88e6xxx_g2_irq_mdio_setup()