r_sys_g3dma.c 5.4 KB
Newer Older
时昊's avatar
时昊 committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181
/*
****************************************************************************
PROJECT : VLIB macro device level driver
FILE    : $Id: r_sys_g3dma.c 4630 2015-01-13 16:48:47Z golczewskim $
============================================================================
DESCRIPTION
G3DMA system functions for d1x_scit
============================================================================
                            C O P Y R I G H T
============================================================================
                           Copyright (c) 2012
                                  by
                       Renesas Electronics (Europe) GmbH.
                           Arcadiastrasse 10
                          D-40472 Duesseldorf
                               Germany
                          All rights reserved.
============================================================================
Purpose: only for testing

DISCLAIMER
This software is supplied by Renesas Electronics Corporation and is only
intended for use with Renesas products. No other uses are authorized. This
software is owned by Renesas Electronics Corporation and is protected under
all applicable laws, including copyright laws.
THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES REGARDING
THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING BUT NOT
LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY DISCLAIMED.
TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
ELECTRONICS CORPORATION NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES FOR
ANY REASON RELATED TO THIS SOFTWARE, EVEN IF RENESAS OR ITS AFFILIATES HAVE
BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
Renesas reserves the right, without notice, to make changes to this software
and to discontinue the availability of this software. By using this software,
you agree to the additional terms and conditions found by accessing the
following link:
http://www.renesas.com/disclaimer *
Copyright (C) 2011 Renesas Electronics Corporation. All rights reserved.

****************************************************************************
*/

/*******************************************************************************
  Title: dev_g3dma G3DMA device functions

  Implementation of the G3DMA support functions for the
  device d1x_scit.
*/

/*******************************************************************************
  Section: Includes
*/

#include "r_typedefs.h"
#include "r_dev_api.h"
#include "r_dma_api.h"
#include "r_g3dma_api.h"
#include "r_g3dma_sys.h"
#include "r_config_g3dma.h"

#if defined(R_DBG_PRINT_DEV_REGS) || defined(R_DBG_PRINT_MSG)
    #include <stdio.h>
    #include "r_dbg_api.h"
#else
    #define R_DBG_PRINT(lvl, txt)
#endif

/*******************************************************************************
  Section: Local Constants
*/

static const r_dev_IntSel_t loc_IntAddress [ R_DMA_CHANNEL_NUM ] = {
    R_DEV_INT_DMA0,
    R_DEV_INT_DMA1,
    R_DEV_INT_DMA2,
    R_DEV_INT_DMA3,
    R_DEV_INT_DMA4,
    R_DEV_INT_DMA5,
    R_DEV_INT_DMA6,
    R_DEV_INT_DMA7,
};

/*******************************************************************************
  Section: Global Functions

*/

/*******************************************************************************
  Function: R_G3DMA_SYS_BaseAddr

  See: r_g3dma_sys.h for details
*/

uint32_t R_G3DMA_SYS_BaseAddr(uint32_t Unit)
{
    return R_G3DMA_BASE;
}

/*******************************************************************************
  Function: R_G3DMA_SYS_HardwareInit

  See: r_g3dma_sys.h for details
*/

r_g3dma_Error_t R_G3DMA_SYS_HardwareInit(uint32_t Unit)
{
    return R_G3DMA_ERR_OK;
}
/*******************************************************************************
  Function: R_G3DMA_SYS_HardwareDeInit

  See: r_g3dma_sys.h for details
*/

r_g3dma_Error_t R_G3DMA_SYS_HardwareDeInit(uint32_t Unit)
{
    return R_G3DMA_ERR_OK;
}

/*******************************************************************************
  Function: R_G3DMA_SYS_EnableInt
*/

void R_G3DMA_SYS_EnableInt(uint32_t Unit, uint32_t ChId)
{
    switch ( Unit )
    {
        case 0:
            /* check ChId ?! */
            /**/
            R_DEV_IntEnable(loc_IntAddress [ ChId ], 1);
            break;
        default:
            R_DEV_ERROR(Unit, R_DEV_ERR_UNIT, "G3DMA: We do not have this Unit");
            break;
    }
}

/*******************************************************************************
  Function: R_G3DMA_SYS_DisableInt
*/

void R_G3DMA_SYS_DisableInt(uint32_t Unit, uint32_t ChId)
{
    switch ( Unit )
    {
        case 0:
            /* check ChId ?! */
            /**/
            R_DEV_IntEnable(loc_IntAddress [ ChId ], 1);
            break;
        default:
            R_DEV_ERROR(Unit, R_DEV_ERR_UNIT, "G3DMA: We do not have this Unit");
            break;
    }
}

/***********************************************************
  Function: R_G3DMA_SYS_GetDmaBaseAddr
*/

uint32_t R_G3DMA_SYS_GetDmaBaseAddr(uint32_t Unit, uint32_t ChId)
{
    uint32_t addr;

    addr = (ChId * R_DMA_CHANNEL_OFFSET) + R_G3DMA_BASE;
    return addr;
}

/***********************************************************
  Function: R_G3DMA_SYS_GetNoOfChannels
*/

uint32_t R_G3DMA_SYS_GetNoOfChannels(uint32_t Unit)
{
    uint32_t addr;
    addr = R_DMA_CHANNEL_NUM;
    return addr;
}