
For 802.11 Fragmented frames, currently there is a generic GetFrameControl API from RX TLV for all Li Chipsets. As the offset for frame control in RX TLV is different for QCN9000 and QCA8074V2, reading the frame control with generic API gives wrong frame control value. The Offset is different as the size of RX_MSDU_START struct is 8DWORDS in QCA8074v2 while it is 9DWORDS in QCA9000. In the reo reinject path the destination queue descriptor address read from ring descriptor address is Invalid Fix is Separating out the GetFrameControl API from generic API to Chip specific API. Also fix the reading of queue descriptor address. CRs-Fixed: 3280809 change-Id: Ifc5eca31b9b7e70c84ca455d56a58c27601cd51d
The below qca6290 and qca8074 folder has c files defining functions and structures to hold target specific definitions to handle differences between chips with respect to hal. Please ensure changes get applied to all platform specific files if the fixes are generic and applicable to all the folders. qca6290 hal_6290_rx.c - rx related target specific function hal_6290_srng_table.c - holds hw srng table and hal hw reg offsets array hal_6290_tx.c - tx related target specific function qca8074 hal_8074_rx.c - rx related target specific function hal_8074_srng_table.c - holds hw srng table and hal hw reg offsets array hal_8074_tx.c - tx related target specific function