SAMD21: Add memory map header file
This commit is contained in:
parent
b4682bd839
commit
62973af6eb
@ -394,10 +394,15 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (32*1024) /* 32KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
# if defined(CONFIG_ARCH_CHIP_SAMD21E15A)
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# else
|
||||
# define SAMDL_FLASHRWW_SIZE (1*1024) /* 1KB */
|
||||
# endif
|
||||
|
||||
#elif defined(CONFIG_ARCH_CHIP_SAMD21E16A) || defined(CONFIG_ARCH_CHIP_SAMD21E16B)
|
||||
|
||||
# define SAMD21 1 /* SAMD21 family */
|
||||
@ -408,10 +413,15 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (64*1024) /* 64KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
# if defined(CONFIG_ARCH_CHIP_SAMD21E16A)
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# else
|
||||
# define SAMDL_FLASHRWW_SIZE (2*1024) /* 2KB */
|
||||
# endif
|
||||
|
||||
#elif defined(CONFIG_ARCH_CHIP_SAMD21E17A)
|
||||
|
||||
# define SAMD21 1 /* SAMD21 family */
|
||||
@ -422,7 +432,7 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (128*1024) /* 128KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
@ -436,7 +446,7 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (256*1024) /* 256KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
@ -450,10 +460,15 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (32*1024) /* 32KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
# if defined(CONFIG_ARCH_CHIP_SAMD21G15A)
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# else
|
||||
# define SAMDL_FLASHRWW_SIZE (1*1024) /* 1KB */
|
||||
# endif
|
||||
|
||||
#elif defined(CONFIG_ARCH_CHIP_SAMD21G16A) || defined(CONFIG_ARCH_CHIP_SAMD21G16B)
|
||||
|
||||
# define SAMD21 1 /* SAMD21 family */
|
||||
@ -464,10 +479,15 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (64*1024) /* 64KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
# if defined(CONFIG_ARCH_CHIP_SAMD21G16A)
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# else
|
||||
# define SAMDL_FLASHRWW_SIZE (2*1024) /* 2KB */
|
||||
# endif
|
||||
|
||||
#elif defined(CONFIG_ARCH_CHIP_SAMD21G17A)
|
||||
|
||||
# define SAMD21 1 /* SAMD21 family */
|
||||
@ -478,7 +498,7 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (128*1024) /* 128KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
@ -492,7 +512,7 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (256*1024) /* 256KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
@ -506,10 +526,15 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (32*1024) /* 32KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_SRAM0_SIZE (4*1024) /* 4KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
# if defined(CONFIG_ARCH_CHIP_SAMD21J15A)
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# else
|
||||
# define SAMDL_FLASHRWW_SIZE (1*1024) /* 1KB */
|
||||
# endif
|
||||
|
||||
#elif defined(CONFIG_ARCH_CHIP_SAMD21J16A) || defined(CONFIG_ARCH_CHIP_SAMD21J16B)
|
||||
|
||||
# define SAMD21 1 /* SAMD21 family */
|
||||
@ -520,10 +545,15 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (64*1024) /* 64KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_SRAM0_SIZE (8*1024) /* 8KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
# if defined(CONFIG_ARCH_CHIP_SAMD21J16A)
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# else
|
||||
# define SAMDL_FLASHRWW_SIZE (2*1024) /* 2KB */
|
||||
# endif
|
||||
|
||||
#elif defined(CONFIG_ARCH_CHIP_SAMD21J17A)
|
||||
|
||||
# define SAMD21 1 /* SAMD21 family */
|
||||
@ -534,7 +564,7 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (128*1024) /* 128KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# define SAMDL_SRAM0_SIZE (16*1024) /* 16KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
@ -548,7 +578,7 @@
|
||||
/* Internal memory */
|
||||
|
||||
# define SAMDL_FLASH_SIZE (256*1024) /* 256KB */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None - except on B device variant */
|
||||
# define SAMDL_FLASHRWW_SIZE (0*1024) /* None */
|
||||
# define SAMDL_SRAM0_SIZE (32*1024) /* 32KB */
|
||||
# define SAMDL_LPRAM_SIZE (0*1024) /* None */
|
||||
|
||||
|
@ -1,9 +1,13 @@
|
||||
/****************************************************************************************
|
||||
* arch/arm/include/samd/samd21_irq.h
|
||||
*
|
||||
* Copyright (C) 2014 Gregory Nutt. All rights reserved.
|
||||
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* References:
|
||||
* "Atmel SAM D21E / SAM D21G / SAM D21J SMART ARM-Based Microcontroller
|
||||
* Datasheet", Atmel-42181E–SAM-D21_Datasheet–02/2015
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
|
@ -56,6 +56,8 @@
|
||||
|
||||
#if defined(CONFIG_ARCH_FAMILY_SAMD20)
|
||||
# include "chip/samd20_memorymap.h"
|
||||
#elif defined(CONFIG_ARCH_FAMILY_SAMD21)
|
||||
# include "chip/samd21_memorymap.h"
|
||||
#elif defined(CONFIG_ARCH_FAMILY_SAML21)
|
||||
# include "chip/saml21_memorymap.h"
|
||||
#else
|
||||
|
130
arch/arm/src/samdl/chip/samd21_memorymap.h
Normal file
130
arch/arm/src/samdl/chip/samd21_memorymap.h
Normal file
@ -0,0 +1,130 @@
|
||||
/********************************************************************************************
|
||||
* arch/arm/src/samdl/chip/samd21_memorymap.h
|
||||
*
|
||||
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* References:
|
||||
* "Atmel SAM D21E / SAM D21G / SAM D21J SMART ARM-Based Microcontroller
|
||||
* Datasheet", Atmel-42181E–SAM-D21_Datasheet–02/2015
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. 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.
|
||||
* 3. Neither the name NuttX 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 __ARCH_ARM_SRC_SAMDL_CHIP_SAMD21_MEMORYMAP_H
|
||||
#define __ARCH_ARM_SRC_SAMDL_CHIP_SAMD21_MEMORYMAP_H
|
||||
|
||||
/********************************************************************************************
|
||||
* Included Files
|
||||
********************************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
#include "chip.h"
|
||||
|
||||
/********************************************************************************************
|
||||
* Pre-processor Definitions
|
||||
********************************************************************************************/
|
||||
/* System Memory Map */
|
||||
|
||||
#define SAM_FLASH_BASE 0x00000000 /* Embedded FLASH memory space (<= 256KB) */
|
||||
#define SAM_FLASHRWW_BASE 0x00100000 /* Embedded FLASH RWW memory space (<= 2KB) */
|
||||
#define SAM_CALIB_BASE 0x00800000 /* Calibration and auxiliary space */
|
||||
#define SAM_SRAM_BASE 0x20000000 /* Embedded SRAM memory space (<= 64KB) */
|
||||
#define SAM_AHBA_BASE 0x40000000 /* AHB-APB Bridge A (64KB) */
|
||||
#define SAM_AHBB_BASE 0x41000000 /* AHB-APB Bridge B (64KB) */
|
||||
#define SAM_AHBC_BASE 0x42000000 /* AHB-APB Bridge C (64KB) */
|
||||
|
||||
/* Calibration and Auxiliary Space */
|
||||
|
||||
#define SAM_AUTOCAL_BASE 0x00800000 /* Automatic Calibration row */
|
||||
#define SAM_AUX0_BASE 0x00804000 /* AUX0 offset address */
|
||||
#define SAM_AUX1_BASE 0x00806000 /* AUX1 offset address */
|
||||
# define SAM_AUX1_AREA1 0x00806000 /* Area 1 offset address (reserved, 64 bits) */
|
||||
# define SAM_AUX1_AREA2 0x00806008 /* Area 2 Device configuration area (64 bits) */
|
||||
# define SAM_AUX1_AREA3 0x00806010 /* Area 3 offset address (reserved, 128 bits) */
|
||||
# define SAM_AUX1_AREA4 0x00806020 /* Area 4 Software calibration area (256 bits) */
|
||||
|
||||
/* AHB-APB Bridge A */
|
||||
|
||||
#define SAM_PAC0_BASE 0x40000000 /* Peripheral Access Controller 0 */
|
||||
#define SAM_PM_BASE 0x40000400 /* Power Manager */
|
||||
#define SAM_SYSCTRL_BASE 0x40000800 /* System Controller */
|
||||
#define SAM_GCLK_BASE 0x40000c00 /* Generic Clock Controller */
|
||||
#define SAM_WDT_BASE 0x40001000 /* Watchdog Timer */
|
||||
#define SAM_RTC_BASE 0x40001400 /* Real-Time Counter */
|
||||
#define SAM_EIC_BASE 0x40001800 /* External Interrupt Controller */
|
||||
|
||||
/* AHB-APB Bridge B */
|
||||
|
||||
#define SAM_PAC1_BASE 0x41000000 /* Peripheral Access Controller 1 */
|
||||
#define SAM_DSU_BASE 0x41002000 /* Device Service Unit */
|
||||
#define SAM_NVMCTRL_BASE 0x41004000 /* Non-Volatile Memory Controller */
|
||||
#define SAM_PORT_BASE 0x41004400 /* Ports */
|
||||
#define SAM_DMAC_BASE 0x41004800 /* DMA Controller */
|
||||
#define SAM_USB_BASE 0x41005000 /* USB */
|
||||
#define SAM_MTB_BASE 0x41006000 /* Micro Trace Buffer (MTB) */
|
||||
|
||||
/* AHB-APB Bridge C */
|
||||
|
||||
#define SAM_PAC2_BASE 0x42000000 /* Peripheral Access Controller 2 */
|
||||
#define SAM_EVSYS_BASE 0x42000400 /* Event System */
|
||||
#define SAM_SERCOM0_BASE 0x42000800 /* Serial Communication Interface 0 */
|
||||
#define SAM_SERCOM1_BASE 0x42000c00 /* Serial Communication Interface 1 */
|
||||
#define SAM_SERCOM2_BASE 0x42001000 /* Serial Communication Interface 2 */
|
||||
#define SAM_SERCOM3_BASE 0x42001400 /* Serial Communication Interface 3 */
|
||||
#define SAM_SERCOM4_BASE 0x42001800 /* Serial Communication Interface 4 */
|
||||
#define SAM_SERCOM5_BASE 0x42001c00 /* Serial Communication Interface 5 */
|
||||
#define SAM_TCC0_BASE 0x42002000 /* Timer/Counter Control 0 */
|
||||
#define SAM_TCC1_BASE 0x42002400 /* Timer/Counter Control 1 */
|
||||
#define SAM_TCC2_BASE 0x42002800 /* Timer/Counter Control 2 */
|
||||
#define SAM_TC3_BASE 0x42002c00 /* Timer/Counter 3 */
|
||||
#define SAM_TC4_BASE 0x42003000 /* Timer/Counter 4 */
|
||||
#define SAM_TC5_BASE 0x42003400 /* Timer/Counter 5 */
|
||||
#define SAM_TC6_BASE 0x42003800 /* Timer/Counter 6 */
|
||||
#define SAM_TC7_BASE 0x42003c00 /* Timer/Counter 7 */
|
||||
#define SAM_ADC_BASE 0x42004000 /* Analog-to-Digital Converter */
|
||||
#define SAM_AC_BASE 0x42004400 /* Analog Comparator*/
|
||||
#define SAM_DAC_BASE 0x42004800 /* Digital-to-Analog Converter */
|
||||
#define SAM_PTC_BASE 0x42004c00 /* Peripheral Touch Controller */
|
||||
#define SAM_I2S_BASE 0x42005000 /* Inter IC Sound */
|
||||
|
||||
/********************************************************************************************
|
||||
* Public Types
|
||||
********************************************************************************************/
|
||||
|
||||
/********************************************************************************************
|
||||
* Public Data
|
||||
********************************************************************************************/
|
||||
|
||||
/********************************************************************************************
|
||||
* Public Functions
|
||||
********************************************************************************************/
|
||||
|
||||
#endif /* __ARCH_ARM_SRC_SAMDL_CHIP_SAMD21_MEMORYMAP_H */
|
Loading…
Reference in New Issue
Block a user