123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219 |
- /* ============================================================================
- * Copyright (c) Texas Instruments Incorporated 2008, 2009
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- *
- * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the
- * distribution.
- *
- * Neither the name of Texas Instruments Incorporated nor the names of
- * its contributors may be used to endorse or promote products derived
- * from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
- /**
- * @file csl_xmc.h
- *
- * @brief
- * XMC CSL Implementation on DSP side
- *
- * \par
- * ============================================================================
- * @n (C) Copyright 2008, 2009, Texas Instruments, Inc.
- * @n Use of this software is controlled by the terms and conditions found
- * @n in the license agreement under which this software has been supplied.
- * ===========================================================================
- * \par
- */
- /** @defgroup CSL_XMC_API XMC
- *
- * @section Introduction
- *
- * @subsection xxx Overview
- *
- * The XMC takes on the following roles:
- * a) UMC to VBusM conversion
- * b) Shared memory access path
- * c) Prefetch support
- * d) Address extension/translation
- * e) Memory protection for addresses outside CGEM eg. MSMC RAM or EMIF
- *
- * @subsection References
- * -# XMC User's Guide
- *
- * @subsection Assumptions
- * The abbreviations XMC, xmc and Xmc have been used throughout this
- * document to refer to CGEM eXtended Memory Controller
- */
- #ifndef CSL_XMC_H
- #define CSL_XMC_H
- #ifdef __cplusplus
- extern "C" {
- #endif
- #include <ti/csl/soc.h>
- #include <ti/csl/csl.h>
- #include <ti/csl/cslr_xmc.h>
- /**
- @defgroup CSL_XMC_SYMBOL XMC Symbols Defined
- @ingroup CSL_XMC_API
- */
- /**
- @defgroup CSL_XMC_DATASTRUCT XMC Data Structures
- @ingroup CSL_XMC_API
- */
- /**
- @defgroup CSL_XMC_FUNCTION XMC Functions
- @ingroup CSL_XMC_API
- */
- /** @addtogroup CSL_XMC_DATASTRUCT
- @{ */
- /** @brief This is the definition of CSL_XMC_XMPAXH */
- typedef struct CSL_XMC_XMPAXH_s
- {
- /** Base Address */
- Uint32 bAddr;
-
- /** Encoded Segment Size */
- Uint8 segSize;
- }CSL_XMC_XMPAXH;
- /** @brief This is the definition of CSL_XMC_XMPAXL */
- typedef struct CSL_XMC_XMPAXL_s
- {
- /** Replacement Address */
- Uint32 rAddr;
-
- /** When set, supervisor may read from segment */
- Uint32 sr;
- /** When set, supervisor may write to segment */
- Uint32 sw;
-
- /** When set, supervisor may execute from segment */
- Uint32 sx;
-
- /** When set, user may read from segment */
- Uint32 ur;
- /** When set, user may write to segment */
- Uint32 uw;
- /** When set, user may execute from segment */
- Uint32 ux;
- }CSL_XMC_XMPAXL;
- /** @brief This is the definition of CSL_XMC_MPFSR */
- typedef struct CSL_XMC_MPFSR_s
- {
- /** Local Access ? */
- Uint32 local;
-
- /** When set, indicates a Supervisor Read Request */
- Uint32 sr;
-
- /** When set, indicates a Supervisor Write Request */
- Uint32 sw;
-
- /** When set, indicates a Supervisor program fetch Request */
- Uint32 sx;
-
- /** When set, indicates a User Read Request */
- Uint32 ur;
-
- /** When set, indicates a User Write Request */
- Uint32 uw;
- /** When set, indicates a User program fetch Request */
- Uint32 ux;
- }CSL_XMC_MPFSR;
- /** @brief This is the definition of CSL_XMC_XPFADDR */
- typedef struct CSL_XMC_XPFADDR_s
- {
- /** Stream address (128-bit aligned) */
- Uint32 addr;
- /** Sign bit of stream direction (0=fwd, 1=rev) */
- Uint32 dir;
-
- /** Data pending for upper ("high") half */
- Uint32 dph;
-
- /** Data valid for upper half */
- Uint32 dvh;
-
- /** Address valid for upper half */
- Uint32 avh;
-
- /** Data pending for lower half */
- Uint32 dpl;
-
- /** Data valid for lower half */
- Uint32 dvl;
-
- /** Address valid for lower half */
- Uint32 avl;
- }CSL_XMC_XPFADDR;
- /** @brief This is the definition of CSL_XMC_ACEN_MODE */
- typedef enum {
- /** Disable analysis counters. */
- CSL_XMC_ACEN_MODE_COUNT_DISABLE = 0,
- /** Count Program events only. */
- CSL_XMC_ACEN_MODE_COUNT_PROGEVENTS = 1,
- /** Count Data events only. */
- CSL_XMC_ACEN_MODE_COUNT_DATAEVENTS = 2,
- /** Count both program and data events. */
- CSL_XMC_ACEN_MODE_COUNT_ALL = 3
- }CSL_XMC_ACEN_MODE;
-
- /**
- * Handle to access XMC registers accessible through config bus.
- */
- #ifndef CSL_XMC_CFG_REGS
- #if defined(SOC_C6678)||defined(SOC_C6657)
- #define CSL_XMC_CFG_REGS (CSL_XMC_CONFIG_REGS)
- #else
- #define CSL_XMC_CFG_REGS (CSL_DSP_DSP_XMC_CTRL_REGS)
- #endif
- #endif
- #define hXmc ((CSL_XmcRegs*)CSL_XMC_CFG_REGS)
- /**
- @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /* CSL_XMC_H */
|