empty_project_28377D/device/driverlib/inc/hw_dma.h

164 lines
8.4 KiB
C

//###########################################################################
//
// FILE: hw_dma.h
//
// TITLE: Definitions for the DMA registers.
//
//###########################################################################
// $Copyright:
// Copyright (C) 2022 Texas Instruments Incorporated - http://www.ti.com
//
// 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.
// $
//###########################################################################
#ifndef HW_DMA_H
#define HW_DMA_H
//*************************************************************************************************
//
// The following are defines for the DMA register offsets
//
//*************************************************************************************************
#define DMA_O_CTRL 0x0U // DMA Control Register
#define DMA_O_DEBUGCTRL 0x1U // Debug Control Register
#define DMA_O_PRIORITYCTRL1 0x4U // Priority Control 1 Register
#define DMA_O_PRIORITYSTAT 0x6U // Priority Status Register
#define DMA_O_MODE 0x0U // Mode Register
#define DMA_O_CONTROL 0x1U // Control Register
#define DMA_O_BURST_SIZE 0x2U // Burst Size Register
#define DMA_O_BURST_COUNT 0x3U // Burst Count Register
#define DMA_O_SRC_BURST_STEP 0x4U // Source Burst Step Register
#define DMA_O_DST_BURST_STEP 0x5U // Destination Burst Step Register
#define DMA_O_TRANSFER_SIZE 0x6U // Transfer Size Register
#define DMA_O_TRANSFER_COUNT 0x7U // Transfer Count Register
#define DMA_O_SRC_TRANSFER_STEP 0x8U // Source Transfer Step Register
#define DMA_O_DST_TRANSFER_STEP 0x9U // Destination Transfer Step Register
#define DMA_O_SRC_WRAP_SIZE 0xAU // Source Wrap Size Register
#define DMA_O_SRC_WRAP_COUNT 0xBU // Source Wrap Count Register
#define DMA_O_SRC_WRAP_STEP 0xCU // Source Wrap Step Register
#define DMA_O_DST_WRAP_SIZE 0xDU // Destination Wrap Size Register
#define DMA_O_DST_WRAP_COUNT 0xEU // Destination Wrap Count Register
#define DMA_O_DST_WRAP_STEP 0xFU // Destination Wrap Step Register
#define DMA_O_SRC_BEG_ADDR_SHADOW 0x10U // Source Begin Address Shadow Register
#define DMA_O_SRC_ADDR_SHADOW 0x12U // Source Address Shadow Register
#define DMA_O_SRC_BEG_ADDR_ACTIVE 0x14U // Source Begin Address Active Register
#define DMA_O_SRC_ADDR_ACTIVE 0x16U // Source Address Active Register
#define DMA_O_DST_BEG_ADDR_SHADOW 0x18U // Destination Begin Address Shadow Register
#define DMA_O_DST_ADDR_SHADOW 0x1AU // Destination Address Shadow Register
#define DMA_O_DST_BEG_ADDR_ACTIVE 0x1CU // Destination Begin Address Active Register
#define DMA_O_DST_ADDR_ACTIVE 0x1EU // Destination Address Active Register
//*************************************************************************************************
//
// The following are defines for the bit fields in the DMACTRL register
//
//*************************************************************************************************
#define DMA_CTRL_HARDRESET 0x1U // Hard Reset Bit
#define DMA_CTRL_PRIORITYRESET 0x2U // Priority Reset Bit
//*************************************************************************************************
//
// The following are defines for the bit fields in the DEBUGCTRL register
//
//*************************************************************************************************
#define DMA_DEBUGCTRL_FREE 0x8000U // Debug Mode Bit
//*************************************************************************************************
//
// The following are defines for the bit fields in the PRIORITYCTRL1 register
//
//*************************************************************************************************
#define DMA_PRIORITYCTRL1_CH1PRIORITY 0x1U // Ch1 Priority Bit
//*************************************************************************************************
//
// The following are defines for the bit fields in the PRIORITYSTAT register
//
//*************************************************************************************************
#define DMA_PRIORITYSTAT_ACTIVESTS_S 0U
#define DMA_PRIORITYSTAT_ACTIVESTS_M 0x7U // Active Channel Status Bits
#define DMA_PRIORITYSTAT_ACTIVESTS_SHADOW_S 4U
#define DMA_PRIORITYSTAT_ACTIVESTS_SHADOW_M 0x70U // Active Channel Status Shadow Bits
//*************************************************************************************************
//
// The following are defines for the bit fields in the MODE register
//
//*************************************************************************************************
#define DMA_MODE_PERINTSEL_S 0U
#define DMA_MODE_PERINTSEL_M 0x1FU // Peripheral Interrupt and Sync Select
#define DMA_MODE_OVRINTE 0x80U // Overflow Interrupt Enable
#define DMA_MODE_PERINTE 0x100U // Peripheral Interrupt Enable
#define DMA_MODE_CHINTMODE 0x200U // Channel Interrupt Mode
#define DMA_MODE_ONESHOT 0x400U // One Shot Mode Bit
#define DMA_MODE_CONTINUOUS 0x800U // Continuous Mode Bit
#define DMA_MODE_DATASIZE 0x4000U // Data Size Mode Bit
#define DMA_MODE_CHINTE 0x8000U // Channel Interrupt Enable Bit
//*************************************************************************************************
//
// The following are defines for the bit fields in the CONTROL register
//
//*************************************************************************************************
#define DMA_CONTROL_RUN 0x1U // Run Bit
#define DMA_CONTROL_HALT 0x2U // Halt Bit
#define DMA_CONTROL_SOFTRESET 0x4U // Soft Reset Bit
#define DMA_CONTROL_PERINTFRC 0x8U // Interrupt Force Bit
#define DMA_CONTROL_PERINTCLR 0x10U // Interrupt Clear Bit
#define DMA_CONTROL_ERRCLR 0x80U // Error Clear Bit
#define DMA_CONTROL_PERINTFLG 0x100U // Interrupt Flag Bit
#define DMA_CONTROL_TRANSFERSTS 0x800U // Transfer Status Bit
#define DMA_CONTROL_BURSTSTS 0x1000U // Burst Status Bit
#define DMA_CONTROL_RUNSTS 0x2000U // Run Status Bit
#define DMA_CONTROL_OVRFLG 0x4000U // Overflow Flag Bit
//*************************************************************************************************
//
// The following are defines for the bit fields in the BURST_SIZE register
//
//*************************************************************************************************
#define DMA_BURST_SIZE_BURSTSIZE_S 0U
#define DMA_BURST_SIZE_BURSTSIZE_M 0x1FU // Burst Transfer Size
//*************************************************************************************************
//
// The following are defines for the bit fields in the BURST_COUNT register
//
//*************************************************************************************************
#define DMA_BURST_COUNT_BURSTCOUNT_S 0U
#define DMA_BURST_COUNT_BURSTCOUNT_M 0x1FU // Burst Transfer Size
#endif