csl_ipc.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /* ============================================================================
  2. * Copyright (c) Texas Instruments Incorporated 2008, 2009
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. *
  11. * Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the
  14. * distribution.
  15. *
  16. * Neither the name of Texas Instruments Incorporated nor the names of
  17. * its contributors may be used to endorse or promote products derived
  18. * from this software without specific prior written permission.
  19. *
  20. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  21. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  22. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  23. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  24. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  25. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  26. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  27. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  28. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  29. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  30. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  31. *
  32. */
  33. /**
  34. * @file csl_ipc.h
  35. *
  36. * @brief
  37. * IPC CSL Implementation on DSP side
  38. *
  39. * \par
  40. * ============================================================================
  41. * @n (C) Copyright 2008, 2009, Texas Instruments, Inc.
  42. * @n Use of this software is controlled by the terms and conditions found
  43. * @n in the license agreement under which this software has been supplied.
  44. * ===========================================================================
  45. * \par
  46. */
  47. /** @defgroup CSL_IPC_API IPC
  48. *
  49. * @section Introduction
  50. *
  51. * @subsection xxx Overview
  52. *
  53. * Each of the GEM cores can communicate with one another in a variety of ways.
  54. * Inter-Processor interrupts (IPC) is one of the ways used for core synchronization,
  55. * allowing for direct notification from one GEM core to another.
  56. * Three different IPC mechanisms are defined:
  57. * a) Inter-DSP Interrupts.
  58. * b) Host CPU Interrupts (interrupts to external host).
  59. * c) Non Maskable Interrupts (NMI) to GEMs.
  60. *
  61. * @subsection References
  62. * -# Inter-Processor Communications (IPC) Architecture
  63. *
  64. * @subsection Assumptions
  65. * The abbreviations IPC, ipc and Ipc have been used throughout this
  66. * document to refer to Inter-Processor Communications (IPC) Architecture
  67. */
  68. #ifndef CSL_IPC_H_
  69. #define CSL_IPC_H_
  70. #ifdef __cplusplus
  71. extern "C" {
  72. #endif
  73. #include <ti/csl/soc.h>
  74. #include <ti/csl/csl.h>
  75. #include <ti/csl/cslr_ipc.h>
  76. /**
  77. @defgroup CSL_IPC_SYMBOL IPC Symbols Defined
  78. @ingroup CSL_IPC_API
  79. */
  80. /**
  81. @defgroup CSL_IPC_DATASTRUCT IPC Data Structures
  82. @ingroup CSL_IPC_API
  83. */
  84. /**
  85. @defgroup CSL_IPC_FUNCTION IPC Functions
  86. @ingroup CSL_IPC_API
  87. */
  88. /**
  89. @addtogroup CSL_IPC_SYMBOL
  90. @{
  91. */
  92. /**
  93. @}
  94. */
  95. /** @addtogroup CSL_IPC_DATASTRUCT
  96. @{ */
  97. /**
  98. * Handle to access IPC registers accessible through config bus.
  99. */
  100. #define hIpc ((CSL_IPCRegs *) (CSL_BOOT_CFG_REGS + 0x200))
  101. /* @} */
  102. /** @addtogroup CSL_IPC_FUNCTION
  103. @{ */
  104. /* @} */
  105. #ifdef __cplusplus
  106. }
  107. #endif
  108. #endif /*CSL_IPC_H_*/