efuse.h 1014 B

1234567891011121314151617181920212223242526272829
  1. /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
  2. /* Copyright(c) 2018-2019 Realtek Corporation
  3. */
  4. #ifndef __RTW_EFUSE_H__
  5. #define __RTW_EFUSE_H__
  6. #define EFUSE_HW_CAP_IGNORE 0
  7. #define EFUSE_HW_CAP_PTCL_VHT 3
  8. #define EFUSE_HW_CAP_SUPP_BW80 7
  9. #define EFUSE_HW_CAP_SUPP_BW40 6
  10. #define EFUSE_READ_FAIL 0xff
  11. #define GET_EFUSE_HW_CAP_HCI(hw_cap) \
  12. le32_get_bits(*((__le32 *)(hw_cap) + 0x01), GENMASK(3, 0))
  13. #define GET_EFUSE_HW_CAP_BW(hw_cap) \
  14. le32_get_bits(*((__le32 *)(hw_cap) + 0x01), GENMASK(18, 16))
  15. #define GET_EFUSE_HW_CAP_NSS(hw_cap) \
  16. le32_get_bits(*((__le32 *)(hw_cap) + 0x01), GENMASK(20, 19))
  17. #define GET_EFUSE_HW_CAP_ANT_NUM(hw_cap) \
  18. le32_get_bits(*((__le32 *)(hw_cap) + 0x01), GENMASK(23, 21))
  19. #define GET_EFUSE_HW_CAP_PTCL(hw_cap) \
  20. le32_get_bits(*((__le32 *)(hw_cap) + 0x01), GENMASK(27, 26))
  21. int rtw_parse_efuse_map(struct rtw_dev *rtwdev);
  22. int rtw_read8_physical_efuse(struct rtw_dev *rtwdev, u16 addr, u8 *data);
  23. #endif