4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-19 06:33:31 +08:00

607 lines
28 KiB
C
Raw Normal View History

2017-09-20 14:21:18 +08:00
/******************************************************************************
******************************************************************************/
#ifndef __BME_H
#define __BME_H
#ifdef __cplusplus
extern "C" {
#endif
/******************************************************************************
* BME operation code
*
*//*! @addtogroup BME_OPCode
* @{
*******************************************************************************/
#define BME_OPCODE_AND 1 /*!< AND opcode */
#define BME_OPCODE_OR 2 /*!< OR opcode */
#define BME_OPCODE_XOR 3 /*!< XOR opcode */
#define BME_OPCODE_BITFIELD 4 /*!< Bit field opcode */
#define BME_OPCODE_BIT_CLEAR 2 /*!< Bit clear opcode */
#define BME_OPCODE_BIT_SET 3 /*!< Bit set opcode */
/*! @} End of BME_OPCode */
/******************************************************************************
* BME macro used to generate hardcoded BME addresses
*
*//*! @addtogroup BME_Utilities
* @{
*******************************************************************************/
/******************************************************************************
* macro used to generate hardcoded AND address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME AND operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_AND(ADDR) (*(volatile uint32_t *)(((uint32_t)ADDR) | (BME_OPCODE_AND<<26)))
/******************************************************************************
* macro used to generate hardcoded OR address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME OR operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_OR(ADDR) (*(volatile uint32_t *)(((uint32_t)ADDR) | (BME_OPCODE_OR<<26)))
/******************************************************************************
* macro used to generate hardcoded XOR address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME XOR operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_XOR(ADDR) (*(volatile uint32_t *)(((uint32_t)ADDR) | (BME_OPCODE_XOR<<26)))
#if !defined(BME_SANITY_CHECK)
/*!
* @brief This is fastest way for BME without sanity check.
*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit clear address (LAC1).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bit clear operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BIT_CLEAR(ADDR,bit) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_CLEAR <<26) \
| ((bit)<<21)))
/******************************************************************************
* macro used to generate hardcoded load 1 bit set address (LAS1).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bit set operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BIT_SET(ADDR,bit) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_SET <<26) \
| ((bit)<<21)))
/******************************************************************************
* macro used to generate hardcoded bit field insert address (BFI).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bitfield insert operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
* @param[in] width bitfield width, 1-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BITFIELD_INSERT(ADDR,bit,width) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit)<<23) | ((width-1))<<19))
/******************************************************************************
* macro used to generate hardcoded bit field extract address (UBFX).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bitfield extract operation addresss (hardcoded 32-bit address).
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
* @param[in] width bitfield width, 1-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BITFIELD_EXTRACT(ADDR,bit,width) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit)<<23) | ((width-1))<<19))
#else
/*!
* @brief This is slow way for BME as it has sanity check.
*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit clear address (LAC1).
*
*******************************************************************************/
#define BME_BIT_CLEAR(ADDR,bit) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_CLEAR <<26) \
| ((bit & 0x1F)<<21))) /*!< Bit clear operation */
/******************************************************************************
* macro used to generate hardcoded load 1 bit set address (LAS1).
*
*******************************************************************************/
#define BME_BIT_SET(ADDR,bit) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_SET <<26) \
| ((bit & 0x1F)<<21))) /*!< Bit set operation */
/******************************************************************************
* macro used to generate hardcoded bit field insert address (BFI).
*
*******************************************************************************/
#define BME_BITFIELD_INSERT(ADDR,bit,width) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit & 0x1F)<<23) | ((width-1) & 0xF)<<19)) /*!< Bitfield insert operation */
/******************************************************************************
* macro used to generate hardcoded bit field extract address (UBFX).
*
*******************************************************************************/
#define BME_BITFIELD_EXTRACT(ADDR,bit,width) (*(volatile uint32_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit & 0x1F)<<23) | ((width-1) & 0xF)<<19)) /*!< Bitfield extract operation */
#endif
/******************************************************************************
* The following macros are used to generate hardcoded address for 8-bit operation.
*
*******************************************************************************/
/******************************************************************************
* macro used to generate hardcoded AND address for 8-bit operation.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME AND operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_AND_8b(ADDR) (*(volatile uint8_t *)(((uint32_t)ADDR) | (BME_OPCODE_AND<<26)))
/******************************************************************************
* macro used to generate hardcoded OR address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME OR operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_OR_8b(ADDR) (*(volatile uint8_t *)(((uint32_t)ADDR) | (BME_OPCODE_OR<<26)))
/******************************************************************************
* macro used to generate hardcoded XOR address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME XOR operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_XOR_8b(ADDR) (*(volatile uint8_t *)(((uint32_t)ADDR) | (BME_OPCODE_XOR<<26)))
#if !defined(BME_SANITY_CHECK)
/*!
* @brief This is fastest way for BME without sanity check.
*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit clear address (LAC1).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bit clear operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BIT_CLEAR_8b(ADDR,bit) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_CLEAR <<26) \
| ((bit)<<21)))
/******************************************************************************
* macro used to generate hardcoded load 1 bit set address (LAS1).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bit set operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BIT_SET_8b(ADDR,bit) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_SET <<26) \
| ((bit)<<21)))
/******************************************************************************
* macro used to generate hardcoded bit field insert address (BFI).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bitfield insert operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
* @param[in] width bitfield width, 1-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BITFIELD_INSERT_8b(ADDR,bit,width) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit)<<23) | ((width-1))<<19))
/******************************************************************************
* macro used to generate hardcoded bit field extract address (UBFX).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bitfield extract operation addresss (hardcoded 32-bit address) for 8-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
* @param[in] width bitfield width, 1-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BITFIELD_EXTRACT_8b(ADDR,bit,width) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit<<23) | ((width-1))<<19))
#else
/*!
* @brief This is slow way for BME as it has sanity check.
*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit clear address (LAC1).
*
*******************************************************************************/
#define BME_BIT_CLEAR_8b(ADDR,bit) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_CLEAR <<26) \
| ((bit & 0x1F)<<21))) /*!< Bit clear operation on 8-bit*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit set address (LAS1).
*
*******************************************************************************/
#define BME_BIT_SET_8b(ADDR,bit) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_SET <<26) \
| ((bit & 0x1F)<<21))) /*!< Bit set operation on 8-bit */
/******************************************************************************
* macro used to generate hardcoded bit field insert address (BFI).
*
*******************************************************************************/
#define BME_BITFIELD_INSERT_8b(ADDR,bit,width) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit & 0x1F)<<23) | ((width-1) & 0xF)<<19)) /*!< Bitfield insert operation on 8-bit */
/******************************************************************************
* macro used to generate hardcoded bit field extract address (UBFX).
*
*******************************************************************************/
#define BME_BITFIELD_EXTRACT_8b(ADDR,bit,width) (*(volatile uint8_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit & 0x1F)<<23) | ((width-1) & 0xF)<<19)) /*!< Bitfield extract operation on 8-bit*/
#endif
/******************************************************************************
* The following macros are used to generate hardcoded address for 16-bit operation.
*
*******************************************************************************/
/******************************************************************************
* macro used to generate hardcoded AND address for 16-bit operation.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME AND operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_AND_16b(ADDR) (*(volatile uint16_t *)(((uint32_t)ADDR) | (BME_OPCODE_AND<<26)))
/******************************************************************************
* macro used to generate hardcoded OR address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME OR operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_OR_16b(ADDR) (*(volatile uint16_t *)(((uint32_t)ADDR) | (BME_OPCODE_OR<<26)))
/******************************************************************************
* macro used to generate hardcoded XOR address.
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME XOR operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_XOR_16b(ADDR) (*(volatile uint16_t *)(((uint32_t)ADDR) | (BME_OPCODE_XOR<<26)))
#if !defined(BME_SANITY_CHECK)
/*!
* @brief This is fastest way for BME without sanity check.
*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit clear address (LAC1).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bit clear operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BIT_CLEAR_16b(ADDR,bit) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_CLEAR <<26) \
| ((bit)<<21)))
/******************************************************************************
* macro used to generate hardcoded load 1 bit set address (LAS1).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bit set operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BIT_SET_16b(ADDR,bit) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_SET <<26) \
| ((bit)<<21)))
/******************************************************************************
* macro used to generate hardcoded bit field insert address (BFI).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bitfield insert operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
* @param[in] width bitfield width, 1-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BITFIELD_INSERT_16b(ADDR,bit,width) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit)<<23) | ((width-1))<<19))
/******************************************************************************
* macro used to generate hardcoded bit field extract address (UBFX).
*
*******************************************************************************/
/*****************************************************************************//*!
*
* @brief generates BME bitfield extract operation addresss (hardcoded 32-bit address) for 16-bit data.
*
* @param[in] ADDR 32-bit address.
* @param[in] bit bit number, 0-based.
* @param[in] width bitfield width, 1-based.
*
* @return hardcoded 32-bit address.
*
* @ Pass/ Fail criteria: none.
*
*****************************************************************************/
#define BME_BITFIELD_EXTRACT_16b(ADDR,bit,width) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit)<<23) | ((width-1))<<19))
#else
/*!
* @brief This is slow way for BME as it has sanity check.
*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit clear address (LAC1).
*
*******************************************************************************/
#define BME_BIT_CLEAR_16b(ADDR,bit) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_CLEAR <<26) \
| ((bit & 0x1F)<<21))) /*!< Bit clear operation on 16-bit*/
/******************************************************************************
* macro used to generate hardcoded load 1 bit set address (LAS1).
*
*******************************************************************************/
#define BME_BIT_SET_16b(ADDR,bit) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BIT_SET <<26) \
| ((bit & 0x1F)<<21))) /*!< Bit set operation on 16-bit */
/******************************************************************************
* macro used to generate hardcoded bit field insert address (BFI).
*
*******************************************************************************/
#define BME_BITFIELD_INSERT_16b(ADDR,bit,width) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit & 0x1F)<<23) | ((width-1) & 0xF)<<19)) /*!< Bitfield insert operation on 16-bit */
/******************************************************************************
* macro used to generate hardcoded bit field extract address (UBFX).
*
*******************************************************************************/
#define BME_BITFIELD_EXTRACT_16b(ADDR,bit,width) (*(volatile uint16_t *)(((uint32_t)ADDR) \
| (BME_OPCODE_BITFIELD <<26) \
| ((bit & 0x1F)<<23) | ((width-1) & 0xF)<<19)) /*!< Bitfield extract operation on 16-bit*/
#endif
/*! @} End of BME_Utilities */
#ifdef __cplusplus
}
#endif
#endif /* __BME_H */