.rx_mac_buf_ring = false,
                .vdev_start_delay = false,
                .htt_peer_map_v2 = true,
+               .tcl_0_only = false,
        },
        {
                .name = "qca6390 hw2.0",
                .rx_mac_buf_ring = true,
                .vdev_start_delay = true,
                .htt_peer_map_v2 = false,
+               .tcl_0_only = true,
        },
 };
 
 
 
 tcl_ring_sel:
        tcl_ring_retry = false;
-       ti.ring_id = ring_selector % DP_TCL_NUM_RING_MAX;
+       /* For some chip, it can only use tcl0 to tx */
+       if (ar->ab->hw_params.tcl_0_only)
+               ti.ring_id = 0;
+       else
+               ti.ring_id = ring_selector % DP_TCL_NUM_RING_MAX;
+
        ring_map |= BIT(ti.ring_id);
 
        tx_ring = &dp->tx_ring[ti.ring_id];
                 * checking this ring earlier for each pkt tx.
                 * Restart ring selection if some rings are not checked yet.
                 */
-               if (ring_map != (BIT(DP_TCL_NUM_RING_MAX) - 1)) {
+               if (ring_map != (BIT(DP_TCL_NUM_RING_MAX) - 1) &&
+                   !ar->ab->hw_params.tcl_0_only) {
                        tcl_ring_retry = true;
                        ring_selector++;
                }