forked from Imagelibrary/rtems
powerpc/gen5200/.../bestcomm_cntrl.h: Fix type punning warnings
Three macros included a case of type punning in each. Addressed by introducing a local pointer variable.
This commit is contained in:
committed by
Sebastian Huber
parent
6fbbee4427
commit
f6f3eafa3b
@@ -118,16 +118,18 @@
|
|||||||
#define SDMA_INT_ENABLE(RegAddr, Bit) \
|
#define SDMA_INT_ENABLE(RegAddr, Bit) \
|
||||||
do { \
|
do { \
|
||||||
rtems_interrupt_level level; \
|
rtems_interrupt_level level; \
|
||||||
|
volatile uint32 *reg = (volatile uint32 *) RegAddr; \
|
||||||
rtems_interrupt_disable(level); \
|
rtems_interrupt_disable(level); \
|
||||||
*((volatile uint32 *) RegAddr) &= ~((uint32) (1 << Bit)); \
|
*reg &= ~((uint32) (1 << Bit)); \
|
||||||
rtems_interrupt_enable(level); \
|
rtems_interrupt_enable(level); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define SDMA_INT_DISABLE(RegAddr, Bit) \
|
#define SDMA_INT_DISABLE(RegAddr, Bit) \
|
||||||
do { \
|
do { \
|
||||||
rtems_interrupt_level level; \
|
rtems_interrupt_level level; \
|
||||||
|
volatile uint32 *reg = (volatile uint32 *) RegAddr; \
|
||||||
rtems_interrupt_disable(level); \
|
rtems_interrupt_disable(level); \
|
||||||
*((volatile uint32 *) (RegAddr)) |= ((uint32)(1 << Bit)); \
|
*reg |= ((uint32)(1 << Bit)); \
|
||||||
rtems_interrupt_enable(level); \
|
rtems_interrupt_enable(level); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
@@ -147,7 +149,8 @@
|
|||||||
|
|
||||||
/* Clear the IntPend bit */
|
/* Clear the IntPend bit */
|
||||||
#define SDMA_CLEAR_IEVENT(RegAddr, Bit) { \
|
#define SDMA_CLEAR_IEVENT(RegAddr, Bit) { \
|
||||||
*((volatile uint32 *)RegAddr) = ((uint32)(1<<Bit)); \
|
volatile uint32 *reg = (volatile uint32 *) RegAddr; \
|
||||||
|
*reg = ((uint32)(1<<Bit)); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SDMA_GET_PENDINGBIT(sdma, Bit) \
|
#define SDMA_GET_PENDINGBIT(sdma, Bit) \
|
||||||
|
|||||||
Reference in New Issue
Block a user