/* **************************************************************************** PROJECT : VLIB macro device level config FILE : $Id: r_config_g3dma.h 7180 2016-01-07 17:45:54Z tobyas.hennig $ ============================================================================ DESCRIPTION G3DMA configuration for D1x ============================================================================ C O P Y R I G H T ============================================================================ Copyright (c) 2015 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. ******************************************************************************** */ #ifndef CONFIG_G3DMA_H_ #define CONFIG_G3DMA_H_ /******************************************************************************* Title: G3DMA device configuration Configuration of the device dependanant part of the G3DMA macro */ /******************************************************************************* Section: Global Defines */ /******************************************************************************* Constant: R_G3DMA_MACRO_NUM Number of macros in the device (this is the value relevant for SW, not necessary the real HW implementation. */ #define R_G3DMA_MACRO_NUM 1u /******************************************************************************* Constant: R_DMA_CHANNEL_NUM Number of available DMA channels */ #define R_DMA_CHANNEL_NUM 16u /******************************************************************************* Constant: R_G3DMA_BASE Base address for the macro registers */ #define R_G3DMA_BASE 0xFFFF8000u #define R_DMA_CHANNEL_OFFSET 0x40u #define R_DTFR_CHANNEL_OFFSET 0x02u /*********************************************************** Macro: R_G3DMA_WRITE_REG Write G3DMAC register with predefined size. SIZE allowed values are 8, 16, 32 */ #ifdef R_DBG_PRINT_G3DMA_REGS #define R_G3DMA_WRITE_REG(SIZE, ADDR, VALUE) \ { \ R_DBG_PrintRegCmd((SIZE), (ADDR), (VALUE)); \ *(( volatile uint##SIZE##_t * )(ADDR)) = (VALUE); \ } #else #define R_G3DMA_WRITE_REG(SIZE, ADDR, VALUE) \ { \ *(( volatile uint##SIZE##_t * )(ADDR)) = (VALUE); \ } #endif /*********************************************************** Macro: R_G3DMA_READ_REG Read G3DMAC register with predefined size. SIZE allowed values are 8, 16, 32 */ #ifdef R_DBG_PRINT_G3DMA_REGS #define R_G3DMA_READ_REG(SIZE, ADDR) (R_DBG_PrintRegRead##SIZE##(ADDR)) #else #define R_G3DMA_READ_REG(SIZE, ADDR) (*(( volatile uint##SIZE##_t * )((ADDR)))) #endif #endif /* CONFIG_G3DMA_H_ */