Lines Matching +full:concat +full:- +full:buf +full:- +full:size
4 * SPDX-License-Identifier: Apache-2.0
45 #define PRV_DATA(ctx) ((struct ksz8xxx_data *const)(ctx)->prv_data)
51 uint8_t buf[3]; in dsa_ksz8xxx_write_reg() local
54 .buf = buf, in dsa_ksz8xxx_write_reg()
62 buf[0] = KSZ8XXX_SPI_CMD_WR | ((reg_addr >> 7) & 0x1F); in dsa_ksz8xxx_write_reg()
63 buf[1] = (reg_addr << 1) & 0xFE; in dsa_ksz8xxx_write_reg()
64 buf[2] = value; in dsa_ksz8xxx_write_reg()
66 spi_write_dt(&pdev->spi, &tx); in dsa_ksz8xxx_write_reg()
74 uint8_t buf[3]; in dsa_ksz8xxx_read_reg() local
77 .buf = buf, in dsa_ksz8xxx_read_reg()
85 .buf = buf, in dsa_ksz8xxx_read_reg()
94 buf[0] = KSZ8XXX_SPI_CMD_RD | ((reg_addr >> 7) & 0x1F); in dsa_ksz8xxx_read_reg()
95 buf[1] = (reg_addr << 1) & 0xFE; in dsa_ksz8xxx_read_reg()
96 buf[2] = 0x0; in dsa_ksz8xxx_read_reg()
98 if (!spi_transceive_dt(&pdev->spi, &tx, &rx)) { in dsa_ksz8xxx_read_reg()
99 *value = buf[2]; in dsa_ksz8xxx_read_reg()
139 * Wait for SPI of KSZ8794 being fully operational - up to 10 ms in dsa_ksz8xxx_probe()
142 tmp != KSZ8XXX_CHIP_ID0_ID_DEFAULT && timeout > 0; timeout--) { in dsa_ksz8xxx_probe()
149 return -ENODEV; in dsa_ksz8xxx_probe()
163 return -ENODEV; in dsa_ksz8xxx_probe()
176 * According to KSZ8794 manual - write to static mac address table in dsa_ksz8xxx_write_static_mac_table()
207 * The data in uint8_t buf[] buffer is stored in the little endian in dsa_ksz8xxx_set_static_mac_table()
210 uint8_t buf[8]; in dsa_ksz8xxx_set_static_mac_table() local
212 buf[7] = 0; in dsa_ksz8xxx_set_static_mac_table()
214 buf[5] = mac[0]; in dsa_ksz8xxx_set_static_mac_table()
215 buf[4] = mac[1]; in dsa_ksz8xxx_set_static_mac_table()
216 buf[3] = mac[2]; in dsa_ksz8xxx_set_static_mac_table()
217 buf[2] = mac[3]; in dsa_ksz8xxx_set_static_mac_table()
218 buf[1] = mac[4]; in dsa_ksz8xxx_set_static_mac_table()
219 buf[0] = mac[5]; in dsa_ksz8xxx_set_static_mac_table()
221 buf[6] = fw_port; in dsa_ksz8xxx_set_static_mac_table()
222 buf[6] |= KSZ8XXX_STATIC_MAC_TABLE_VALID; in dsa_ksz8xxx_set_static_mac_table()
223 buf[6] |= KSZ8XXX_STATIC_MAC_TABLE_OVRD; in dsa_ksz8xxx_set_static_mac_table()
225 dsa_ksz8xxx_write_static_mac_table(pdev, entry_idx, buf); in dsa_ksz8xxx_set_static_mac_table()
234 * According to KSZ8794 manual - read from static mac address table in dsa_ksz8xxx_read_static_mac_table()
269 * Loop through ports - The same setup when tail tagging is enabled or in dsa_ksz8xxx_switch_setup()
308 * Loop through ports - The same setup when tail tagging is enabled or in dsa_ksz8xxx_switch_setup()
353 * https://microchipsupport.force.com/s/article/Solution-for-Short-Cable-
354 * Problems-with-the-KSZ8795-Family
359 * 2) There may be a link-up issue in the capacitor AC coupling mode for port
368 * When using some type of short cable (for example, CAT-6 cable with low
369 * attenuation to high frequencies signal vs. CAT-5 cable) or board to board
371 * is amplified too much and cause the link-up failed with same boost setting in
384 * The indirect DSP register (0x3c) is an 8-bit register, the bits describe as
389 * 7-5 Reserved RO 000 000
394 * 3-1 Cpu_EQ_CP_Points Control of EQ training is
395 * over-boosted or
396 * [2:0] under-boosted, that means to
412 * Ethernet short cables like CAT-5, CAT-5e without any problem.
432 * Solution for Using CAT-5E or CAT-6 Short Cable with a Link Issue for the
436 * Solution for Using CAT-5E or CAT-6 Short Cable with a Link Issue for the
438 * https://microchipsupport.force.com/s/article/Solution-for-Using-CAT-5E-or
439 * -CAT-6-Short-Cable- with-a-Link-Issue-for-the-KSZ8795-Family
445 * short CAT-5E or CAT-6 cable (about <=30 meter). The failure rate may be about
446 * 2-5%.
450 * Basically, KSZ8795 10/100 Ethernet switch family was designed based on CAT-5
452 * cables of CAT-5E and CAT-6, both cables have wider bandwidth that has
453 * different frequency characteristics than CAT-5 cable. More higher frequency
454 * component of the CAT-5E or CAT-6 will be amplified in the receiving amplifier
456 * components receiving signal amplitude and cause the link-up failure with
463 * range when using CAT-5E and CAT-6 cable.
466 * Format is w [Register address] [8-bit data]
476 * solve the link issue if using CAT-5E and CAT-6 short cables.
478 * The indirect register (0x4C) is an 8-bit register. The bits [7:6] are
484 * 7-6 RX BW control Low pass filter bandwidth R/W 00 01
489 * 5 Enable Near-end loopback R/W 0 0
490 * 4-3 BTRT Additional reduce R/W 00 00
492 * 1-0 FXD reference setting 1.7V, 2V,
498 * For the wider bandwidth cables or on-board capacitor AC coupling
502 * short cable or on-board capacitors AC coupling application.
505 * Format is w [Register address] [8-bit data]
513 * The indirect DSP register (0x08) is an 8-bit register. The bits [5:0] are
520 * 5-0 Cpu_EQ_Index Equalizer index control
524 * Due to CAT-5E and CAT-6 cable having wider bandwidth, more high frequency
528 * reduce the high frequency components to meet CAT-5E and CAT-6 short cable
529 * link issue and doesn’t affect CAT-5 cable because CAT-5 is not a wider
535 * using very short cable or an on-board direct connection like capacitors AC
553 LOG_INF("apply workarkound 0x02 link issue CAT-5E/6 on KSZ8794"); in dsa_ksz8794_phy_workaround_0x02()
566 LOG_INF("apply workarkound 0x04 link issue CAT-5E/6 on KSZ8794"); in dsa_ksz8794_phy_workaround_0x04()
622 ret = -1; in dsa_ksz8794_set_lowspeed_drivestrength()
629 /* set Low-Speed Interface Drive Strength for MII and RMMI */ in dsa_ksz8794_set_lowspeed_drivestrength()
650 return -ENODEV; in dsa_ksz8xxx_gpio_reset()
666 if (pdev->is_init) { in dsa_hw_init()
679 if (!spi_is_ready_dt(&pdev->spi)) { in dsa_hw_init()
681 pdev->spi.bus->name); in dsa_hw_init()
682 return -ENODEV; in dsa_hw_init()
709 pdev->is_init = true; in dsa_hw_init()
724 /* Skip Switch <-> CPU Port */ in dsa_delayed_work()
730 if (link_state && !context->link_up[i]) { in dsa_delayed_work()
732 net_eth_carrier_on(context->iface_slave[i]); in dsa_delayed_work()
733 } else if (!link_state && context->link_up[i]) { in dsa_delayed_work()
735 net_eth_carrier_off(context->iface_slave[i]); in dsa_delayed_work()
737 context->link_up[i] = link_state; in dsa_delayed_work()
740 k_work_reschedule(&context->dsa_work, DSA_STATUS_PERIOD_MS); in dsa_delayed_work()
745 struct dsa_context *data = dev->data; in dsa_port_init()
756 struct dsa_context *data = dev->data; in dsa_ksz8xxx_sw_write_reg()
767 struct dsa_context *data = dev->data; in dsa_ksz8xxx_sw_read_reg()
791 struct dsa_context *data = dev->data; in dsa_ksz8xxx_set_mac_table_entry()
795 return -EINVAL; in dsa_ksz8xxx_set_mac_table_entry()
808 * @param buf The buffer for data read from the table
814 uint8_t *buf, in dsa_ksz8xxx_get_mac_table_entry() argument
817 struct dsa_context *data = dev->data; in dsa_ksz8xxx_get_mac_table_entry()
820 dsa_ksz8xxx_read_static_mac_table(pdev, tbl_entry_idx, buf); in dsa_ksz8xxx_get_mac_table_entry()
841 struct net_buf *buf; in dsa_ksz8xxx_xmit_pkt() local
844 lladst.len = sizeof(hdr->dst.addr); in dsa_ksz8xxx_xmit_pkt()
845 lladst.addr = &hdr->dst.addr[0]; in dsa_ksz8xxx_xmit_pkt()
849 * For KSZ8794 one needs to 'pad' the L2 frame to its minimal size in dsa_ksz8xxx_xmit_pkt()
852 if (len < (DSA_MIN_L2_FRAME_SIZE - DSA_L2_FCS_SIZE)) { in dsa_ksz8xxx_xmit_pkt()
854 pad = DSA_MIN_L2_FRAME_SIZE - DSA_L2_FCS_SIZE - len; in dsa_ksz8xxx_xmit_pkt()
857 buf = net_buf_alloc_len(net_buf_pool_get(pkt->buffer->pool_id), in dsa_ksz8xxx_xmit_pkt()
859 if (!buf) { in dsa_ksz8xxx_xmit_pkt()
868 dbuf = net_buf_simple_tail(&(buf->b)); in dsa_ksz8xxx_xmit_pkt()
872 * For master port (eth0) set the bit 7 to use look-up table to pass in dsa_ksz8xxx_xmit_pkt()
876 * bit 0 -> eth1, bit 1 -> eth2. bit 2 -> eth3 in dsa_ksz8xxx_xmit_pkt()
885 port_idx = (1 << (ctx->dsa_port_idx)); in dsa_ksz8xxx_xmit_pkt()
888 NET_DBG("TT - port: 0x%x[%p] LEN: %d 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x", in dsa_ksz8xxx_xmit_pkt()
896 net_buf_add(buf, pad + DSA_KSZ8794_INGRESS_TAG_LEN); in dsa_ksz8xxx_xmit_pkt()
899 net_buf_frag_add(pkt->buffer, buf); in dsa_ksz8xxx_xmit_pkt()
914 * - Pointer to struct net_if
933 net_pkt_skip(pkt, plen - DSA_KSZ8794_EGRESS_TAG_LEN); in dsa_ksz8xxx_get_iface()
936 net_pkt_update_length(pkt, plen - DSA_KSZ8794_EGRESS_TAG_LEN); in dsa_ksz8xxx_get_iface()
951 NET_DBG("TT - plen: %d pnum: %d pos: 0x%p dsa_port_idx: %d", in dsa_ksz8xxx_get_iface()
952 plen - DSA_KSZ8794_EGRESS_TAG_LEN, pnum, in dsa_ksz8xxx_get_iface()
953 net_pkt_cursor_get_pos(pkt), ctx->dsa_port_idx); in dsa_ksz8xxx_get_iface()
962 net_if_get_device(iface)->config; in dsa_iface_init()
965 struct dsa_context *context = dev->data; in dsa_iface_init()
968 int i = pdev->iface_init_count; in dsa_iface_init()
971 if (context->iface_master == NULL) { in dsa_iface_init()
973 context->iface_master = net_if_lookup_by_dev(dm); in dsa_iface_init()
974 if (context->iface_master == NULL) { in dsa_iface_init()
983 ctx_master = net_if_l2_data(context->iface_master); in dsa_iface_init()
984 ctx_master->dsa_ctx = context; in dsa_iface_init()
987 if (context->iface_slave[i] == NULL) { in dsa_iface_init()
988 context->iface_slave[i] = iface; in dsa_iface_init()
989 net_if_set_link_addr(iface, cfg->mac_addr, in dsa_iface_init()
990 sizeof(cfg->mac_addr), in dsa_iface_init()
992 ctx->dsa_port_idx = i; in dsa_iface_init()
993 ctx->dsa_ctx = context; in dsa_iface_init()
1002 pdev->iface_init_count++; in dsa_iface_init()
1010 if (pdev->iface_init_count == context->num_slave_ports) { in dsa_iface_init()
1011 k_work_init_delayable(&context->dsa_work, dsa_delayed_work); in dsa_iface_init()
1012 k_work_reschedule(&context->dsa_work, DSA_STATUS_PERIOD_MS); in dsa_iface_init()
1044 * To make the code simpler - the special care needs to be put on
1045 * the proper placement of eth0, lan1, lan2, lan3, etc - to avoid
1050 * available for use - let's use it.
1054 * objdump -dst ./zephyr/CMakeFiles/zephyr.dir/drivers/ethernet/eth_mcux.c.obj\
1069 NET_DEVICE_INIT_INSTANCE(CONCAT(dsa_slave_port_, slave), \