regfile_001.h 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * @brief Register File registers and control functions
  3. *
  4. * @note
  5. * Copyright(C) NXP Semiconductors, 2012
  6. * All rights reserved.
  7. *
  8. * @par
  9. * Software that is described herein is for illustrative purposes only
  10. * which provides customers with programming information regarding the
  11. * LPC products. This software is supplied "AS IS" without any warranties of
  12. * any kind, and NXP Semiconductors and its licensor disclaim any and
  13. * all warranties, express or implied, including all implied warranties of
  14. * merchantability, fitness for a particular purpose and non-infringement of
  15. * intellectual property rights. NXP Semiconductors assumes no responsibility
  16. * or liability for the use of the software, conveys no license or rights under any
  17. * patent, copyright, mask work right, or any other intellectual property rights in
  18. * or to any products. NXP Semiconductors reserves the right to make changes
  19. * in the software without notification. NXP Semiconductors also makes no
  20. * representation or warranty that such application will be suitable for the
  21. * specified use without further testing or modification.
  22. *
  23. * @par
  24. * Permission to use, copy, modify, and distribute this software and its
  25. * documentation is hereby granted, under NXP Semiconductors' and its
  26. * licensor's relevant copyrights in the software, without fee, provided that it
  27. * is used in conjunction with NXP Semiconductors microcontrollers. This
  28. * copyright, permission, and disclaimer notice must appear in all copies of
  29. * this code.
  30. */
  31. #ifndef __REGFILE_001_H_
  32. #define __REGFILE_001_H_
  33. #include "sys_config.h"
  34. #include "cmsis.h"
  35. #ifdef __cplusplus
  36. extern "C" {
  37. #endif
  38. /** @defgroup IP_REGFILE_001 IP: REGFILE register block and driver
  39. * @ingroup IP_Drivers
  40. * Register File
  41. * @{
  42. */
  43. /**
  44. * @brief Register File register block structure
  45. */
  46. typedef struct {
  47. __IO uint32_t REGFILE[64]; /*!< General purpose storage register */
  48. } IP_REGFILE_001_T;
  49. /**
  50. * @brief Write value to General purpose registers
  51. * @param pREG : Pointer to regfile block
  52. * @param index : General purpose register index
  53. * @param value : Value to write
  54. * @return None
  55. * Note: These General purpose registers can be used to store important
  56. * information when the main power supply is off. The value in these
  57. * registers is not affected by chip reset. These registers are usually
  58. * powered in the RTC power domain.
  59. */
  60. STATIC INLINE void IP_REGFILE_Write(IP_REGFILE_001_T *pREG, int index, uint32_t value)
  61. {
  62. pREG->REGFILE[index] = value;
  63. }
  64. /**
  65. * @brief Read value from General purpose registers
  66. * @param pREG : Pointer to regfile block
  67. * @param index : General purpose register index
  68. * @return Read value
  69. * These General purpose registers can be used to store important
  70. * information when the main power supply is off. The value in these
  71. * registers is not affected by chip reset. These registers are usually
  72. * powered in the RTC power domain.
  73. */
  74. STATIC INLINE uint32_t IP_REGFILE_Read(IP_REGFILE_001_T *pREG, int index)
  75. {
  76. return pREG->REGFILE[index];
  77. }
  78. /**
  79. * @}
  80. */
  81. #ifdef __cplusplus
  82. }
  83. #endif
  84. #endif /* __REGFILE_001_H_ */