mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-10 14:02:43 +00:00
5416 and similar chips grew another region in the pci clock domain
where register accesses do not pass through the byte-lane hardware; extend the register op macros to deal with this MFC after: 1 week
This commit is contained in:
parent
2227a3e9e1
commit
faaedb30ca
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=179467
@ -87,8 +87,11 @@ extern u_int32_t ath_hal_reg_read(struct ath_hal *ah, u_int reg);
|
||||
#define AH_BIG_ENDIAN 4321
|
||||
|
||||
#if _BYTE_ORDER == _BIG_ENDIAN
|
||||
#define OS_REG_UNSWAPPED(_reg) \
|
||||
(((_reg) >= 0x4000 && (_reg) < 0x5000) || \
|
||||
((_reg) >= 0x7000 && (_reg) < 0x8000))
|
||||
#define OS_REG_WRITE(_ah, _reg, _val) do { \
|
||||
if ( (_reg) >= 0x4000 && (_reg) < 0x5000) \
|
||||
if (OS_REG_UNSWAPPED(_reg)) \
|
||||
bus_space_write_4((bus_space_tag_t)(_ah)->ah_st, \
|
||||
(bus_space_handle_t)(_ah)->ah_sh, (_reg), (_val)); \
|
||||
else \
|
||||
@ -96,12 +99,13 @@ extern u_int32_t ath_hal_reg_read(struct ath_hal *ah, u_int reg);
|
||||
(bus_space_handle_t)(_ah)->ah_sh, (_reg), (_val)); \
|
||||
} while (0)
|
||||
#define OS_REG_READ(_ah, _reg) \
|
||||
(((_reg) >= 0x4000 && (_reg) < 0x5000) ? \
|
||||
(OS_REG_UNSWAPPED(_reg) ? \
|
||||
bus_space_read_4((bus_space_tag_t)(_ah)->ah_st, \
|
||||
(bus_space_handle_t)(_ah)->ah_sh, (_reg)) : \
|
||||
bus_space_read_stream_4((bus_space_tag_t)(_ah)->ah_st, \
|
||||
(bus_space_handle_t)(_ah)->ah_sh, (_reg)))
|
||||
#else /* _BYTE_ORDER == _LITTLE_ENDIAN */
|
||||
#define OS_REG_UNSWAPPED(_reg) (0)
|
||||
#define OS_REG_WRITE(_ah, _reg, _val) \
|
||||
bus_space_write_4((bus_space_tag_t)(_ah)->ah_st, \
|
||||
(bus_space_handle_t)(_ah)->ah_sh, (_reg), (_val))
|
||||
|
Loading…
Reference in New Issue
Block a user