merge fs changes.

This commit is contained in:
TXuian 2024-03-12 16:37:08 +08:00
commit 85b5d365df
373 changed files with 167964 additions and 286 deletions

View File

@ -36,10 +36,9 @@ History:
1. Date: 2024-01-25
Author: AIIT XUOS Lab
Modification:
1. support inode create and delete
3. remove inode lock and unlock
4. remove inode cache
5. rename function names(DirInodeAddEntry,DirInodeLookup, InodeAlloc, InodeFree, PathElementExtract, InodeBlockMapping, Seek, InodeSeek, InodeParentSeek, InodeRead, InodeWrite) to fit XIZI_AIoT use sceneries
1. remove inode lock and unlock
2. remove inode cache
3. rewrite skipelem function to PathElementExtract to fit XIZI_AIoT use sceneries
*************************************************/
#include <string.h>
@ -48,22 +47,15 @@ Modification:
#include "fs.h"
#include "libserial.h"
static void Error(char* s)
{
printf("Error: %s\n", s);
for (;;)
;
}
#define min(a, b) ((a) < (b) ? (a) : (b))
#define MIN_LENGTH(len1, len2) ((len1) < (len2) ? (len1) : (len2))
static int DirInodeAddEntry(struct Inode* dp, char* name, uint32_t inum);
static struct Inode* DirInodeLookup(struct Inode* dp, char* name, uint32_t* poff);
static struct Inode* InodeAlloc(short type);
static int InodeFree(struct Inode* ip);
static int DirInodeDelEntry(struct Inode* parent_inode, char* name);
static struct Inode* DirInodeLookup(struct Inode* dp, char* name);
static struct Inode* InodeAlloc(int type);
static int InodeFreeRecursive(struct Inode* dp);
static char* PathElementExtract(char* path, char* name);
static uint32_t InodeBlockMapping(struct Inode* ip, uint32_t block_num);
static uint32_t InodeBlockMapping(struct Inode* inode, uint32_t block_num);
#define MAX_SUPPORT_FD 1024
static struct FileDescriptor fd_table[MAX_SUPPORT_FD];
@ -80,83 +72,236 @@ void MemFsInit(uintptr_t _binary_fs_img_start, uint32_t fs_img_len)
/// @brief Read the super block.
void ReadSuperBlock(struct SuperBlock* sb)
{
uint8_t* data = BlockRead(ROOT_INUM);
memmove(sb, data, sizeof(*sb));
uint8_t* block = BlockRead(ROOT_INUM);
memmove(sb, block, sizeof(*sb));
}
/// @brief Get a existed Inode by inum
struct Inode* InodeGet(uint32_t inum)
{
struct Inode* ip;
uint8_t* data = BlockRead(BLOCK_INDEX(inum));
ip = (struct Inode*)data + INODE_INDEX(inum);
return ip;
struct Inode* inode;
uint8_t* block = BlockRead(BLOCK_INDEX(inum));
inode = (struct Inode*)block + INODE_INDEX(inum);
return inode;
}
/// @brief Create a new Inode under the parent Inode
struct Inode* InodeCreate(struct Inode* parent_inode, char* name, int type)
{
struct Inode* inode;
if ((inode = DirInodeLookup(parent_inode, name)) != 0) {
if (type == FS_FILE && inode->type == FS_FILE) {
return inode;
}
return 0;
}
if ((inode = InodeAlloc(type)) == 0) {
printf("InodeCreate: alloc Inode failed, no free inode\n");
return 0;
}
if (type == FS_DIRECTORY) {
if (DirInodeAddEntry(inode, ".", inode->inum) < 0 || DirInodeAddEntry(inode, "..", parent_inode->inum) < 0) {
printf("InodeCreate: create dots");
return 0;
}
}
if (DirInodeAddEntry(parent_inode, name, inode->inum) < 0) {
printf("InodeCreate: DirInodeAddEntry failed");
return 0;
}
return inode;
}
/// @brief Delete a file Inode or a dir Inode
int InodeDelete(struct Inode* parent_inode, char* name)
{
uint32_t offset;
struct Inode* inode;
struct DirectEntry de;
if ((inode = DirInodeLookup(parent_inode, name)) == 0) {
printf("Inode delete failed, file not exsit");
return -1;
}
if (inode->type == FS_FILE) {
inode->type = 0;
} else if (inode->type == FS_DIRECTORY) {
// recursive free alloced Inode
if (InodeFreeRecursive(inode) < 0) {
return -1;
}
}
DirInodeDelEntry(parent_inode, name);
return 0;
}
/// @brief Read data from the Inode to the dst buffer.
int InodeRead(struct Inode* inode, char* dst, int offset, int len)
{
uint32_t location, writen_len;
uint8_t* block;
if (len < 0 || offset > inode->size) {
return -1;
}
if (offset + len > inode->size) {
len = inode->size - offset;
}
location = 0;
while (location < len) {
if ((block = BlockRead(InodeBlockMapping(inode, offset / BLOCK_SIZE))) == 0) {
return 0;
}
writen_len = MIN_LENGTH(len - location, BLOCK_SIZE - offset % BLOCK_SIZE);
memmove(dst, block + offset % BLOCK_SIZE, writen_len);
location += writen_len;
offset += writen_len;
dst += writen_len;
}
return len;
}
/// @brief Write data from src buffer to the Inode, then increase the Inode size if neccessary.
int InodeWrite(struct Inode* inode, char* src, int offset, int len)
{
uint32_t location, writen_len;
uint8_t* block;
if (len < 0 || offset > inode->size) {
return -1;
}
if (offset + len > MAX_FILE_SIZE * BLOCK_SIZE) {
return -1;
}
location = 0;
while (location < len) {
if ((block = BlockRead(InodeBlockMapping(inode, offset / BLOCK_SIZE))) == 0) {
return 0;
}
writen_len = MIN_LENGTH(len - location, BLOCK_SIZE - offset % BLOCK_SIZE);
memmove(block + offset % BLOCK_SIZE, src, writen_len);
location += writen_len;
offset += writen_len;
src += writen_len;
}
if (len > 0 && offset > inode->size) {
inode->size = offset;
}
return len;
}
/// @brief Find target Inode from source Inode
struct Inode* InodeSeek(struct Inode* source, char* path)
{
if (source->size == 0) {
printf("Inode is empty\n");
return 0;
}
char name[DIR_NAME_SIZE] = { 0 };
struct Inode *cur_inode, *next_inode;
cur_inode = source;
while ((path = PathElementExtract(path, name)) != 0) {
if (cur_inode->type != FS_DIRECTORY) {
return NULL;
}
if ((next_inode = DirInodeLookup(cur_inode, name)) == 0) {
return NULL;
}
cur_inode = next_inode;
}
return cur_inode;
}
/// @brief Find target parent Inode from source Inode
struct Inode* InodeParentSeek(struct Inode* source, char* path, char* name)
{
if (source->size == 0) {
printf("Inode is empty\n");
return 0;
}
struct Inode *cur_inode, *next_inode;
cur_inode = source;
while ((path = PathElementExtract(path, name)) != 0) {
if (cur_inode->type != FS_DIRECTORY) {
return NULL;
}
if (*path == '\0') {
return cur_inode;
}
if ((next_inode = DirInodeLookup(cur_inode, name)) == 0) {
return NULL;
}
cur_inode = next_inode;
}
return NULL;
}
/// @brief Alloc a new Inode using type
static struct Inode* InodeAlloc(short type)
static struct Inode* InodeAlloc(int type)
{
int inum;
struct Inode* ip;
struct Inode* inode;
struct SuperBlock sb;
ReadSuperBlock(&sb);
for (inum = 1; inum < sb.ninodes; inum++) {
uint8_t* data = BlockRead(BLOCK_INDEX(inum));
ip = (struct Inode*)data + INODE_INDEX(inum);
if (ip->type == 0) {
memset(ip, 0, sizeof(*ip));
ip->inum = inum;
ip->type = type;
ip->nlink = 1;
ip->size = 0;
return ip;
uint8_t* block = BlockRead(BLOCK_INDEX(inum));
inode = (struct Inode*)block + INODE_INDEX(inum);
if (inode->type == 0) {
memset(inode, 0, sizeof(*inode));
inode->inum = inum;
inode->type = type;
inode->size = 0;
return inode;
}
}
Error("InodeAlloc: no inodes");
return NULL;
}
/// @brief Free the existed Inode
static int InodeFree(struct Inode* ip)
{
uint8_t* data = BlockRead(BLOCK_INDEX(ip->inum));
struct Inode* dip = (struct Inode*)data + INODE_INDEX(ip->inum);
dip->type = 0;
return 0;
}
/// @brief Delete the dir and all files or dirs under the dir.
static int InodeFreeRecursive(struct Inode* dp)
static int InodeFreeRecursive(struct Inode* parent_inode)
{
uint32_t off;
struct Inode* ip;
uint32_t offset;
struct Inode* inode;
struct DirectEntry de;
for (off = 0; off < dp->size; off += sizeof(de)) {
if (InodeRead(dp, (char*)&de, off, sizeof(de)) != sizeof(de)) {
Error("inode_delete_dir failed: read directory entry failed");
for (offset = 0; offset < parent_inode->size; offset += sizeof(de)) {
if (InodeRead(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("inode_delete_dir failed: read directory entry failed");
return -1;
}
// unlink dir
if (de.inum == 0 || strcmp(de.name, "..") == 0 || strcmp(de.name, ".") == 0) {
continue;
}
ip = InodeGet(de.inum);
if (ip->type == T_DIR) {
if (InodeFreeRecursive(ip) < 0) {
inode = InodeGet(de.inum);
if (inode->type == FS_DIRECTORY) {
if (InodeFreeRecursive(inode) < 0) {
return -1;
}
} else if (ip->type == T_FILE) {
InodeFree(ip);
} else if (inode->type == FS_FILE) {
inode->type = 0;
}
// delete the dir entry
de.inum = 0;
if (InodeWrite(dp, (char*)&de, off, sizeof(de)) != sizeof(de)) {
if (InodeWrite(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("InodeDelete failed: clear directory entry failed");
return -1;
}
@ -164,74 +309,14 @@ static int InodeFreeRecursive(struct Inode* dp)
return 0;
}
/// @brief Delete a file Inode or a dir Inode
int InodeDelete(struct Inode* dp, char* name)
{
uint32_t off;
struct Inode* ip;
struct DirectEntry de;
if ((ip = DirInodeLookup(dp, name, &off)) == 0) {
Error("Inode delete failed, file not exsit");
return -1;
}
InodeFree(ip);
if (ip->type == T_DIR) {
// recursive free alloced Inode
if (InodeFreeRecursive(ip) < 0) {
return -1;
}
}
// delete the dir entry
de.inum = 0;
if (InodeWrite(dp, (char*)&de, off, sizeof(de)) != sizeof(de)) {
printf("InodeDelete failed: clear directory entry failed");
return -1;
}
return 0;
}
/// @brief Create a new Inode under the parent Inode
struct Inode* InodeCreate(struct Inode* dp, char* name, short type, short major, short minor)
{
uint32_t off;
struct Inode* ip;
if ((ip = DirInodeLookup(dp, name, &off)) != 0) {
if (type == T_FILE && ip->type == T_FILE) {
return ip;
}
return 0;
}
if ((ip = InodeAlloc(type)) == 0) {
Error("InodeCreate: create Inode failed\n");
}
if (type == T_DIR) {
dp->nlink++;
if (DirInodeAddEntry(ip, ".", ip->inum) < 0 || DirInodeAddEntry(ip, "..", dp->inum) < 0) {
Error("InodeCreate: create dots");
}
}
if (DirInodeAddEntry(dp, name, ip->inum) < 0) {
Error("InodeCreate: DirInodeAddEntry failed");
}
return ip;
}
/// @brief Mapping the direct block addrs or indirect block addrs of the Inode using the block_num
static uint32_t InodeBlockMapping(struct Inode* ip, uint32_t block_num)
static uint32_t InodeBlockMapping(struct Inode* inode, uint32_t block_num)
{
uint32_t addr;
// block is in range of direct mapping
if (block_num < NR_DIRECT_BLOCKS) {
if ((addr = ip->addrs[block_num]) == 0) {
ip->addrs[block_num] = addr = BlockAlloc();
if ((addr = inode->addrs[block_num]) == 0) {
inode->addrs[block_num] = addr = BlockAlloc();
}
return addr;
}
@ -240,12 +325,12 @@ static uint32_t InodeBlockMapping(struct Inode* ip, uint32_t block_num)
block_num -= NR_DIRECT_BLOCKS;
int indirect_block_id = block_num / MAX_INDIRECT_BLOCKS;
if (indirect_block_id < NR_INDIRECT_BLOCKS) {
if ((addr = ip->addrs[NR_DIRECT_BLOCKS + indirect_block_id]) == 0) {
ip->addrs[NR_DIRECT_BLOCKS + indirect_block_id] = addr = BlockAlloc();
if ((addr = inode->addrs[NR_DIRECT_BLOCKS + indirect_block_id]) == 0) {
inode->addrs[NR_DIRECT_BLOCKS + indirect_block_id] = addr = BlockAlloc();
}
block_num -= indirect_block_id * MAX_INDIRECT_BLOCKS;
} else {
Error("InodeBlockMapping: out of range");
printf("InodeBlockMapping: out of range");
return 0;
}
@ -259,18 +344,20 @@ static uint32_t InodeBlockMapping(struct Inode* ip, uint32_t block_num)
}
/// @brief Look up the directory Inode for searching the target Inode
static struct Inode* DirInodeLookup(struct Inode* dp, char* name, uint32_t* poff)
static struct Inode* DirInodeLookup(struct Inode* parent_inode, char* name)
{
uint32_t off, inum;
uint32_t offset, inum;
struct DirectEntry de;
if (dp->type != T_DIR) {
Error("DirInodeLookup not DIR");
if (parent_inode->type != FS_DIRECTORY) {
printf("DirInodeLookup not DIR");
return 0;
}
for (off = 0; off < dp->size; off += sizeof(de)) {
if (InodeRead(dp, (char*)&de, off, sizeof(de)) != sizeof(de)) {
Error("DirInodeAddEntry read");
for (offset = 0; offset < parent_inode->size; offset += sizeof(de)) {
if (InodeRead(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("DirInodeAddEntry read");
return 0;
}
if (de.inum == 0) {
@ -278,9 +365,6 @@ static struct Inode* DirInodeLookup(struct Inode* dp, char* name, uint32_t* poff
}
if (strncmp((const char*)name, (const char*)de.name, DIR_NAME_SIZE) == 0) {
if (poff) {
*poff = off;
}
inum = de.inum;
return InodeGet(inum);
}
@ -290,21 +374,22 @@ static struct Inode* DirInodeLookup(struct Inode* dp, char* name, uint32_t* poff
}
/// @brief Add a new directory entry for dir Inode
static int DirInodeAddEntry(struct Inode* dp, char* name, uint32_t inum)
static int DirInodeAddEntry(struct Inode* parent_inode, char* name, uint32_t inum)
{
int off;
int offset;
struct DirectEntry de;
struct Inode* ip;
struct Inode* inode;
// Check that direct entry is existed.
if ((ip = DirInodeLookup(dp, name, 0)) != 0) {
// Check the direct entry is not existed.
if ((inode = DirInodeLookup(parent_inode, name)) != 0) {
return -1;
}
// Look for an empty dir entry.
for (off = 0; off < dp->size; off += sizeof(de)) {
if (InodeRead(dp, (char*)&de, off, sizeof(de)) != sizeof(de)) {
Error("DirInodeAddEntry: read failed");
for (offset = 0; offset < parent_inode->size; offset += sizeof(de)) {
if (InodeRead(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("DirInodeAddEntry: read failed");
return -1;
}
if (de.inum == 0) {
@ -315,98 +400,45 @@ static int DirInodeAddEntry(struct Inode* dp, char* name, uint32_t inum)
// build a new direct entry.
strncpy(de.name, name, DIR_NAME_SIZE);
de.inum = inum;
if (InodeWrite(dp, (char*)&de, off, sizeof(de)) != sizeof(de)) {
Error("DirInodeAddEntry: write failed");
if (InodeWrite(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("DirInodeAddEntry: write failed");
return -1;
}
return 0;
}
static struct Inode* Seek(struct Inode* ip, char* path, int nameiparent, char* name)
/// @brief Delete the directory entry for dir Inode
static int DirInodeDelEntry(struct Inode* parent_inode, char* name)
{
if (ip->size == 0) {
Error("Inode is not sync\n");
}
int offset;
struct DirectEntry de;
struct Inode* inode;
struct Inode* next;
while ((path = PathElementExtract(path, name)) != 0) {
if (ip->type != T_DIR) {
return NULL;
}
if (nameiparent && *path == '\0') {
return ip;
}
if ((next = DirInodeLookup(ip, name, 0)) == 0) {
return NULL;
}
ip = next;
}
if (nameiparent) {
return NULL;
}
return ip;
}
/// @brief Find target Inode from source Inode
struct Inode* InodeSeek(struct Inode* source, char* path)
{
char name[DIR_NAME_SIZE] = { 0 };
return Seek(source, path, 0, name);
}
/// @brief Find target parent Inode from source Inode
struct Inode* InodeParentSeek(struct Inode* source, char* path, char* name)
{
return Seek(source, path, 1, name);
}
/// @brief Read data from the Inode to the dst buffer.
int InodeRead(struct Inode* ip, char* dst, int off, int n)
{
uint32_t tot, m;
if (off > ip->size || off + n < off) {
// Check the direct entry is existed.
if ((inode = DirInodeLookup(parent_inode, name)) == 0) {
return -1;
}
if (off + n > ip->size) {
n = ip->size - off;
// Look for an empty dir entry.
for (offset = 0; offset < parent_inode->size; offset += sizeof(de)) {
if (InodeRead(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("DirInodeAddEntry: read failed");
return -1;
}
if (strncmp(de.name, name, DIR_NAME_SIZE) == 0) {
break;
}
}
for (tot = 0; tot < n; tot += m, off += m, dst += m) {
uint8_t* data = BlockRead(InodeBlockMapping(ip, off / BLOCK_SIZE));
m = min(n - tot, BLOCK_SIZE - off % BLOCK_SIZE);
memmove(dst, data + off % BLOCK_SIZE, m);
}
return n;
}
/// @brief Write data from src buffer to the Inode, then increase the Inode size if neccessary.
int InodeWrite(struct Inode* ip, char* src, uint32_t off, uint32_t n)
{
uint32_t tot, m;
if (off > ip->size || off + n < off) {
de.inum = 0;
if (InodeWrite(parent_inode, (char*)&de, offset, sizeof(de)) != sizeof(de)) {
printf("DirInodeAddEntry: write failed");
return -1;
}
if (off + n > MAX_FILE_SIZE * BLOCK_SIZE) {
return -1;
}
for (tot = 0; tot < n; tot += m, off += m, src += m) {
uint8_t* data = BlockRead(InodeBlockMapping(ip, off / BLOCK_SIZE));
m = min(n - tot, BLOCK_SIZE - off % BLOCK_SIZE);
memmove(data + off % BLOCK_SIZE, src, m);
}
if (n > 0 && off > ip->size) {
ip->size = off;
}
return n;
return 0;
}
// Paths process

View File

@ -110,7 +110,7 @@ int IPC_DO_SERVE_FUNC(Ipc_cd)(char* path)
return -1;
}
if (ip->type != T_DIR) {
if (ip->type != FS_DIRECTORY) {
printf("cd:not a dir\n");
return -1;
}
@ -148,7 +148,7 @@ int IPC_DO_SERVE_FUNC(Ipc_mkdir)(char* path)
return -1;
}
if (InodeCreate(ip, name, T_DIR, 0, 0) == 0) {
if (InodeCreate(ip, name, FS_DIRECTORY) == 0) {
printf("create target Inode %s failed\n", path);
return -1;
}
@ -207,7 +207,7 @@ int IPC_DO_SERVE_FUNC(Ipc_cat)(char* path)
return -1;
}
if (ip->type != T_FILE) {
if (ip->type != FS_FILE) {
printf("cat: %s Is not a file\n", path);
return -1;
}
@ -254,7 +254,6 @@ int IPC_DO_SERVE_FUNC(Ipc_open)(char* path)
/// @todo record absolute path
strncpy(fdp->path, path, strlen(path) + 1);
ip->nlink++;
fdp->data = ip;
return fd;
@ -262,15 +261,6 @@ int IPC_DO_SERVE_FUNC(Ipc_open)(char* path)
int IPC_DO_SERVE_FUNC(Ipc_close)(int* fd)
{
struct FileDescriptor* fdp = GetFileDescriptor(*fd);
if (!fdp) {
printf("read: fd invalid\n");
return -1;
}
struct Inode* ip = fdp->data;
ip->nlink--;
FreeFileDescriptor(*fd);
return 0;
}
@ -285,7 +275,7 @@ int IPC_DO_SERVE_FUNC(Ipc_read)(int* fd, char* dst, int* offset, int* len)
}
struct Inode* ip = fdp->data;
if (ip->type != T_FILE) {
if (ip->type != FS_FILE) {
printf("read: %s Is not a file\n", fdp->path);
return -1;
}
@ -305,7 +295,7 @@ int IPC_DO_SERVE_FUNC(Ipc_write)(int* fd, char* src, int* offset, int* len)
}
struct Inode* ip = fdp->data;
if (ip->type != T_FILE) {
if (ip->type != FS_FILE) {
printf("read: %s Is not a file\n", fdp->path);
return -1;
}

View File

@ -1,15 +1,46 @@
/*
* Copyright (c) 2020 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
// Copyright (c) 2006-2018 Frans Kaashoek, Robert Morris, Russ Cox, Massachusetts Institute of Technology
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
/**
* @file fs.h
* @brief file system important struct definition
* @version 1.0
* @author AIIT XUOS Lab
* @date 2024-01-25
*/
/*************************************************
File name: fs.h
Description: file system important struct definition
Others: take ARM_XV6 kernel/fs.h and kernel/file.h for references
https://github.com/KingofHamyang/ARM_xv6
History:
1. Date: 2024-01-25
Author: AIIT XUOS Lab
Modification:
1. remove nlog member of superblock struct
2. rebuild inode struct to fit XIZI_AIoT use sceneries
3. change direct and indirect block number to fit XIZI_AIoT use sceneries
*************************************************/
#pragma once
#include <stdint.h>
@ -33,19 +64,12 @@ struct MemFsRange {
uint32_t memfs_nr_blocks;
};
// current state of the Inode
enum INODE_STATE {
I_RESERVED = 0,
I_BUSY,
I_VALID
};
// memfs file type
enum FILE_TYPE {
T_RESERVED = 0,
T_DIR, // Directory
T_FILE, // File
T_DEV, // Device
FS_RESERVED = 0,
FS_DIRECTORY, // Directory
FS_FILE, // File
FS_DEVICE, // Device
};
// File system super block
@ -55,20 +79,10 @@ struct SuperBlock {
uint32_t ninodes; // Number of inodes.
};
// state of the Inode
struct State {
short type; // Type of file
int dev; // File system's disk device
uint32_t ino; // Inode number
short nlink; // Number of links to file
uint32_t size; // Size of file in bytes
};
// Inode structure
struct Inode {
uint32_t inum; // Inode number
short type; // File type
short nlink; // Number of links to Inode in file system
uint32_t type; // File type
uint32_t size; // Size of file (bytes)
uint32_t addrs[NR_DIRECT_BLOCKS + NR_INDIRECT_BLOCKS]; // Data block addresses
};
@ -85,7 +99,6 @@ struct DirectEntry {
struct FileDescriptor {
char path[MAX_PATH_LEN];
void* data;
struct State st;
};
// range of memory fs
@ -96,10 +109,10 @@ void ReadSuperBlock(struct SuperBlock*);
// fs Inode ops
struct Inode* InodeGet(uint32_t inum);
struct Inode* InodeCreate(struct Inode*, char*, short, short, short);
struct Inode* InodeCreate(struct Inode*, char*, int);
int InodeDelete(struct Inode*, char*);
int InodeRead(struct Inode*, char*, int, int);
int InodeWrite(struct Inode*, char*, uint32_t, uint32_t);
int InodeWrite(struct Inode*, char*, int, int);
struct Inode* InodeSeek(struct Inode*, char*);
struct Inode* InodeParentSeek(struct Inode*, char*, char*);

View File

@ -38,7 +38,7 @@ Author: AIIT XUOS Lab
Modification:
1. Increse the number of blocks and inodes
2. support more than one indirect blocks
3. remove unused stat
3. remove unused stat and nlink property of inode struct
*************************************************/
#include <assert.h>
@ -136,7 +136,7 @@ int main(int argc, char* argv[])
wsect(1, buf);
// build root
rootino = ialloc(T_DIR);
rootino = ialloc(FS_DIRECTORY);
assert(rootino == ROOT_INUM);
bzero(&de, sizeof(de));
@ -165,7 +165,7 @@ int main(int argc, char* argv[])
if (argv[i][0] == '_')
++argv[i];
inum = ialloc(T_FILE);
inum = ialloc(FS_FILE);
bzero(&de, sizeof(de));
de.inum = xshort(inum);
@ -251,7 +251,6 @@ uint ialloc(ushort type)
bzero(&din, sizeof(din));
din.type = xshort(type);
din.nlink = xshort(1);
din.size = xint(0);
din.inum = inum;
winode(inum, &din);

View File

@ -37,14 +37,14 @@ History:
Author: AIIT XUOS Lab
Modification:
1. Increse the number of indirect blocks
2. Rename some variables' name for readability
2. Remove unused nlink of inode struct
*************************************************/
#pragma once
#define T_DIR 1 // Directory
#define T_FILE 2 // File
#define T_DEV 3 // Device
#define FS_DIRECTORY 1 // Directory
#define FS_FILE 2 // File
#define FS_DEVICE 3 // Device
#define ROOT_INUM 1 // root inode number
#define BLOCK_SIZE 512 // block size
@ -74,8 +74,7 @@ struct SuperBlock {
// Inode structure
struct Inode {
uint inum; // inode number
short type; // File type
short nlink; // Number of links to inode in file system
uint type; // File type
uint size; // Size of file (bytes)
uint addrs[NR_DIRECT_BLOCKS + NR_INDIRECT_BLOCKS]; // Data block addresses
};

View File

@ -6,7 +6,7 @@ MAKEFLAGS += --no-print-directory
riscv_support := kd233 maix-go hifive1-rev-B gapuino gd32vf103-rvstar rv32m1-vega aiit-riscv64-board xidatong-riscv64 edu-riscv64 ch32v307vct6
arm_support += stm32f407-st-discovery stm32f407zgt6 stm32f103-nano nuvoton-m2354 ok1052-c imxrt1176-sbc aiit-arm32-board xidatong-arm32 xiwangtong-arm32 edu-arm32 xishutong-arm32 rzv2l-m33
arm_support += stm32f407-st-discovery stm32f407zgt6 stm32f103-nano nuvoton-m2354 ok1052-c imxrt1176-sbc aiit-arm32-board xidatong-arm32 xiwangtong-arm32 edu-arm32 xishutong-arm32 rzv2l-m33 rzg2ul-m33
emulator_support += hifive1-emulator k210-emulator cortex-m0-emulator cortex-m3-emulator cortex-m4-emulator cortex-m7-emulator
support := $(riscv_support) $(arm_support) $(emulator_support)

View File

@ -64,4 +64,8 @@ ifeq ($(CONFIG_BOARD_RZV2L_M33),y)
SRC_DIR += cortex-m33
endif
ifeq ($(CONFIG_BOARD_RZG2UL_M33),y)
SRC_DIR += cortex-m33
endif
include $(KERNEL_ROOT)/compiler.mk

View File

@ -0,0 +1,43 @@
mainmenu "XiZi_IIoT Project Configuration"
config BSP_DIR
string
option env="BSP_ROOT"
default "."
config KERNEL_DIR
string
option env="KERNEL_ROOT"
default "../.."
config BOARD_RZG2UL_M33
bool
select ARCH_ARM
default y
source "$KERNEL_DIR/arch/Kconfig"
menu "rzg2ul m33 feature"
menu "config default board resources"
menu "config board app name"
config BOARD_APP_NAME
string "config board app name"
default "/XiUOS_rzg2ul_m33_app.bin"
endmenu
menu "config board service table"
config SERVICE_TABLE_ADDRESS
hex "board service table address"
default 0x20000000
endmenu
endmenu
endmenu
menu "Hardware feature"
source "$KERNEL_DIR/resources/Kconfig"
endmenu
source "$KERNEL_DIR/Kconfig"

View File

@ -0,0 +1,5 @@
SRC_FILES := $(wildcard *.c)
SRC_DIR := rzg rzg_gen src
include $(KERNEL_ROOT)/compiler.mk

View File

@ -0,0 +1,228 @@
# 从零开始构建矽璓工业物联操作系统:使用 RZ/G2UL 开发板的Cortex-M33核心
[XiUOS](http://xuos.io/) (X Industrial Ubiquitous Operating System) 矽璓工业物联操作系统是一款面向工业物联场景的泛在操作系统,来自泛在操作系统研究计划。所谓泛在操作系统(UOS: Ubiquitous Operating Systems)是支持互联网时代人机物融合泛在计算应用模式的新型操作系统是传统操作系统概念的泛化与延伸。在泛在操作系统技术体系中不同的泛在计算设备和泛在应用场景需要符合各自特性的不同UOSXiUOS即是面向工业物联场景的一种UOS主要由一个极简的微型实时操作系统(RTOS)内核和其上的智能工业物联框架构成,支持工业物联网(IIoT: Industrial Internet of Things)应用。
## 一、开发环境搭建
### 操作系统Ubuntu 20.04 Ubuntu 18.04也可以)
### 1、Ubuntu 20.04 换源 Ubuntu 18.04可自行百度)
### 1、打开sources.list文件
```c
sudo vim /etc/apt/sources.list
```
### 2、将以下内容复制到sources.list文件
```c
deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
```
### 3、更新源和系统软件
```c
sudo apt-get update
sudo apt-get upgrade
```
### 2、项目依赖包安装
```c
$ sudo apt install build-essential pkg-config git
$ sudo apt install gcc make libncurses5-dev openssl libssl-dev bison flex libelf-dev autoconf libtool gperf libc6-dev
```
### 3、开发工具安装
**开发工具推荐使用 VSCode VScode下载地址为** VSCode [https://code.visualstudio.com/](https://code.visualstudio.com/)
### 4、VSCode 插件安装
**推荐安装下图所示插件:**
![VSCode插件推荐](img/vscode-plugins.png "VSCode插件推荐")
### 5、XiUOS操作系统源码下载
XiUOS [https://www.gitlink.org.cn/xuos/xiuos](https://www.gitlink.org.cn/xuos/xiuos)
新建一个空文件夹并进入文件夹中,并下载源码,具体命令如下:
```c
mkdir test && cd test
git clone https://gitlink.org.cn/xuos/xiuos.git
```
1、打开XiUOS源码文件包可以看到以下目录
| 名称 | 说明 |
| -- | -- |
| APP_Framework | 应用代码 |
| Ubiquitous | 板级支持包,支持NuttX、RT-Thread和XiZi内核 |
2、打开XiZi内核源码文件包可以看到以下目录
| 名称 | 说明 |
| -- | -- |
| arch | 架构代码 |
| board | 板级支持包 |
| fs | 文件系统 |
| kernel | 内核源码 |
| lib | 第三方库源码 |
| resources | 驱动文件 |
| tool | 系统工具 |
使用VScode打开代码具体操作步骤为在源码文件夹下打开系统终端输入`code .`即可打开VScode开发环境如下图所示
![VSCode介绍](img/vscode.jpg "VSCode介绍")
### 6、裁减配置工具的下载
**工具地址:** kconfig-frontends [https://www.gitlink.org.cn/xuos/kconfig-frontends](https://www.gitlink.org.cn/xuos/kconfig-frontends),下载与安装的具体命令如下:
```c
mkdir kfrontends && cd kfrontends
git clone https://gitlink.org.cn/xuos/kconfig-frontends.git
```
下载源码后按以下步骤执行软件安装:
```c
cd kconfig-frontends
./xs_build.sh
```
### 7、编译工具链安装
**下载GNU ARM Embedded Toolchain** gcc-arm-none-eabi-10.3-2021.10-x86_64-linux.tar.bz2 [https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads](https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads)
**下载Libgen Update for GNU ARM Embedded Toolchains** Libgen Update (Linux) for GCC ARM Embedded Toolchains v1.2023.11 or later [https://gcc-renesas.com/rz/rz-download-toolchains/](https://gcc-renesas.com/rz/rz-download-toolchains/)
**GNU ARM Embedded Toolchain 安装位置推荐:/usr/local/arm**
**找到下载的工具链更新包 Libgen ,并运行以下命令:**
```c
sudo chmod 755 LibgenUpdateInstall_v1.2023.11.run
sudo ./LibgenUpdateInstall_v1.2023.11.run
```
**运行后输入ARM工具链根目录、回车再输入 y 以确认**
![更新编译工具链](img/libgen-update.png "更新编译工具链")
**至此,编译环境已经安装完毕**
## 二、系统源代码编译步骤
### 1、编译前准备修改编译链位置
### 1修改文件 xiuos/Ubiquitous/XiZi_IIoT/board/rzg2ul-m33/config.mk
``` c
// 参照原本的数据将其修改为自己的编译链位置
export CROSS_COMPILE ?=/usr/local/arm/gcc-arm-none-eabi-10.3-2021.10/bin/arm-none-eabi-
```
### 2修改文件 xiuos/Ubiquitous/XiZi_IIoT/board/rzg2ul-m33/script/postbuild.sh
``` c
// 参照原本的数据将其修改为自己的目标文件位置
inputfilename={path to}/xiuos/Ubiquitous/XiZi_IIoT/build/XiZi-rzg2ul-m33.elf
// 将 objcopy 工具路径改为自己的路径
{path to}/gcc-arm-none-eabi-10.3-2021.10/bin/arm-none-eabi-objcopy
```
### 2、编译配置
在VScode命令终端中执行以下命令生成配置文件
```c
cd ./Ubiquitous/XiZi
make BOARD=rzg2ul-m33 distclean
make BOARD=rzg2ul-m33 menuconfig
```
### 3、编译
在VScode命令终端中执行以下命令以开始编译
```c
make BOARD=rzg2ul-m33
```
等待编译完成:生成`XiZi-rzg2ul-m33.elf`等文件
![编译结果](img/compile-result.png "编译结果")
### 4、编译输出处理
`RZ/G2UL`的`M33`端没有`FLASH`,需要借助 `boot-loader` 加载到内存中直接运行。
同时因为内存映射跨度大,不能作为一个`bin`文件进行烧录,需要将其拆分为多个`bin`文件由`loader`逐一加载。
```c
// 打开VSCode终端进入目录 Ubiquitous/XiZi_IIoT/board/rzg2ul-m33/script 执行脚本 postbuild.sh
./postbuild.sh
```
生成的文件:安全/非安全的中断向量表和代码数据段共四个文件
![运行文件提取](img/postbuild-result.png "运行文件提取")
## 三、运行执行
### 1、BootLoader烧录
BootLoader的烧录、Linux端的编译参照官方注意M33的串口2输出引脚与USB0冲突不能同时使用同时需要修改Linux配置文件
```c
// 文件 /kernel-source/drivers/clk/renesas/r9a07g043-cpg.c 修改如下以防止串口2在Linux启动过程中被重置
static const unsigned int r9a07g043_crit_mod_clks[] __initconst = {
MOD_CLK_BASE + R9A07G043_GIC600_GICCLK,
MOD_CLK_BASE + R9A07G043_IA55_PCLK,
MOD_CLK_BASE + R9A07G043_IA55_CLK,
MOD_CLK_BASE + R9A07G043_DMAC_ACLK,
MOD_CLK_BASE + R9A07G043_OSTM2_PCLK, // 用于M33时钟心跳
MOD_CLK_BASE + R9A07G043_SCIF2_CLK_PCK, // 用于M33串口输出
};
```
### 2、将生成的文件拷贝到上一步生成的SD卡里
![复制到内存卡](img/copy-bin-to-sd.png "复制到内存卡")
> 在上一步中SD被划分为两个逻辑分区一个作为根文件系统RZ_ext一个用于存放系统镜像RZ_FAT包含Linux镜像、设备数已经刚放进去的M33端程序
### 3、物理连接
`SCIF2_TX/RX`作为M33核心的输出串口`RZ_SCIF0_TX/RX`作为Linux的输出串口`GND`共地;
![硬件连接](img/connection-state.jpg "硬件连接")
### 4、修改 boot 参数以自动加载
```c
// 1. 加载安全区代码的环境变量
setenv bootcmd_m3_sec_load "fatload mmc 1:1 0x0001FF80 rzg2ul_cm33_rpmsg_demo_secure_vector.bin; fatload mmc 1:1 0x42EFF440 rzg2ul_cm33_rpmsg_demo_secure_code.bin"
// 2. 加载非安全区代码的环境变量
setenv bootcmd_m3_nosec_load "fatload mmc 1:1 0x00010000 rzg2ul_cm33_rpmsg_demo_non_secure_vector.bin; fatload mmc 1:1 0x40010000 rzg2ul_cm33_rpmsg_demo_non_secure_code.bin"
// 3. 防止环境变量过长,合并文件加载
setenv bootcmd_m3_load "run bootcmd_m3_nosec_load; run bootcmd_m3_sec_load"
// 4. M33 启动环境变量
setenv bootcmd_m3_start "cm33 start_debug 0x1001FF80 0x00010000"
// 5. 合并M33启动加载环境变量
setenv bootcmd_m3_boot "dcache off; mmc dev 1; run bootcmd_m3_load; run bootcmd_m3_start; dcache on"
// 6. Boot会在超时后自动执行 bootcmd 将M33的启动命令加入该环境变量
setenv bootcmd "run bootcmd_m3_boot" // 注意若是需要启动Linux需要把Linux内核的启动命令也放入该环境变量
// 7. 保存环境变量
saveenv
```
### 5、运行M33
**将SD插入卡槽按下开发板 reset 按键**
![启动M33](img/run-result.jpeg "启动M33")
## 四、核间通信测试
> XiUOS 将收到的数据打印后返回到Linux
### 1、在M33端创建监听任务
```c
CreateRPMsgTask // 该命令会创建一个通信节点在探测到Linux的第一条信息时该通信节点被激活
```
![通信节点创造](img/rpmsg_create.png "通信节点创造")
### 2、在Linux端启动核间通信测试例程
```c
rpmsg_sample_client
```
![测试启动](img/rpmsg_test_begin.png "测试启动")
### 3、测试结果
![测试结果](img/rpmsg_test_result.png "测试结果")

View File

@ -0,0 +1,21 @@
export CROSS_COMPILE ?=/usr/local/arm/gcc-arm-none-eabi-10.3-2021.10/bin/arm-none-eabi-
# DEBUG
# CFLAGS := -mthumb -mcpu=cortex-m33+nodsp+nofp -fdiagnostics-parseable-fixits -Og -fmessage-length=0 -fsigned-char -ffunction-sections -fdata-sections
# CFLAGS += -Wunused -Wuninitialized -Wall -Wextra -Wmissing-declarations -Wconversion -Wpointer-arith -Wshadow -Wlogical-op -Waggregate-return -Wfloat-equal
# CFLAGS += -Wnull-dereference
# CFLAGS += -g -std=c99 -mcmse
# RELEASE
CFLAGS := -mthumb -mcpu=cortex-m33+nodsp+nofp -fdiagnostics-parseable-fixits -Og -fmessage-length=0 -fsigned-char -ffunction-sections -fdata-sections
CFLAGS += -Wunused -Wuninitialized -Wall -Wextra -Wmissing-declarations -Wconversion -Wpointer-arith -Wshadow -Wlogical-op
CFLAGS += -Waggregate-return -Wfloat-equal -Wnull-dereference -g -std=c99 -mcmse
export CFLAGS
export LFLAGS := -mthumb -mcpu=cortex-m33+nodsp+nofp -ffunction-sections -fdata-sections -Wl,--gc-sections,-Map=XiZi-rzg2ul-m33.map,-cref,-u,Warm_Reset_S -T $(BSP_ROOT)/link.lds
export DEFINES := -DHAVE_CCONFIG_H
export ARCH = arm
export MCU = cortex-m33

View File

@ -0,0 +1,313 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<raConfiguration version="8">
<generalSettings>
<option key="#Board#" value="board.rzg2ul_smarc"/>
<option key="CPU" value="RZG2UL"/>
<option key="#TargetName#" value="R9A07G043U12GBG_CM33"/>
<option key="#TargetARCHITECTURE#" value="cortex-m33"/>
<option key="#DeviceCommand#" value="R9A07G043U12GBG_CM33"/>
<option key="#RTOS#" value="rtos.awsfreertos"/>
<option key="#pinconfiguration#" value="R9A07G043U12GBG_CM33.pincfg"/>
<option key="#FSPVersion#" value="2.0.0"/>
<option key="#ConfigurationFragments#" value="Renesas##BSP##Board##rzg2ul_smarc##"/>
<option key="#SELECTED_TOOLCHAIN#" value="gcc-arm-embedded"/>
<option key="#ToolchainVersion#" value="10.3.1.20210824"/>
</generalSettings>
<raBspConfiguration>
<config id="config.bsp.rzg2ul.R9A07G043U12GBG_CM33">
<property id="config.bsp.part_number" value="config.bsp.part_number.value"/>
<property id="config.bsp.rom_size_bytes" value="config.bsp.rom_size_bytes.value"/>
<property id="config.bsp.ram_size_bytes" value="config.bsp.ram_size_bytes.value"/>
<property id="config.bsp.package_style" value="config.bsp.package_style.value"/>
<property id="config.bsp.package_pins" value="config.bsp.package_pins.value"/>
</config>
<config id="config.bsp.rzg2ul">
<property id="config.bsp.series" value="config.bsp.series.value"/>
</config>
<config id="config.bsp.rzg2ul.fsp">
<property id="config.bsp.fsp.mcu.adc_c.min_adc.sampling_time" value="6"/>
<property id="config.bsp.fsp.mcu.adc_c.max_adc.sampling_time" value="2800"/>
<property id="config.bsp.fsp.mcu.canfd.max_data_rate_hz" value="4"/>
<property id="config.bsp.fsp.mcu.canfd.min_nominal_timeseg1" value="4"/>
<property id="config.bsp.fsp.mcu.canfd.max_nominal_timeseg1" value="128"/>
<property id="config.bsp.fsp.mcu.canfd.max_nominal_timeseg2" value="32"/>
<property id="config.bsp.fsp.mcu.canfd.max_nominal_sync_jump_width" value="32"/>
<property id="config.bsp.fsp.mcu.canfd.max_data_prescaler" value="256"/>
<property id="config.bsp.fsp.mcu.canfd.max_data_timeseg1" value="16"/>
<property id="config.bsp.fsp.mcu.canfd.max_data_timeseg2" value="8"/>
<property id="config.bsp.fsp.mcu.canfd.max_data_sync_jump_width" value="8"/>
<property id="config.bsp.fsp.mcu.canfd.afl_rules" value="128"/>
<property id="config.bsp.fsp.mcu.canfd.afl_rules_each_chnl" value="64"/>
<property id="config.bsp.fsp.mcu.spi.max_bitrate" value="25000000"/>
</config>
<config id="config.bsp.rz">
<property id="config.bsp.common.secure_stack" value="0x200"/>
<property id="config.bsp.common.main" value="0x200"/>
<property id="config.bsp.common.heap" value="0"/>
<property id="config.bsp.common.vcc" value="3300"/>
<property id="config.bsp.common.checking" value="config.bsp.common.checking.disabled"/>
<property id="config.bsp.common.assert" value="config.bsp.common.assert.none"/>
<property id="config.bsp.common.error_log" value="config.bsp.common.error_log.none"/>
<property id="config.bsp.common.pfs_protect" value="config.bsp.common.pfs_protect.enabled"/>
<property id="config.bsp.common.c_runtime_init" value="config.bsp.common.c_runtime_init.enabled"/>
</config>
</raBspConfiguration>
<raClockConfiguration>
<node id="board.clock.osc.freq" mul="24000000" option="_edit"/>
<node id="board.clock.iclk.freq" mul="1000000000" option="_edit"/>
<node id="board.clock.i2clk.freq" mul="200000000" option="_edit"/>
<node id="board.clock.s0clk.freq" mul="12000" option="_edit"/>
<node id="board.clock.spi0clk.freq" mul="200000000" option="_edit"/>
<node id="board.clock.spi1clk.freq" mul="100000000" option="_edit"/>
<node id="board.clock.sd0clk.freq" mul="533000000" option="_edit"/>
<node id="board.clock.sd1clk.freq" mul="533000000" option="_edit"/>
<node id="board.clock.m0clk.freq" mul="200000000" option="_edit"/>
<node id="board.clock.m2clk.freq" mul="266500000" option="_edit"/>
<node id="board.clock.m3clk.freq" mul="3000000000" option="_edit"/>
<node id="board.clock.hpclk.freq" mul="250000000" option="_edit"/>
<node id="board.clock.tsuclk.freq" mul="80000000" option="_edit"/>
<node id="board.clock.ztclk.freq" mul="100000000" option="_edit"/>
<node id="board.clock.p0clk.freq" mul="100000000" option="_edit"/>
<node id="board.clock.p1clk.freq" mul="200000000" option="_edit"/>
<node id="board.clock.p2clk.freq" mul="100000000" option="_edit"/>
<node id="board.clock.atclk.freq" mul="400000000" option="_edit"/>
</raClockConfiguration>
<raComponentSelection>
<component apiversion="" class="BSP" condition="" group="Board" subgroup="rzg2ul_smarc" variant="" vendor="Renesas" version="2.0.0">
<description>Evaluation Kit RZ/G2L Support Files (RZ/G2UL)</description>
<originalPack>Renesas.RZG_board_rzg2ul_smarc.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="Middleware" condition="" group="OpenAMP" subgroup="all" variant="" vendor="Linaro" version="1.0.0+fsp.2.0.0">
<description>OpenAMP</description>
<originalPack>Linaro.OpenAMP.1.0.0+fsp.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="Middleware" condition="" group="OpenAMP" subgroup="libmetal" variant="" vendor="Linaro" version="1.0.0+fsp.2.0.0">
<description>libmetal</description>
<originalPack>Linaro.OpenAMP.1.0.0+fsp.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="Middleware" condition="" group="OpenAMP" subgroup="open-amp" variant="" vendor="Linaro" version="1.0.0+fsp.2.0.0">
<description>open-amp</description>
<originalPack>Linaro.OpenAMP.1.0.0+fsp.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="BSP" condition="" group="rzg2ul" subgroup="device" variant="R9A07G043U12GBG_CM33" vendor="Renesas" version="2.0.0">
<description>Board support package for R9A07G043U12GBG_CM33</description>
<originalPack>Renesas.RZG_mcu_rzg2ul.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="BSP" condition="" group="rzg2ul" subgroup="device" variant="" vendor="Renesas" version="2.0.0">
<description>Board support package for RZG2UL</description>
<originalPack>Renesas.RZG_mcu_rzg2ul.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="BSP" condition="" group="rzg2ul" subgroup="fsp" variant="" vendor="Renesas" version="2.0.0">
<description>Board support package for RZ/G2L (RZ/G2UL) - FSP Data</description>
<originalPack>Renesas.RZG_mcu_rzg2ul.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="RTOS" condition="" group="FreeRTOS" subgroup="all" variant="" vendor="AWS" version="10.4.6+fsp.2.0.0">
<description>FreeRTOS</description>
<originalPack>Amazon.FreeRTOS-Kernel.10.4.6+fsp.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="Heaps" condition="" group="FreeRTOS" subgroup="heap_4" variant="" vendor="AWS" version="10.4.6+fsp.2.0.0">
<description>FreeRTOS - Memory Management - Heap 4</description>
<originalPack>Amazon.FreeRTOS-Kernel.10.4.6+fsp.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="Middleware" condition="" group="all" subgroup="rm_freertos_port" variant="" vendor="Renesas" version="2.0.0">
<description>FreeRTOS Port</description>
<originalPack>Renesas.RZG.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="Common" condition="" group="all" subgroup="fsp_common" variant="" vendor="Renesas" version="2.0.0">
<description>Board Support Package Common Files</description>
<originalPack>Renesas.RZG.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="HAL Drivers" condition="" group="all" subgroup="r_gtm" variant="" vendor="Renesas" version="2.0.0">
<description>General Timer</description>
<originalPack>Renesas.RZG.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="HAL Drivers" condition="" group="all" subgroup="r_ioport" variant="" vendor="Renesas" version="2.0.0">
<description>I/O Port</description>
<originalPack>Renesas.RZG.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="HAL Drivers" condition="" group="all" subgroup="r_mhu_ns" variant="" vendor="Renesas" version="2.0.0">
<description>Message Handler Unit (NonSecure)</description>
<originalPack>Renesas.RZG.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="HAL Drivers" condition="" group="all" subgroup="r_scif_uart" variant="" vendor="Renesas" version="2.0.0">
<description>SCIF UART</description>
<originalPack>Renesas.RZG.2.0.0.pack</originalPack>
</component>
<component apiversion="" class="CMSIS" condition="" group="CMSIS5" subgroup="CoreM" variant="" vendor="Arm" version="5.9.0+fsp.2.0.0">
<description>Arm CMSIS Version 5 - Core (M)</description>
<originalPack>Arm.CMSIS5.5.9.0+fsp.2.0.0.pack</originalPack>
</component>
</raComponentSelection>
<raElcConfiguration/>
<raIcuConfiguration/>
<raModuleConfiguration>
<module id="module.driver.ioport_on_ioport.0">
<property id="module.driver.ioport.name" value="g_ioport"/>
<property id="module.driver.ioport.pincfg" value="g_bsp_pin_cfg"/>
</module>
<module id="module.driver.timer_on_gtm.2">
<property id="module.driver.timer.name" value="g_timer2"/>
<property id="module.driver.timer.channel" value="enum.mcu.gtm.channels.2"/>
<property id="module.driver.timer.mode" value="module.driver.timer.mode.mode_periodic"/>
<property id="module.driver.timer.period" value="1000"/>
<property id="module.driver.timer.unit" value="module.driver.timer.unit.unit_frequency_hz"/>
<property id="module.driver.timer.count_source" value="module.driver.timer.count_source.clock_p0clk"/>
<property id="module.driver.timer.p_callback" value="NULL"/>
<property id="module.driver.timer.ipl" value="255"/>
<property id="module.driver.timer.int.generateatstart" value="module.driver.timer.int.generateatstart.0"/>
<property id="module.driver.timer.direction" value="module.driver.timer.direction.0"/>
</module>
<module id="module.freertos.heap.4.4"/>
<module id="module.middleware.rm_freertos_port.0"/>
<module id="module.driver.mhu_ns.1921636645">
<property id="module.driver.mhu_ns.name" value="g_mhu_ns0"/>
<property id="module.driver.mhu_ns.channel" value="enum.mcu.mhu.channels.1"/>
<property id="module.driver.mhu_ns.p_callback" value="NULL"/>
<property id="module.driver.mhu_ns.is_use_openamp" value="module.driver.mhu_ns.is_use_openamp.1"/>
<property id="module.driver.mhu_ns.ipl" value="12"/>
<property id="module.driver.mhu_ns.shmem" value="0"/>
</module>
<module id="module.driver.uart_on_scif_uart.580040235">
<property id="module.driver.uart.name" value="g_uart0"/>
<property id="module.driver.uart.channel" value="0"/>
<property id="module.driver.uart.data_bits" value="module.driver.uart.data_bits.data_bits_8"/>
<property id="module.driver.uart.parity" value="module.driver.uart.parity.parity_off"/>
<property id="module.driver.uart.stop_bits" value="module.driver.uart.stop_bits.stop_bits_1"/>
<property id="module.driver.uart.baud" value="115200"/>
<property id="module.driver.uart.baudrate_modulation" value="module.driver.uart.baudrate_modulation.disabled"/>
<property id="module.driver.uart.baudrate_max_err" value="5"/>
<property id="module.driver.uart.uart_comm_mode" value="module.driver.uart.uart_comm_mode.uart_rs232_mode"/>
<property id="module.driver.uart.pin_polarity" value="module.driver.uart.pin_polarity.high"/>
<property id="module.driver.uart.pin_control_port" value="module.driver.uart.pin_control_port.PORT_DISABLE"/>
<property id="module.driver.uart.pin_control_pin" value="module.driver.uart.pin_control_pin.PIN_DISABLE"/>
<property id="module.driver.uart.autoflow" value="module.driver.uart.autoflow.disable"/>
<property id="module.driver.uart.clk_src" value="module.driver.uart.clk_src.int_clk"/>
<property id="module.driver.uart.noisecancel_en" value="module.driver.uart.noisecancel_en.disabled"/>
<property id="module.driver.uart.rx_fifo_trigger" value="module.driver.uart.rx_fifo_trigger.max"/>
<property id="module.driver.uart.rts_fifo_trigger" value="module.driver.uart.rts_fifo_trigger.14"/>
<property id="module.driver.uart.callback" value="NULL"/>
<property id="module.driver.uart.eri_ipl" value="14"/>
<property id="module.driver.uart.bri_ipl" value="14"/>
<property id="module.driver.uart.rxi_ipl" value="14"/>
<property id="module.driver.uart.txi_ipl" value="14"/>
</module>
<module id="module.driver.openamp.2090365989"/>
<module id="module.driver.openamp.open-amp.419535215"/>
<module id="module.driver.openamp.libmetal.1571366027"/>
<context id="_hal.0">
<stack module="module.driver.ioport_on_ioport.0"/>
<stack module="module.middleware.rm_freertos_port.0">
<stack module="module.driver.timer_on_gtm.2" requires="module.middleware.rm_freertos_port.requires.gtm.ticker"/>
</stack>
<stack module="module.freertos.heap.4.4"/>
<stack module="module.driver.mhu_ns.1921636645"/>
<stack module="module.driver.uart_on_scif_uart.580040235"/>
<stack module="module.driver.openamp.2090365989">
<stack module="module.driver.openamp.open-amp.419535215" requires="module.driver.openamp.requires.open-amp"/>
<stack module="module.driver.openamp.libmetal.1571366027" requires="module.driver.openamp.requires.libmetal"/>
</stack>
</context>
<context id="rtos.awsfreertos.thread.0">
<property id="_symbol" value="blinky_thread"/>
<property id="rtos.awsfreertos.thread.name" value="Blinky Thread"/>
<property id="rtos.awsfreertos.thread.stack" value="512"/>
<property id="rtos.awsfreertos.thread.priority" value="1"/>
<property id="rtos.awsfreertos.thread.context" value="NULL"/>
<property id="rtos.awsfreertos.thread.allocation" value="rtos.awsfreertos.thread.allocation.dynamic"/>
<property id="rtos.awsfreertos.thread.secure_context" value="rtos.awsfreertos.thread.secure_context.enable"/>
</context>
<context id="rtos.awsfreertos.thread.350222811">
<property id="_symbol" value="MainTask"/>
<property id="rtos.awsfreertos.thread.name" value="MainTask#0"/>
<property id="rtos.awsfreertos.thread.stack" value="4096"/>
<property id="rtos.awsfreertos.thread.priority" value="1"/>
<property id="rtos.awsfreertos.thread.context" value="0"/>
<property id="rtos.awsfreertos.thread.allocation" value="rtos.awsfreertos.thread.allocation.dynamic"/>
<property id="rtos.awsfreertos.thread.secure_context" value="rtos.awsfreertos.thread.secure_context.enable"/>
</context>
<config id="config.driver.gtm">
<property id="config.driver.gtm.param_checking_enable" value="config.driver.gtm.param_checking_enable.bsp"/>
</config>
<config id="config.driver.scif_uart">
<property id="config.driver.scif_uart.param_checking_enable" value="config.driver.scif_uart.param_checking_enable.bsp"/>
<property id="config.driver.scif_uart.dmac_enable" value="config.driver.scif_uart.dmac_enable.disabled"/>
<property id="config.driver.scif_uart.flow_control" value="config.driver.scif_uart.flow_control.disabled"/>
</config>
<config id="config.driver.mhu_ns">
<property id="config.driver.mhu_ns.param_checking_enable" value="config.driver.mhu_ns.param_checking_enable.bsp"/>
</config>
<config id="config.awsfreertos.thread">
<property id="config.awsfreertos.custom_freertosconfig" value=""/>
<property id="config.awsfreertos.thread.configenable_mpu" value="config.awsfreertos.thread.configenable_mpu.disabled"/>
<property id="config.awsfreertos.thread.configenable_trustzone" value="config.awsfreertos.thread.configenable_trustzone.disabled"/>
<property id="config.awsfreertos.thread.configuse_preemption" value="config.awsfreertos.thread.configuse_preemption.enabled"/>
<property id="config.awsfreertos.thread.configuse_port_optimised_task_selection" value="config.awsfreertos.thread.configuse_port_optimised_task_selection.disabled"/>
<property id="config.awsfreertos.thread.configuse_tickless_idle" value="config.awsfreertos.thread.configuse_tickless_idle.disabled"/>
<property id="config.awsfreertos.thread.configuse_idle_hook" value="config.awsfreertos.thread.configuse_idle_hook.enabled"/>
<property id="config.awsfreertos.thread.configuse_malloc_failed_hook" value="config.awsfreertos.thread.configuse_malloc_failed_hook.disabled"/>
<property id="config.awsfreertos.thread.configuse_daemon_task_startup_hook" value="config.awsfreertos.thread.configuse_daemon_task_startup_hook.disabled"/>
<property id="config.awsfreertos.thread.configuse_tick_hook" value="config.awsfreertos.thread.configuse_tick_hook.disabled"/>
<property id="config.awsfreertos.thread.configcpu_clock_hz" value="SystemCoreClock"/>
<property id="config.awsfreertos.thread.configtick_rate_hz" value="1000"/>
<property id="config.awsfreertos.thread.configmax_priorities" value="5"/>
<property id="config.awsfreertos.thread.configminimal_stack_size" value="128"/>
<property id="config.awsfreertos.thread.configmax_task_name_len" value="16"/>
<property id="config.awsfreertos.thread.configuse_trace_facility" value="config.awsfreertos.thread.configuse_trace_facility.disabled"/>
<property id="config.awsfreertos.thread.configuse_stats_formatting_functions" value="config.awsfreertos.thread.configuse_stats_formatting_functions.disabled"/>
<property id="config.awsfreertos.thread.configuse_16_bit_ticks" value="config.awsfreertos.thread.configuse_16_bit_ticks.disabled"/>
<property id="config.awsfreertos.thread.configidle_should_yield" value="config.awsfreertos.thread.configidle_should_yield.enabled"/>
<property id="config.awsfreertos.thread.configuse_task_notifications" value="config.awsfreertos.thread.configuse_task_notifications.enabled"/>
<property id="config.awsfreertos.thread.configuse_mutexes" value="config.awsfreertos.thread.configuse_mutexes.disabled"/>
<property id="config.awsfreertos.thread.configuse_recursive_mutexes" value="config.awsfreertos.thread.configuse_recursive_mutexes.disabled"/>
<property id="config.awsfreertos.thread.configuse_counting_semaphores" value="config.awsfreertos.thread.configuse_counting_semaphores.enabled"/>
<property id="config.awsfreertos.thread.configcheck_for_stack_overflow" value="config.awsfreertos.thread.configcheck_for_stack_overflow.disabled"/>
<property id="config.awsfreertos.thread.configqueue_registry_size" value="10"/>
<property id="config.awsfreertos.thread.configuse_queue_sets" value="config.awsfreertos.thread.configuse_queue_sets.disabled"/>
<property id="config.awsfreertos.thread.configuse_time_slicing" value="config.awsfreertos.thread.configuse_time_slicing.disabled"/>
<property id="config.awsfreertos.thread.configuse_newlib_reentrant" value="config.awsfreertos.thread.configuse_newlib_reentrant.disabled"/>
<property id="config.awsfreertos.thread.configenable_backward_compatibility" value="config.awsfreertos.thread.configenable_backward_compatibility.disabled"/>
<property id="config.awsfreertos.thread.confignum_thread_local_storage_pointers" value="5"/>
<property id="config.awsfreertos.thread.configstack_depth_type" value="uint32_t"/>
<property id="config.awsfreertos.thread.configmessage_buffer_length_type" value="size_t"/>
<property id="config.awsfreertos.thread.configsupport_static_allocation" value="config.awsfreertos.thread.configsupport_static_allocation.enabled"/>
<property id="config.awsfreertos.thread.configsupport_dynamic_allocation" value="config.awsfreertos.thread.configsupport_dynamic_allocation.enabled"/>
<property id="config.awsfreertos.thread.configtotal_heap_size" value="40960"/>
<property id="config.awsfreertos.thread.configapplication_allocated_heap" value="config.awsfreertos.thread.configapplication_allocated_heap.enabled"/>
<property id="config.awsfreertos.thread.configgenerate_run_time_stats" value="config.awsfreertos.thread.configgenerate_run_time_stats.disabled"/>
<property id="config.awsfreertos.thread.configuse_timers" value="config.awsfreertos.thread.configuse_timers.enabled"/>
<property id="config.awsfreertos.thread.configtimer_task_priority" value="3"/>
<property id="config.awsfreertos.thread.configtimer_queue_length" value="10"/>
<property id="config.awsfreertos.thread.configtimer_task_stack_depth" value="128"/>
<property id="config.awsfreertos.thread.configlibrary_max_syscall_interrupt_priority" value="board.icu.common.irq.priority1"/>
<property id="config.awsfreertos.thread.configassert" value="assert(x)"/>
<property id="config.awsfreertos.thread.configinclude_application_defined_privileged_functions" value="config.awsfreertos.thread.configinclude_application_defined_privileged_functions.disabled"/>
<property id="config.awsfreertos.thread.include_vtaskpriorityset" value="config.awsfreertos.thread.include_vtaskpriorityset.enabled"/>
<property id="config.awsfreertos.thread.include_uxtaskpriorityget" value="config.awsfreertos.thread.include_uxtaskpriorityget.enabled"/>
<property id="config.awsfreertos.thread.include_vtaskdelete" value="config.awsfreertos.thread.include_vtaskdelete.enabled"/>
<property id="config.awsfreertos.thread.include_vtasksuspend" value="config.awsfreertos.thread.include_vtasksuspend.enabled"/>
<property id="config.awsfreertos.thread.include_xresumefromisr" value="config.awsfreertos.thread.include_xresumefromisr.enabled"/>
<property id="config.awsfreertos.thread.include_vtaskdelayuntil" value="config.awsfreertos.thread.include_vtaskdelayuntil.enabled"/>
<property id="config.awsfreertos.thread.include_vtaskdelay" value="config.awsfreertos.thread.include_vtaskdelay.enabled"/>
<property id="config.awsfreertos.thread.include_xtaskgetschedulerstate" value="config.awsfreertos.thread.include_xtaskgetschedulerstate.enabled"/>
<property id="config.awsfreertos.thread.include_xtaskgetcurrenttaskhandle" value="config.awsfreertos.thread.include_xtaskgetcurrenttaskhandle.enabled"/>
<property id="config.awsfreertos.thread.include_uxtaskgetstackhighwatermark" value="config.awsfreertos.thread.include_uxtaskgetstackhighwatermark.disabled"/>
<property id="config.awsfreertos.thread.include_xtaskgetidletaskhandle" value="config.awsfreertos.thread.include_xtaskgetidletaskhandle.disabled"/>
<property id="config.awsfreertos.thread.include_etaskgetstate" value="config.awsfreertos.thread.include_etaskgetstate.disabled"/>
<property id="config.awsfreertos.thread.include_xeventgroupsetbitfromisr" value="config.awsfreertos.thread.include_xeventgroupsetbitfromisr.enabled"/>
<property id="config.awsfreertos.thread.include_xtimerpendfunctioncall" value="config.awsfreertos.thread.include_xtimerpendfunctioncall.disabled"/>
<property id="config.awsfreertos.thread.include_xtaskabortdelay" value="config.awsfreertos.thread.include_xtaskabortdelay.disabled"/>
<property id="config.awsfreertos.thread.include_xtaskgethandle" value="config.awsfreertos.thread.include_xtaskgethandle.disabled"/>
<property id="config.awsfreertos.thread.include_xtaskresumefromisr" value="config.awsfreertos.thread.include_xtaskresumefromisr.enabled"/>
<property id="config.awsfreertos.thread.print_function" value=""/>
<property id="config.awsfreertos.thread.max_length" value="192"/>
<property id="config.awsfreertos.thread.include_time_and_task" value="config.awsfreertos.thread.include_time_and_task.disabled"/>
</config>
<config id="config.driver.ioport">
<property id="config.driver.ioport.checking" value="config.driver.ioport.checking.system"/>
</config>
</raModuleConfiguration>
<raPinConfiguration>
<pincfg active="true" name="RZG2UL-SMARC.pincfg" selected="true" symbol="g_bsp_pin_cfg"/>
<pincfg active="false" name="R9A07G043U12GBG_CM33.pincfg" selected="false" symbol=""/>
</raPinConfiguration>
</raConfiguration>

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 57 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 21 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 50 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 100 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

View File

@ -0,0 +1,349 @@
/*
Linker File for Renesas FSP
*/
/* Memory allocation example using ddr. */
VECTBL_N_START = 0x00010000;
VECTBL_N_LENGTH = 0x00000800;
VECTBL_S_START = 0x1001FF80;
VECTBL_S_LENGTH = 0x00000080;
CODE_N_START = 0x60010000;
CODE_N_LENGTH = 0x00100000;
RAM_N_START = 0x60110000;
RAM_N_LENGTH = 0x02DEF440;
CODE_S_START = 0x72EFF440;
CODE_S_LENGTH = 0x000003C0;
RAM_S_START = 0x72EFF800;
RAM_S_LENGTH = 0x00000800;
DDR_START = 0x60010000;
DDR_LENGTH = 0x03EF0000;
OPENAMP_RSCTBL_START = 0x62F00000;
OPENAMP_RSCTBL_LENGTH = 0x00001000;
MHU_SHMEM_START = 0x62F01000;
MHU_SHMEM_LENGTH = 0x00001000;
OPENAMP_VRING_START = 0x63000000;
OPENAMP_VRING_LENGTH = 0x00800000;
/* When using OpenAMP, allocate the length of the OpenAMP relevant region. */
OPENAMP_RSCTBL_START = DEFINED(OPENAMP_RSCTBL_START) ? OPENAMP_RSCTBL_START : 0;
OPENAMP_RSCTBL_LENGTH = DEFINED(OPENAMP_RSCTBL_LENGTH)? OPENAMP_RSCTBL_LENGTH : 0;
MHU_SHMEM_START = DEFINED(MHU_SHMEM_START) ? MHU_SHMEM_START : 0;
MHU_SHMEM_LENGTH = DEFINED(MHU_SHMEM_LENGTH) ? MHU_SHMEM_LENGTH : 0;
OPENAMP_VRING_START = DEFINED(OPENAMP_VRING_START) ? OPENAMP_VRING_START : 0;
OPENAMP_VRING_LENGTH = DEFINED(OPENAMP_VRING_LENGTH) ? OPENAMP_VRING_LENGTH : 0;
/* Define memory regions. */
MEMORY
{
RAM_S (rwx) : ORIGIN = RAM_S_START, LENGTH = RAM_S_LENGTH
RAM_N (rwx) : ORIGIN = RAM_N_START, LENGTH = RAM_N_LENGTH
CODE_S (rx) : ORIGIN = CODE_S_START, LENGTH = CODE_S_LENGTH
CODE_N (rx) : ORIGIN = CODE_N_START, LENGTH = CODE_N_LENGTH
VECTTBL_S (rx) : ORIGIN = VECTBL_S_START, LENGTH = VECTBL_S_LENGTH
VECTTBL_N (rx) : ORIGIN = VECTBL_N_START, LENGTH = VECTBL_N_LENGTH
OPENAMP_RSCTBL(rw): ORIGIN = OPENAMP_RSCTBL_START,LENGTH = OPENAMP_RSCTBL_LENGTH
MHU_SHMEM(rw) : ORIGIN = MHU_SHMEM_START, LENGTH = MHU_SHMEM_LENGTH
OPENAMP_VRING(rw) : ORIGIN = OPENAMP_VRING_START, LENGTH = OPENAMP_VRING_LENGTH
}
/* Library configurations */
GROUP(libgcc.a libc.a libm.a libnosys.a)
/* Linker script to place sections and symbol values. Should be used together
* with other linker script that defines memory regions CODE, RAM and etc.
* It references following symbols, which must be defined in code:
* Reset_Handler_S : Entry of secure reset handler
*
* It defines following symbols, which code can use without definition:
* __exidx_start
* __exidx_end
* __copy_table_start__
* __copy_table_end__
* __zero_table_start__
* __zero_table_end__
* __etext
* __data_start__
* __preinit_array_start
* __preinit_array_end
* __init_array_start
* __init_array_end
* __fini_array_start
* __fini_array_end
* __data_end__
* __bss_start__
* __bss_end__
* __HeapLimit
* __StackLimit
* __StackTop
* __stack
* __Vectors_End
* __Vectors_Size
*/
ENTRY(Warm_Reset_S)
SECTIONS
{
__tz_VECTBL_S = ABSOLUTE(VECTBL_S_START);
. = __tz_VECTBL_S;
.text.secure_vector :
{
/* Even though the vector table is not 16 entries (64B) long, we still allocate that much space. */
KEEP(*(.fixed_secure_vectors*))
} >VECTTBL_S
__tz_CODE_S = ABSOLUTE(CODE_S_START);
. = __tz_CODE_S;
.text.secure_code :
{
*\bsp_security.o (.text)
*\bsp_security.o (.text.*)
*\bsp_security.o (.rodata)
*\bsp_security.o (.rodata.*)
*\bsp_irqs.o (.text)
*\bsp_irqs.o (.text.*)
*\bsp_irqs.o (.rodata)
*\bsp_irqs.o (.rodata.*)
*\startups.o (.text)
*\startups.o (.text.*)
*\startups.o (.rodata)
*\startups.o (.rodata.*)
*\systems.o (.text)
*\systems.o (.text.*)
*\systems.o (.rodata)
*\systems.o (.rodata.*)
__CODE_S_End = .;
} >CODE_S
__tz_RAM_S = ABSOLUTE(RAM_S_START);
. = __tz_RAM_S;
/* secure stacks are stored in this section. */
.stack_dummy (NOLOAD) :
{
__S_StackLimit = .;
/* secure main stack */
KEEP(*(.s_stack))
__S_StackTop = .;
} >RAM_S
/* start at address VECTBL_N_START */
__tz_VECTBL_N = ABSOLUTE(VECTBL_N_START);
. = __tz_VECTBL_N;
.text.non_secure_vector :
{
/* Even though the vector table is not 512 entries (2KB) long, we still allocate that much space. */
KEEP(*(.fixed_vectors*))
KEEP(*(.application_vectors*))
__Vectors_End = .;
} >VECTTBL_N
__Vectors_Size = __Vectors_End - __Vectors;
/* start at address CODE_N_START */
__tz_CODE_N = ABSOLUTE(CODE_N_START);
. = __tz_CODE_N;
.text.non_secure_code :
{
*(.text*)
KEEP(*(.version))
KEEP(*(.init))
KEEP(*(.fini))
/* .ctors */
*crtbegin.o(.ctors)
*crtbegin?.o(.ctors)
*(EXCLUDE_FILE(* crtend?.o * crtend.o) .ctors)
*(SORT(.ctors.*))
*(.ctors)
/* .dtors */
*crtbegin.o(.dtors)
*crtbegin?.o(.dtors)
*(EXCLUDE_FILE(* crtend?.o * crtend.o) .dtors)
*(SORT(.dtors.*))
*(.dtors)
*(.rodata*)
KEEP(*(.eh_frame*))
/* section information for shell */
. = ALIGN(4);
_shell_command_start = .;
KEEP (*(shellCommand))
_shell_command_end = .;
. = ALIGN(4);
__isrtbl_idx_start = .;
KEEP(*(.isrtbl.idx))
__isrtbl_start = .;
KEEP(*(.isrtbl))
__isrtbl_end = .;
. = ALIGN(4);
PROVIDE(g_service_table_start = ABSOLUTE(.));
KEEP(*(.g_service_table))
PROVIDE(g_service_table_end = ABSOLUTE(.));
} >CODE_N
.ARM.extab :
{
*(.ARM.extab* .gnu.linkonce.armextab.*)
} > CODE_N
__exidx_start = .;
.ARM.exidx :
{
*(.ARM.exidx* .gnu.linkonce.armexidx.*)
} > CODE_N
__exidx_end = .;
/* To copy multiple CODE_N to RAM_N sections,
* uncomment .copy.table section and,
* define __STARTUP_COPY_MULTIPLE in startup_ARMCMx.S */
/*
* .copy.table :
* {
* . = ALIGN(4);
* __copy_table_start__ = .;
* LONG (__etext)
* LONG (__data_start__)
* LONG (__data_end__ - __data_start__)
* LONG (__etext2)
* LONG (__data2_start__)
* LONG (__data2_end__ - __data2_start__)
* __copy_table_end__ = .;
* } > CODE_N
*/
/* To clear multiple BSS sections,
* uncomment .zero.table section and,
* define __STARTUP_CLEAR_BSS_MULTIPLE in startup_ARMCMx.S */
/*
* .zero.table :
* {
* . = ALIGN(4);
* __zero_table_start__ = .;
* LONG (__bss_start__)
* LONG (__bss_end__ - __bss_start__)
* LONG (__bss2_start__)
* LONG (__bss2_end__ - __bss2_start__)
* __zero_table_end__ = .;
* } > CODE_N
*/
__etext = .;
__tz_RAM_N = ABSOLUTE(RAM_N_START);
. = __tz_RAM_N;
/* Initialized data section. */
.data :
{
__data_start__ = .;
. = ALIGN(4);
__Code_In_RAM_Start = .;
KEEP(*(.code_in_ram*))
__Code_In_RAM_End = .;
*(vtable)
/* Don't use *(.data*) because it will place data meant for .data_flash in this section. */
*(.data.*)
*(.data)
. = ALIGN(4);
/* preinit data */
PROVIDE_HIDDEN(__preinit_array_start = .);
KEEP(*(.preinit_array))
PROVIDE_HIDDEN(__preinit_array_end = .);
. = ALIGN(4);
/* init data */
PROVIDE_HIDDEN(__init_array_start = .);
KEEP(*(SORT(.init_array.*)))
KEEP(*(.init_array))
PROVIDE_HIDDEN(__init_array_end = .);
. = ALIGN(4);
/* finit data */
PROVIDE_HIDDEN(__fini_array_start = .);
KEEP(*(SORT(.fini_array.*)))
KEEP(*(.fini_array))
PROVIDE_HIDDEN(__fini_array_end = .);
KEEP(*(.jcr*))
. = ALIGN(4);
/* All data end */
__data_end__ = .;
} > RAM_N AT > CODE_N
.bss.noinit (NOLOAD) :
{
. = ALIGN(4);
__noinit_start = .;
KEEP(*(.noinit*))
. = ALIGN(8);
/* Place the FreeRTOS heap here so that the __HeapLimit calculation does not include the freertos heap. */
KEEP(*(.heap.*))
__noinit_end = .;
} > RAM_N
.bss :
{
. = ALIGN(4);
__bss_start__ = .;
*(.bss*)
*(COMMON)
. = ALIGN(4);
__bss_end__ = .;
} > RAM_N
.heap (NOLOAD) :
{
. = ALIGN(8);
__HeapBase = .;
/* Place the STD heap here. */
KEEP(*(.heap))
__HeapLimit = .;
} > RAM_N
/* Stacks are stored in this section. */
.stack (NOLOAD) :
{
. = ALIGN(8);
__StackLimit = .;
/* Main stack */
KEEP(*(.stack))
__StackTop = .;
/* Thread stacks */
KEEP(*(.stack*))
__StackTopAll = .;
} > RAM_N
PROVIDE(__stack = __StackTopAll);
/* This symbol represents the end of user allocated RAM. The RAM after this symbol can be used
at run time for things such as ThreadX memory pool allocations. */
__RAM_segment_used_end__ = ALIGN(__StackTopAll , 4);
PROVIDE(__tz_RAM_C = __RAM_segment_used_end__);
__tz_OPENAMP_RSCTBL = ABSOLUTE(OPENAMP_RSCTBL_START);
. = __tz_OPENAMP_RSCTBL;
/* OpenAMP resource table */
.bss.resource_table (NOLOAD) :
{
PROVIDE(__rsctbl_start = .);
*(.resource_table)
PROVIDE(__rsctbl_end = .);
} > OPENAMP_RSCTBL
__tz_MHU_SHMEM = ABSOLUTE(MHU_SHMEM_START);
. = __tz_MHU_SHMEM;
/* MHU driver shared memory */
.bss.mhu_shmem (NOLOAD) :
{
PROVIDE(__mhu_shmem_start = .);
. += MHU_SHMEM_LENGTH;
PROVIDE(__mhu_shmem_end = .);
} > MHU_SHMEM
__tz_OPENAMP_VRING = ABSOLUTE(OPENAMP_VRING_START);
. = __tz_OPENAMP_VRING;
/* OpenAMP VRINGresource table */
.bss.vring (NOLOAD) :
{
PROVIDE(__vring_start = .);
. += OPENAMP_VRING_LENGTH;
PROVIDE(__vring_end = .);
} > OPENAMP_VRING
}

View File

@ -0,0 +1,13 @@
SRC_DIR := board/rzg2ul_smarc
SRC_DIR += fsp/src/bsp/cmsis/Device/RENESAS/Source
SRC_DIR += fsp/src/bsp/mcu/all
SRC_DIR += fsp/src/r_ioport
SRC_DIR += fsp/src/r_mhu_ns
SRC_DIR += fsp/src/r_scif_uart
SRC_DIR += fsp/src/r_gtm
SRC_DIR += linaro
SRC_FILES := $(wildcard *.c)
include $(KERNEL_ROOT)/compiler.mk

View File

@ -0,0 +1,411 @@
/******************************************************************************
* @file cachel1_armv7.h
* @brief CMSIS Level 1 Cache API for Armv7-M and later
* @version V1.0.0
* @date 03. March 2020
******************************************************************************/
/*
* Copyright (c) 2020 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef ARM_CACHEL1_ARMV7_H
#define ARM_CACHEL1_ARMV7_H
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_CacheFunctions Cache Functions
\brief Functions that configure Instruction and Data cache.
@{
*/
/* Cache Size ID Register Macros */
#define CCSIDR_WAYS(x) (((x) & SCB_CCSIDR_ASSOCIATIVITY_Msk) >> SCB_CCSIDR_ASSOCIATIVITY_Pos)
#define CCSIDR_SETS(x) (((x) & SCB_CCSIDR_NUMSETS_Msk ) >> SCB_CCSIDR_NUMSETS_Pos )
#ifndef __SCB_DCACHE_LINE_SIZE
#define __SCB_DCACHE_LINE_SIZE 32U /*!< Cortex-M7 cache line size is fixed to 32 bytes (8 words). See also register SCB_CCSIDR */
#endif
#ifndef __SCB_ICACHE_LINE_SIZE
#define __SCB_ICACHE_LINE_SIZE 32U /*!< Cortex-M7 cache line size is fixed to 32 bytes (8 words). See also register SCB_CCSIDR */
#endif
/**
\brief Enable I-Cache
\details Turns on I-Cache
*/
__STATIC_FORCEINLINE void SCB_EnableICache (void)
{
#if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
if (SCB->CCR & SCB_CCR_IC_Msk) return; /* return if ICache is already enabled */
__DSB();
__ISB();
SCB->ICIALLU = 0UL; /* invalidate I-Cache */
__DSB();
__ISB();
SCB->CCR |= (uint32_t)SCB_CCR_IC_Msk; /* enable I-Cache */
__DSB();
__ISB();
#endif
}
/**
\brief Disable I-Cache
\details Turns off I-Cache
*/
__STATIC_FORCEINLINE void SCB_DisableICache (void)
{
#if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
__DSB();
__ISB();
SCB->CCR &= ~(uint32_t)SCB_CCR_IC_Msk; /* disable I-Cache */
SCB->ICIALLU = 0UL; /* invalidate I-Cache */
__DSB();
__ISB();
#endif
}
/**
\brief Invalidate I-Cache
\details Invalidates I-Cache
*/
__STATIC_FORCEINLINE void SCB_InvalidateICache (void)
{
#if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
__DSB();
__ISB();
SCB->ICIALLU = 0UL;
__DSB();
__ISB();
#endif
}
/**
\brief I-Cache Invalidate by address
\details Invalidates I-Cache for the given address.
I-Cache is invalidated starting from a 32 byte aligned address in 32 byte granularity.
I-Cache memory blocks which are part of given address + given size are invalidated.
\param[in] addr address
\param[in] isize size of memory block (in number of bytes)
*/
__STATIC_FORCEINLINE void SCB_InvalidateICache_by_Addr (void *addr, int32_t isize)
{
#if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
if ( isize > 0 ) {
int32_t op_size = isize + (((uint32_t)addr) & (__SCB_ICACHE_LINE_SIZE - 1U));
uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_ICACHE_LINE_SIZE - 1U) */;
__DSB();
do {
SCB->ICIMVAU = op_addr; /* register accepts only 32byte aligned values, only bits 31..5 are valid */
op_addr += __SCB_ICACHE_LINE_SIZE;
op_size -= __SCB_ICACHE_LINE_SIZE;
} while ( op_size > 0 );
__DSB();
__ISB();
}
#endif
}
/**
\brief Enable D-Cache
\details Turns on D-Cache
*/
__STATIC_FORCEINLINE void SCB_EnableDCache (void)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
uint32_t ccsidr;
uint32_t sets;
uint32_t ways;
if (SCB->CCR & SCB_CCR_DC_Msk) return; /* return if DCache is already enabled */
SCB->CSSELR = 0U; /* select Level 1 data cache */
__DSB();
ccsidr = SCB->CCSIDR;
/* invalidate D-Cache */
sets = (uint32_t)(CCSIDR_SETS(ccsidr));
do {
ways = (uint32_t)(CCSIDR_WAYS(ccsidr));
do {
SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) |
((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk) );
#if defined ( __CC_ARM )
__schedule_barrier();
#endif
} while (ways-- != 0U);
} while(sets-- != 0U);
__DSB();
SCB->CCR |= (uint32_t)SCB_CCR_DC_Msk; /* enable D-Cache */
__DSB();
__ISB();
#endif
}
/**
\brief Disable D-Cache
\details Turns off D-Cache
*/
__STATIC_FORCEINLINE void SCB_DisableDCache (void)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
uint32_t ccsidr;
uint32_t sets;
uint32_t ways;
SCB->CSSELR = 0U; /* select Level 1 data cache */
__DSB();
SCB->CCR &= ~(uint32_t)SCB_CCR_DC_Msk; /* disable D-Cache */
__DSB();
ccsidr = SCB->CCSIDR;
/* clean & invalidate D-Cache */
sets = (uint32_t)(CCSIDR_SETS(ccsidr));
do {
ways = (uint32_t)(CCSIDR_WAYS(ccsidr));
do {
SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) |
((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk) );
#if defined ( __CC_ARM )
__schedule_barrier();
#endif
} while (ways-- != 0U);
} while(sets-- != 0U);
__DSB();
__ISB();
#endif
}
/**
\brief Invalidate D-Cache
\details Invalidates D-Cache
*/
__STATIC_FORCEINLINE void SCB_InvalidateDCache (void)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
uint32_t ccsidr;
uint32_t sets;
uint32_t ways;
SCB->CSSELR = 0U; /* select Level 1 data cache */
__DSB();
ccsidr = SCB->CCSIDR;
/* invalidate D-Cache */
sets = (uint32_t)(CCSIDR_SETS(ccsidr));
do {
ways = (uint32_t)(CCSIDR_WAYS(ccsidr));
do {
SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) |
((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk) );
#if defined ( __CC_ARM )
__schedule_barrier();
#endif
} while (ways-- != 0U);
} while(sets-- != 0U);
__DSB();
__ISB();
#endif
}
/**
\brief Clean D-Cache
\details Cleans D-Cache
*/
__STATIC_FORCEINLINE void SCB_CleanDCache (void)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
uint32_t ccsidr;
uint32_t sets;
uint32_t ways;
SCB->CSSELR = 0U; /* select Level 1 data cache */
__DSB();
ccsidr = SCB->CCSIDR;
/* clean D-Cache */
sets = (uint32_t)(CCSIDR_SETS(ccsidr));
do {
ways = (uint32_t)(CCSIDR_WAYS(ccsidr));
do {
SCB->DCCSW = (((sets << SCB_DCCSW_SET_Pos) & SCB_DCCSW_SET_Msk) |
((ways << SCB_DCCSW_WAY_Pos) & SCB_DCCSW_WAY_Msk) );
#if defined ( __CC_ARM )
__schedule_barrier();
#endif
} while (ways-- != 0U);
} while(sets-- != 0U);
__DSB();
__ISB();
#endif
}
/**
\brief Clean & Invalidate D-Cache
\details Cleans and Invalidates D-Cache
*/
__STATIC_FORCEINLINE void SCB_CleanInvalidateDCache (void)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
uint32_t ccsidr;
uint32_t sets;
uint32_t ways;
SCB->CSSELR = 0U; /* select Level 1 data cache */
__DSB();
ccsidr = SCB->CCSIDR;
/* clean & invalidate D-Cache */
sets = (uint32_t)(CCSIDR_SETS(ccsidr));
do {
ways = (uint32_t)(CCSIDR_WAYS(ccsidr));
do {
SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) |
((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk) );
#if defined ( __CC_ARM )
__schedule_barrier();
#endif
} while (ways-- != 0U);
} while(sets-- != 0U);
__DSB();
__ISB();
#endif
}
/**
\brief D-Cache Invalidate by address
\details Invalidates D-Cache for the given address.
D-Cache is invalidated starting from a 32 byte aligned address in 32 byte granularity.
D-Cache memory blocks which are part of given address + given size are invalidated.
\param[in] addr address
\param[in] dsize size of memory block (in number of bytes)
*/
__STATIC_FORCEINLINE void SCB_InvalidateDCache_by_Addr (void *addr, int32_t dsize)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
if ( dsize > 0 ) {
int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U));
uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */;
__DSB();
do {
SCB->DCIMVAC = op_addr; /* register accepts only 32byte aligned values, only bits 31..5 are valid */
op_addr += __SCB_DCACHE_LINE_SIZE;
op_size -= __SCB_DCACHE_LINE_SIZE;
} while ( op_size > 0 );
__DSB();
__ISB();
}
#endif
}
/**
\brief D-Cache Clean by address
\details Cleans D-Cache for the given address
D-Cache is cleaned starting from a 32 byte aligned address in 32 byte granularity.
D-Cache memory blocks which are part of given address + given size are cleaned.
\param[in] addr address
\param[in] dsize size of memory block (in number of bytes)
*/
__STATIC_FORCEINLINE void SCB_CleanDCache_by_Addr (uint32_t *addr, int32_t dsize)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
if ( dsize > 0 ) {
int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U));
uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */;
__DSB();
do {
SCB->DCCMVAC = op_addr; /* register accepts only 32byte aligned values, only bits 31..5 are valid */
op_addr += __SCB_DCACHE_LINE_SIZE;
op_size -= __SCB_DCACHE_LINE_SIZE;
} while ( op_size > 0 );
__DSB();
__ISB();
}
#endif
}
/**
\brief D-Cache Clean and Invalidate by address
\details Cleans and invalidates D_Cache for the given address
D-Cache is cleaned and invalidated starting from a 32 byte aligned address in 32 byte granularity.
D-Cache memory blocks which are part of given address + given size are cleaned and invalidated.
\param[in] addr address (aligned to 32-byte boundary)
\param[in] dsize size of memory block (in number of bytes)
*/
__STATIC_FORCEINLINE void SCB_CleanInvalidateDCache_by_Addr (uint32_t *addr, int32_t dsize)
{
#if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
if ( dsize > 0 ) {
int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U));
uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */;
__DSB();
do {
SCB->DCCIMVAC = op_addr; /* register accepts only 32byte aligned values, only bits 31..5 are valid */
op_addr += __SCB_DCACHE_LINE_SIZE;
op_size -= __SCB_DCACHE_LINE_SIZE;
} while ( op_size > 0 );
__DSB();
__ISB();
}
#endif
}
/*@} end of CMSIS_Core_CacheFunctions */
#endif /* ARM_CACHEL1_ARMV7_H */

View File

@ -0,0 +1,885 @@
/**************************************************************************//**
* @file cmsis_armcc.h
* @brief CMSIS compiler ARMCC (Arm Compiler 5) header file
* @version V5.2.1
* @date 26. March 2020
******************************************************************************/
/*
* Copyright (c) 2009-2020 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __CMSIS_ARMCC_H
#define __CMSIS_ARMCC_H
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 400677)
#error "Please use Arm Compiler Toolchain V4.0.677 or later!"
#endif
/* CMSIS compiler control architecture macros */
#if ((defined (__TARGET_ARCH_6_M ) && (__TARGET_ARCH_6_M == 1)) || \
(defined (__TARGET_ARCH_6S_M ) && (__TARGET_ARCH_6S_M == 1)) )
#define __ARM_ARCH_6M__ 1
#endif
#if (defined (__TARGET_ARCH_7_M ) && (__TARGET_ARCH_7_M == 1))
#define __ARM_ARCH_7M__ 1
#endif
#if (defined (__TARGET_ARCH_7E_M) && (__TARGET_ARCH_7E_M == 1))
#define __ARM_ARCH_7EM__ 1
#endif
/* __ARM_ARCH_8M_BASE__ not applicable */
/* __ARM_ARCH_8M_MAIN__ not applicable */
/* __ARM_ARCH_8_1M_MAIN__ not applicable */
/* CMSIS compiler control DSP macros */
#if ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) )
#define __ARM_FEATURE_DSP 1
#endif
/* CMSIS compiler specific defines */
#ifndef __ASM
#define __ASM __asm
#endif
#ifndef __INLINE
#define __INLINE __inline
#endif
#ifndef __STATIC_INLINE
#define __STATIC_INLINE static __inline
#endif
#ifndef __STATIC_FORCEINLINE
#define __STATIC_FORCEINLINE static __forceinline
#endif
#ifndef __NO_RETURN
#define __NO_RETURN __declspec(noreturn)
#endif
#ifndef __USED
#define __USED __attribute__((used))
#endif
#ifndef __WEAK
#define __WEAK __attribute__((weak))
#endif
#ifndef __PACKED
#define __PACKED __attribute__((packed))
#endif
#ifndef __PACKED_STRUCT
#define __PACKED_STRUCT __packed struct
#endif
#ifndef __PACKED_UNION
#define __PACKED_UNION __packed union
#endif
#ifndef __UNALIGNED_UINT32 /* deprecated */
#define __UNALIGNED_UINT32(x) (*((__packed uint32_t *)(x)))
#endif
#ifndef __UNALIGNED_UINT16_WRITE
#define __UNALIGNED_UINT16_WRITE(addr, val) ((*((__packed uint16_t *)(addr))) = (val))
#endif
#ifndef __UNALIGNED_UINT16_READ
#define __UNALIGNED_UINT16_READ(addr) (*((const __packed uint16_t *)(addr)))
#endif
#ifndef __UNALIGNED_UINT32_WRITE
#define __UNALIGNED_UINT32_WRITE(addr, val) ((*((__packed uint32_t *)(addr))) = (val))
#endif
#ifndef __UNALIGNED_UINT32_READ
#define __UNALIGNED_UINT32_READ(addr) (*((const __packed uint32_t *)(addr)))
#endif
#ifndef __ALIGNED
#define __ALIGNED(x) __attribute__((aligned(x)))
#endif
#ifndef __RESTRICT
#define __RESTRICT __restrict
#endif
#ifndef __COMPILER_BARRIER
#define __COMPILER_BARRIER() __memory_changed()
#endif
/* ######################### Startup and Lowlevel Init ######################## */
#ifndef __PROGRAM_START
#define __PROGRAM_START __main
#endif
#ifndef __INITIAL_SP
#define __INITIAL_SP Image$$ARM_LIB_STACK$$ZI$$Limit
#endif
#ifndef __STACK_LIMIT
#define __STACK_LIMIT Image$$ARM_LIB_STACK$$ZI$$Base
#endif
#ifndef __VECTOR_TABLE
#define __VECTOR_TABLE __Vectors
#endif
#ifndef __VECTOR_TABLE_ATTRIBUTE
#define __VECTOR_TABLE_ATTRIBUTE __attribute__((used, section("RESET")))
#endif
/* ########################### Core Function Access ########################### */
/** \ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions
@{
*/
/**
\brief Enable IRQ Interrupts
\details Enables IRQ interrupts by clearing the I-bit in the CPSR.
Can only be executed in Privileged modes.
*/
/* intrinsic void __enable_irq(); */
/**
\brief Disable IRQ Interrupts
\details Disables IRQ interrupts by setting the I-bit in the CPSR.
Can only be executed in Privileged modes.
*/
/* intrinsic void __disable_irq(); */
/**
\brief Get Control Register
\details Returns the content of the Control Register.
\return Control Register value
*/
__STATIC_INLINE uint32_t __get_CONTROL(void)
{
register uint32_t __regControl __ASM("control");
return(__regControl);
}
/**
\brief Set Control Register
\details Writes the given value to the Control Register.
\param [in] control Control Register value to set
*/
__STATIC_INLINE void __set_CONTROL(uint32_t control)
{
register uint32_t __regControl __ASM("control");
__regControl = control;
}
/**
\brief Get IPSR Register
\details Returns the content of the IPSR Register.
\return IPSR Register value
*/
__STATIC_INLINE uint32_t __get_IPSR(void)
{
register uint32_t __regIPSR __ASM("ipsr");
return(__regIPSR);
}
/**
\brief Get APSR Register
\details Returns the content of the APSR Register.
\return APSR Register value
*/
__STATIC_INLINE uint32_t __get_APSR(void)
{
register uint32_t __regAPSR __ASM("apsr");
return(__regAPSR);
}
/**
\brief Get xPSR Register
\details Returns the content of the xPSR Register.
\return xPSR Register value
*/
__STATIC_INLINE uint32_t __get_xPSR(void)
{
register uint32_t __regXPSR __ASM("xpsr");
return(__regXPSR);
}
/**
\brief Get Process Stack Pointer
\details Returns the current value of the Process Stack Pointer (PSP).
\return PSP Register value
*/
__STATIC_INLINE uint32_t __get_PSP(void)
{
register uint32_t __regProcessStackPointer __ASM("psp");
return(__regProcessStackPointer);
}
/**
\brief Set Process Stack Pointer
\details Assigns the given value to the Process Stack Pointer (PSP).
\param [in] topOfProcStack Process Stack Pointer value to set
*/
__STATIC_INLINE void __set_PSP(uint32_t topOfProcStack)
{
register uint32_t __regProcessStackPointer __ASM("psp");
__regProcessStackPointer = topOfProcStack;
}
/**
\brief Get Main Stack Pointer
\details Returns the current value of the Main Stack Pointer (MSP).
\return MSP Register value
*/
__STATIC_INLINE uint32_t __get_MSP(void)
{
register uint32_t __regMainStackPointer __ASM("msp");
return(__regMainStackPointer);
}
/**
\brief Set Main Stack Pointer
\details Assigns the given value to the Main Stack Pointer (MSP).
\param [in] topOfMainStack Main Stack Pointer value to set
*/
__STATIC_INLINE void __set_MSP(uint32_t topOfMainStack)
{
register uint32_t __regMainStackPointer __ASM("msp");
__regMainStackPointer = topOfMainStack;
}
/**
\brief Get Priority Mask
\details Returns the current state of the priority mask bit from the Priority Mask Register.
\return Priority Mask value
*/
__STATIC_INLINE uint32_t __get_PRIMASK(void)
{
register uint32_t __regPriMask __ASM("primask");
return(__regPriMask);
}
/**
\brief Set Priority Mask
\details Assigns the given value to the Priority Mask Register.
\param [in] priMask Priority Mask
*/
__STATIC_INLINE void __set_PRIMASK(uint32_t priMask)
{
register uint32_t __regPriMask __ASM("primask");
__regPriMask = (priMask);
}
#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
(defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) )
/**
\brief Enable FIQ
\details Enables FIQ interrupts by clearing the F-bit in the CPSR.
Can only be executed in Privileged modes.
*/
#define __enable_fault_irq __enable_fiq
/**
\brief Disable FIQ
\details Disables FIQ interrupts by setting the F-bit in the CPSR.
Can only be executed in Privileged modes.
*/
#define __disable_fault_irq __disable_fiq
/**
\brief Get Base Priority
\details Returns the current value of the Base Priority register.
\return Base Priority register value
*/
__STATIC_INLINE uint32_t __get_BASEPRI(void)
{
register uint32_t __regBasePri __ASM("basepri");
return(__regBasePri);
}
/**
\brief Set Base Priority
\details Assigns the given value to the Base Priority register.
\param [in] basePri Base Priority value to set
*/
__STATIC_INLINE void __set_BASEPRI(uint32_t basePri)
{
register uint32_t __regBasePri __ASM("basepri");
__regBasePri = (basePri & 0xFFU);
}
/**
\brief Set Base Priority with condition
\details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled,
or the new value increases the BASEPRI priority level.
\param [in] basePri Base Priority value to set
*/
__STATIC_INLINE void __set_BASEPRI_MAX(uint32_t basePri)
{
register uint32_t __regBasePriMax __ASM("basepri_max");
__regBasePriMax = (basePri & 0xFFU);
}
/**
\brief Get Fault Mask
\details Returns the current value of the Fault Mask register.
\return Fault Mask register value
*/
__STATIC_INLINE uint32_t __get_FAULTMASK(void)
{
register uint32_t __regFaultMask __ASM("faultmask");
return(__regFaultMask);
}
/**
\brief Set Fault Mask
\details Assigns the given value to the Fault Mask register.
\param [in] faultMask Fault Mask value to set
*/
__STATIC_INLINE void __set_FAULTMASK(uint32_t faultMask)
{
register uint32_t __regFaultMask __ASM("faultmask");
__regFaultMask = (faultMask & (uint32_t)1U);
}
#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
(defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */
/**
\brief Get FPSCR
\details Returns the current value of the Floating Point Status/Control register.
\return Floating Point Status/Control register value
*/
__STATIC_INLINE uint32_t __get_FPSCR(void)
{
#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
(defined (__FPU_USED ) && (__FPU_USED == 1U)) )
register uint32_t __regfpscr __ASM("fpscr");
return(__regfpscr);
#else
return(0U);
#endif
}
/**
\brief Set FPSCR
\details Assigns the given value to the Floating Point Status/Control register.
\param [in] fpscr Floating Point Status/Control value to set
*/
__STATIC_INLINE void __set_FPSCR(uint32_t fpscr)
{
#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
(defined (__FPU_USED ) && (__FPU_USED == 1U)) )
register uint32_t __regfpscr __ASM("fpscr");
__regfpscr = (fpscr);
#else
(void)fpscr;
#endif
}
/*@} end of CMSIS_Core_RegAccFunctions */
/* ########################## Core Instruction Access ######################### */
/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface
Access to dedicated instructions
@{
*/
/**
\brief No Operation
\details No Operation does nothing. This instruction can be used for code alignment purposes.
*/
#define __NOP __nop
/**
\brief Wait For Interrupt
\details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs.
*/
#define __WFI __wfi
/**
\brief Wait For Event
\details Wait For Event is a hint instruction that permits the processor to enter
a low-power state until one of a number of events occurs.
*/
#define __WFE __wfe
/**
\brief Send Event
\details Send Event is a hint instruction. It causes an event to be signaled to the CPU.
*/
#define __SEV __sev
/**
\brief Instruction Synchronization Barrier
\details Instruction Synchronization Barrier flushes the pipeline in the processor,
so that all instructions following the ISB are fetched from cache or memory,
after the instruction has been completed.
*/
#define __ISB() __isb(0xF)
/**
\brief Data Synchronization Barrier
\details Acts as a special kind of Data Memory Barrier.
It completes when all explicit memory accesses before this instruction complete.
*/
#define __DSB() __dsb(0xF)
/**
\brief Data Memory Barrier
\details Ensures the apparent order of the explicit memory operations before
and after the instruction, without ensuring their completion.
*/
#define __DMB() __dmb(0xF)
/**
\brief Reverse byte order (32 bit)
\details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412.
\param [in] value Value to reverse
\return Reversed value
*/
#define __REV __rev
/**
\brief Reverse byte order (16 bit)
\details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856.
\param [in] value Value to reverse
\return Reversed value
*/
#ifndef __NO_EMBEDDED_ASM
__attribute__((section(".rev16_text"))) __STATIC_INLINE __ASM uint32_t __REV16(uint32_t value)
{
rev16 r0, r0
bx lr
}
#endif
/**
\brief Reverse byte order (16 bit)
\details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000.
\param [in] value Value to reverse
\return Reversed value
*/
#ifndef __NO_EMBEDDED_ASM
__attribute__((section(".revsh_text"))) __STATIC_INLINE __ASM int16_t __REVSH(int16_t value)
{
revsh r0, r0
bx lr
}
#endif
/**
\brief Rotate Right in unsigned value (32 bit)
\details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits.
\param [in] op1 Value to rotate
\param [in] op2 Number of Bits to rotate
\return Rotated value
*/
#define __ROR __ror
/**
\brief Breakpoint
\details Causes the processor to enter Debug state.
Debug tools can use this to investigate system state when the instruction at a particular address is reached.
\param [in] value is ignored by the processor.
If required, a debugger can use it to store additional information about the breakpoint.
*/
#define __BKPT(value) __breakpoint(value)
/**
\brief Reverse bit order of value
\details Reverses the bit order of the given value.
\param [in] value Value to reverse
\return Reversed value
*/
#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
(defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) )
#define __RBIT __rbit
#else
__attribute__((always_inline)) __STATIC_INLINE uint32_t __RBIT(uint32_t value)
{
uint32_t result;
uint32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */
result = value; /* r will be reversed bits of v; first get LSB of v */
for (value >>= 1U; value != 0U; value >>= 1U)
{
result <<= 1U;
result |= value & 1U;
s--;
}
result <<= s; /* shift when v's highest bits are zero */
return result;
}
#endif
/**
\brief Count leading zeros
\details Counts the number of leading zeros of a data value.
\param [in] value Value to count the leading zeros
\return number of leading zeros in value
*/
#define __CLZ __clz
#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
(defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) )
/**
\brief LDR Exclusive (8 bit)
\details Executes a exclusive LDR instruction for 8 bit value.
\param [in] ptr Pointer to data
\return value of type uint8_t at (*ptr)
*/
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020)
#define __LDREXB(ptr) ((uint8_t ) __ldrex(ptr))
#else
#define __LDREXB(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint8_t ) __ldrex(ptr)) _Pragma("pop")
#endif
/**
\brief LDR Exclusive (16 bit)
\details Executes a exclusive LDR instruction for 16 bit values.
\param [in] ptr Pointer to data
\return value of type uint16_t at (*ptr)
*/
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020)
#define __LDREXH(ptr) ((uint16_t) __ldrex(ptr))
#else
#define __LDREXH(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint16_t) __ldrex(ptr)) _Pragma("pop")
#endif
/**
\brief LDR Exclusive (32 bit)
\details Executes a exclusive LDR instruction for 32 bit values.
\param [in] ptr Pointer to data
\return value of type uint32_t at (*ptr)
*/
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020)
#define __LDREXW(ptr) ((uint32_t ) __ldrex(ptr))
#else
#define __LDREXW(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint32_t ) __ldrex(ptr)) _Pragma("pop")
#endif
/**
\brief STR Exclusive (8 bit)
\details Executes a exclusive STR instruction for 8 bit values.
\param [in] value Value to store
\param [in] ptr Pointer to location
\return 0 Function succeeded
\return 1 Function failed
*/
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020)
#define __STREXB(value, ptr) __strex(value, ptr)
#else
#define __STREXB(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop")
#endif
/**
\brief STR Exclusive (16 bit)
\details Executes a exclusive STR instruction for 16 bit values.
\param [in] value Value to store
\param [in] ptr Pointer to location
\return 0 Function succeeded
\return 1 Function failed
*/
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020)
#define __STREXH(value, ptr) __strex(value, ptr)
#else
#define __STREXH(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop")
#endif
/**
\brief STR Exclusive (32 bit)
\details Executes a exclusive STR instruction for 32 bit values.
\param [in] value Value to store
\param [in] ptr Pointer to location
\return 0 Function succeeded
\return 1 Function failed
*/
#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020)
#define __STREXW(value, ptr) __strex(value, ptr)
#else
#define __STREXW(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop")
#endif
/**
\brief Remove the exclusive lock
\details Removes the exclusive lock which is created by LDREX.
*/
#define __CLREX __clrex
/**
\brief Signed Saturate
\details Saturates a signed value.
\param [in] value Value to be saturated
\param [in] sat Bit position to saturate to (1..32)
\return Saturated value
*/
#define __SSAT __ssat
/**
\brief Unsigned Saturate
\details Saturates an unsigned value.
\param [in] value Value to be saturated
\param [in] sat Bit position to saturate to (0..31)
\return Saturated value
*/
#define __USAT __usat
/**
\brief Rotate Right with Extend (32 bit)
\details Moves each bit of a bitstring right by one bit.
The carry input is shifted in at the left end of the bitstring.
\param [in] value Value to rotate
\return Rotated value
*/
#ifndef __NO_EMBEDDED_ASM
__attribute__((section(".rrx_text"))) __STATIC_INLINE __ASM uint32_t __RRX(uint32_t value)
{
rrx r0, r0
bx lr
}
#endif
/**
\brief LDRT Unprivileged (8 bit)
\details Executes a Unprivileged LDRT instruction for 8 bit value.
\param [in] ptr Pointer to data
\return value of type uint8_t at (*ptr)
*/
#define __LDRBT(ptr) ((uint8_t ) __ldrt(ptr))
/**
\brief LDRT Unprivileged (16 bit)
\details Executes a Unprivileged LDRT instruction for 16 bit values.
\param [in] ptr Pointer to data
\return value of type uint16_t at (*ptr)
*/
#define __LDRHT(ptr) ((uint16_t) __ldrt(ptr))
/**
\brief LDRT Unprivileged (32 bit)
\details Executes a Unprivileged LDRT instruction for 32 bit values.
\param [in] ptr Pointer to data
\return value of type uint32_t at (*ptr)
*/
#define __LDRT(ptr) ((uint32_t ) __ldrt(ptr))
/**
\brief STRT Unprivileged (8 bit)
\details Executes a Unprivileged STRT instruction for 8 bit values.
\param [in] value Value to store
\param [in] ptr Pointer to location
*/
#define __STRBT(value, ptr) __strt(value, ptr)
/**
\brief STRT Unprivileged (16 bit)
\details Executes a Unprivileged STRT instruction for 16 bit values.
\param [in] value Value to store
\param [in] ptr Pointer to location
*/
#define __STRHT(value, ptr) __strt(value, ptr)
/**
\brief STRT Unprivileged (32 bit)
\details Executes a Unprivileged STRT instruction for 32 bit values.
\param [in] value Value to store
\param [in] ptr Pointer to location
*/
#define __STRT(value, ptr) __strt(value, ptr)
#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
(defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */
/**
\brief Signed Saturate
\details Saturates a signed value.
\param [in] value Value to be saturated
\param [in] sat Bit position to saturate to (1..32)
\return Saturated value
*/
__attribute__((always_inline)) __STATIC_INLINE int32_t __SSAT(int32_t val, uint32_t sat)
{
if ((sat >= 1U) && (sat <= 32U))
{
const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U);
const int32_t min = -1 - max ;
if (val > max)
{
return max;
}
else if (val < min)
{
return min;
}
}
return val;
}
/**
\brief Unsigned Saturate
\details Saturates an unsigned value.
\param [in] value Value to be saturated
\param [in] sat Bit position to saturate to (0..31)
\return Saturated value
*/
__attribute__((always_inline)) __STATIC_INLINE uint32_t __USAT(int32_t val, uint32_t sat)
{
if (sat <= 31U)
{
const uint32_t max = ((1U << sat) - 1U);
if (val > (int32_t)max)
{
return max;
}
else if (val < 0)
{
return 0U;
}
}
return (uint32_t)val;
}
#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
(defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */
/*@}*/ /* end of group CMSIS_Core_InstructionInterface */
/* ################### Compiler specific Intrinsics ########################### */
/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics
Access to dedicated SIMD instructions
@{
*/
#if ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) )
#define __SADD8 __sadd8
#define __QADD8 __qadd8
#define __SHADD8 __shadd8
#define __UADD8 __uadd8
#define __UQADD8 __uqadd8
#define __UHADD8 __uhadd8
#define __SSUB8 __ssub8
#define __QSUB8 __qsub8
#define __SHSUB8 __shsub8
#define __USUB8 __usub8
#define __UQSUB8 __uqsub8
#define __UHSUB8 __uhsub8
#define __SADD16 __sadd16
#define __QADD16 __qadd16
#define __SHADD16 __shadd16
#define __UADD16 __uadd16
#define __UQADD16 __uqadd16
#define __UHADD16 __uhadd16
#define __SSUB16 __ssub16
#define __QSUB16 __qsub16
#define __SHSUB16 __shsub16
#define __USUB16 __usub16
#define __UQSUB16 __uqsub16
#define __UHSUB16 __uhsub16
#define __SASX __sasx
#define __QASX __qasx
#define __SHASX __shasx
#define __UASX __uasx
#define __UQASX __uqasx
#define __UHASX __uhasx
#define __SSAX __ssax
#define __QSAX __qsax
#define __SHSAX __shsax
#define __USAX __usax
#define __UQSAX __uqsax
#define __UHSAX __uhsax
#define __USAD8 __usad8
#define __USADA8 __usada8
#define __SSAT16 __ssat16
#define __USAT16 __usat16
#define __UXTB16 __uxtb16
#define __UXTAB16 __uxtab16
#define __SXTB16 __sxtb16
#define __SXTAB16 __sxtab16
#define __SMUAD __smuad
#define __SMUADX __smuadx
#define __SMLAD __smlad
#define __SMLADX __smladx
#define __SMLALD __smlald
#define __SMLALDX __smlaldx
#define __SMUSD __smusd
#define __SMUSDX __smusdx
#define __SMLSD __smlsd
#define __SMLSDX __smlsdx
#define __SMLSLD __smlsld
#define __SMLSLDX __smlsldx
#define __SEL __sel
#define __QADD __qadd
#define __QSUB __qsub
#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \
((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) )
#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \
((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) )
#define __SMMLA(ARG1,ARG2,ARG3) ( (int32_t)((((int64_t)(ARG1) * (ARG2)) + \
((int64_t)(ARG3) << 32U) ) >> 32U))
#define __SXTB16_RORn(ARG1, ARG2) __SXTB16(__ROR(ARG1, ARG2))
#endif /* ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */
/*@} end of group CMSIS_SIMD_intrinsics */
#endif /* __CMSIS_ARMCC_H */

View File

@ -0,0 +1,283 @@
/**************************************************************************//**
* @file cmsis_compiler.h
* @brief CMSIS compiler generic header file
* @version V5.1.0
* @date 09. October 2018
******************************************************************************/
/*
* Copyright (c) 2009-2018 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __CMSIS_COMPILER_H
#define __CMSIS_COMPILER_H
#include <stdint.h>
/*
* Arm Compiler 4/5
*/
#if defined ( __CC_ARM )
#include "cmsis_armcc.h"
/*
* Arm Compiler 6.6 LTM (armclang)
*/
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) && (__ARMCC_VERSION < 6100100)
#include "cmsis_armclang_ltm.h"
/*
* Arm Compiler above 6.10.1 (armclang)
*/
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6100100)
#include "cmsis_armclang.h"
/*
* GNU Compiler
*/
#elif defined ( __GNUC__ )
#include "cmsis_gcc.h"
/*
* IAR Compiler
*/
#elif defined ( __ICCARM__ )
#include <cmsis_iccarm.h>
/*
* TI Arm Compiler
*/
#elif defined ( __TI_ARM__ )
#include <cmsis_ccs.h>
#ifndef __ASM
#define __ASM __asm
#endif
#ifndef __INLINE
#define __INLINE inline
#endif
#ifndef __STATIC_INLINE
#define __STATIC_INLINE static inline
#endif
#ifndef __STATIC_FORCEINLINE
#define __STATIC_FORCEINLINE __STATIC_INLINE
#endif
#ifndef __NO_RETURN
#define __NO_RETURN __attribute__((noreturn))
#endif
#ifndef __USED
#define __USED __attribute__((used))
#endif
#ifndef __WEAK
#define __WEAK __attribute__((weak))
#endif
#ifndef __PACKED
#define __PACKED __attribute__((packed))
#endif
#ifndef __PACKED_STRUCT
#define __PACKED_STRUCT struct __attribute__((packed))
#endif
#ifndef __PACKED_UNION
#define __PACKED_UNION union __attribute__((packed))
#endif
#ifndef __UNALIGNED_UINT32 /* deprecated */
struct __attribute__((packed)) T_UINT32 { uint32_t v; };
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
#endif
#ifndef __UNALIGNED_UINT16_WRITE
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void*)(addr))->v) = (val))
#endif
#ifndef __UNALIGNED_UINT16_READ
__PACKED_STRUCT T_UINT16_READ { uint16_t v; };
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
#endif
#ifndef __UNALIGNED_UINT32_WRITE
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
#endif
#ifndef __UNALIGNED_UINT32_READ
__PACKED_STRUCT T_UINT32_READ { uint32_t v; };
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
#endif
#ifndef __ALIGNED
#define __ALIGNED(x) __attribute__((aligned(x)))
#endif
#ifndef __RESTRICT
#define __RESTRICT __restrict
#endif
#ifndef __COMPILER_BARRIER
#warning No compiler specific solution for __COMPILER_BARRIER. __COMPILER_BARRIER is ignored.
#define __COMPILER_BARRIER() (void)0
#endif
/*
* TASKING Compiler
*/
#elif defined ( __TASKING__ )
/*
* The CMSIS functions have been implemented as intrinsics in the compiler.
* Please use "carm -?i" to get an up to date list of all intrinsics,
* Including the CMSIS ones.
*/
#ifndef __ASM
#define __ASM __asm
#endif
#ifndef __INLINE
#define __INLINE inline
#endif
#ifndef __STATIC_INLINE
#define __STATIC_INLINE static inline
#endif
#ifndef __STATIC_FORCEINLINE
#define __STATIC_FORCEINLINE __STATIC_INLINE
#endif
#ifndef __NO_RETURN
#define __NO_RETURN __attribute__((noreturn))
#endif
#ifndef __USED
#define __USED __attribute__((used))
#endif
#ifndef __WEAK
#define __WEAK __attribute__((weak))
#endif
#ifndef __PACKED
#define __PACKED __packed__
#endif
#ifndef __PACKED_STRUCT
#define __PACKED_STRUCT struct __packed__
#endif
#ifndef __PACKED_UNION
#define __PACKED_UNION union __packed__
#endif
#ifndef __UNALIGNED_UINT32 /* deprecated */
struct __packed__ T_UINT32 { uint32_t v; };
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
#endif
#ifndef __UNALIGNED_UINT16_WRITE
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val))
#endif
#ifndef __UNALIGNED_UINT16_READ
__PACKED_STRUCT T_UINT16_READ { uint16_t v; };
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
#endif
#ifndef __UNALIGNED_UINT32_WRITE
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
#endif
#ifndef __UNALIGNED_UINT32_READ
__PACKED_STRUCT T_UINT32_READ { uint32_t v; };
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
#endif
#ifndef __ALIGNED
#define __ALIGNED(x) __align(x)
#endif
#ifndef __RESTRICT
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored.
#define __RESTRICT
#endif
#ifndef __COMPILER_BARRIER
#warning No compiler specific solution for __COMPILER_BARRIER. __COMPILER_BARRIER is ignored.
#define __COMPILER_BARRIER() (void)0
#endif
/*
* COSMIC Compiler
*/
#elif defined ( __CSMC__ )
#include <cmsis_csm.h>
#ifndef __ASM
#define __ASM _asm
#endif
#ifndef __INLINE
#define __INLINE inline
#endif
#ifndef __STATIC_INLINE
#define __STATIC_INLINE static inline
#endif
#ifndef __STATIC_FORCEINLINE
#define __STATIC_FORCEINLINE __STATIC_INLINE
#endif
#ifndef __NO_RETURN
// NO RETURN is automatically detected hence no warning here
#define __NO_RETURN
#endif
#ifndef __USED
#warning No compiler specific solution for __USED. __USED is ignored.
#define __USED
#endif
#ifndef __WEAK
#define __WEAK __weak
#endif
#ifndef __PACKED
#define __PACKED @packed
#endif
#ifndef __PACKED_STRUCT
#define __PACKED_STRUCT @packed struct
#endif
#ifndef __PACKED_UNION
#define __PACKED_UNION @packed union
#endif
#ifndef __UNALIGNED_UINT32 /* deprecated */
@packed struct T_UINT32 { uint32_t v; };
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
#endif
#ifndef __UNALIGNED_UINT16_WRITE
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val))
#endif
#ifndef __UNALIGNED_UINT16_READ
__PACKED_STRUCT T_UINT16_READ { uint16_t v; };
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
#endif
#ifndef __UNALIGNED_UINT32_WRITE
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
#endif
#ifndef __UNALIGNED_UINT32_READ
__PACKED_STRUCT T_UINT32_READ { uint32_t v; };
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
#endif
#ifndef __ALIGNED
#warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored.
#define __ALIGNED(x)
#endif
#ifndef __RESTRICT
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored.
#define __RESTRICT
#endif
#ifndef __COMPILER_BARRIER
#warning No compiler specific solution for __COMPILER_BARRIER. __COMPILER_BARRIER is ignored.
#define __COMPILER_BARRIER() (void)0
#endif
#else
#error Unknown compiler.
#endif
#endif /* __CMSIS_COMPILER_H */

View File

@ -0,0 +1,968 @@
/**************************************************************************//**
* @file cmsis_iccarm.h
* @brief CMSIS compiler ICCARM (IAR Compiler for Arm) header file
* @version V5.2.0
* @date 28. January 2020
******************************************************************************/
//------------------------------------------------------------------------------
//
// Copyright (c) 2017-2019 IAR Systems
// Copyright (c) 2017-2019 Arm Limited. All rights reserved.
//
// SPDX-License-Identifier: Apache-2.0
//
// Licensed under the Apache License, Version 2.0 (the "License")
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
//------------------------------------------------------------------------------
#ifndef __CMSIS_ICCARM_H__
#define __CMSIS_ICCARM_H__
#ifndef __ICCARM__
#error This file should only be compiled by ICCARM
#endif
#pragma system_include
#define __IAR_FT _Pragma("inline=forced") __intrinsic
#if (__VER__ >= 8000000)
#define __ICCARM_V8 1
#else
#define __ICCARM_V8 0
#endif
#ifndef __ALIGNED
#if __ICCARM_V8
#define __ALIGNED(x) __attribute__((aligned(x)))
#elif (__VER__ >= 7080000)
/* Needs IAR language extensions */
#define __ALIGNED(x) __attribute__((aligned(x)))
#else
#warning No compiler specific solution for __ALIGNED.__ALIGNED is ignored.
#define __ALIGNED(x)
#endif
#endif
/* Define compiler macros for CPU architecture, used in CMSIS 5.
*/
#if __ARM_ARCH_6M__ || __ARM_ARCH_7M__ || __ARM_ARCH_7EM__ || __ARM_ARCH_8M_BASE__ || __ARM_ARCH_8M_MAIN__
/* Macros already defined */
#else
#if defined(__ARM8M_MAINLINE__) || defined(__ARM8EM_MAINLINE__)
#define __ARM_ARCH_8M_MAIN__ 1
#elif defined(__ARM8M_BASELINE__)
#define __ARM_ARCH_8M_BASE__ 1
#elif defined(__ARM_ARCH_PROFILE) && __ARM_ARCH_PROFILE == 'M'
#if __ARM_ARCH == 6
#define __ARM_ARCH_6M__ 1
#elif __ARM_ARCH == 7
#if __ARM_FEATURE_DSP
#define __ARM_ARCH_7EM__ 1
#else
#define __ARM_ARCH_7M__ 1
#endif
#endif /* __ARM_ARCH */
#endif /* __ARM_ARCH_PROFILE == 'M' */
#endif
/* Alternativ core deduction for older ICCARM's */
#if !defined(__ARM_ARCH_6M__) && !defined(__ARM_ARCH_7M__) && !defined(__ARM_ARCH_7EM__) && \
!defined(__ARM_ARCH_8M_BASE__) && !defined(__ARM_ARCH_8M_MAIN__)
#if defined(__ARM6M__) && (__CORE__ == __ARM6M__)
#define __ARM_ARCH_6M__ 1
#elif defined(__ARM7M__) && (__CORE__ == __ARM7M__)
#define __ARM_ARCH_7M__ 1
#elif defined(__ARM7EM__) && (__CORE__ == __ARM7EM__)
#define __ARM_ARCH_7EM__ 1
#elif defined(__ARM8M_BASELINE__) && (__CORE == __ARM8M_BASELINE__)
#define __ARM_ARCH_8M_BASE__ 1
#elif defined(__ARM8M_MAINLINE__) && (__CORE == __ARM8M_MAINLINE__)
#define __ARM_ARCH_8M_MAIN__ 1
#elif defined(__ARM8EM_MAINLINE__) && (__CORE == __ARM8EM_MAINLINE__)
#define __ARM_ARCH_8M_MAIN__ 1
#else
#error "Unknown target."
#endif
#endif
#if defined(__ARM_ARCH_6M__) && __ARM_ARCH_6M__==1
#define __IAR_M0_FAMILY 1
#elif defined(__ARM_ARCH_8M_BASE__) && __ARM_ARCH_8M_BASE__==1
#define __IAR_M0_FAMILY 1
#else
#define __IAR_M0_FAMILY 0
#endif
#ifndef __ASM
#define __ASM __asm
#endif
#ifndef __COMPILER_BARRIER
#define __COMPILER_BARRIER() __ASM volatile("":::"memory")
#endif
#ifndef __INLINE
#define __INLINE inline
#endif
#ifndef __NO_RETURN
#if __ICCARM_V8
#define __NO_RETURN __attribute__((__noreturn__))
#else
#define __NO_RETURN _Pragma("object_attribute=__noreturn")
#endif
#endif
#ifndef __PACKED
#if __ICCARM_V8
#define __PACKED __attribute__((packed, aligned(1)))
#else
/* Needs IAR language extensions */
#define __PACKED __packed
#endif
#endif
#ifndef __PACKED_STRUCT
#if __ICCARM_V8
#define __PACKED_STRUCT struct __attribute__((packed, aligned(1)))
#else
/* Needs IAR language extensions */
#define __PACKED_STRUCT __packed struct
#endif
#endif
#ifndef __PACKED_UNION
#if __ICCARM_V8
#define __PACKED_UNION union __attribute__((packed, aligned(1)))
#else
/* Needs IAR language extensions */
#define __PACKED_UNION __packed union
#endif
#endif
#ifndef __RESTRICT
#if __ICCARM_V8
#define __RESTRICT __restrict
#else
/* Needs IAR language extensions */
#define __RESTRICT restrict
#endif
#endif
#ifndef __STATIC_INLINE
#define __STATIC_INLINE static inline
#endif
#ifndef __FORCEINLINE
#define __FORCEINLINE _Pragma("inline=forced")
#endif
#ifndef __STATIC_FORCEINLINE
#define __STATIC_FORCEINLINE __FORCEINLINE __STATIC_INLINE
#endif
#ifndef __UNALIGNED_UINT16_READ
#pragma language=save
#pragma language=extended
__IAR_FT uint16_t __iar_uint16_read(void const *ptr)
{
return *(__packed uint16_t*)(ptr);
}
#pragma language=restore
#define __UNALIGNED_UINT16_READ(PTR) __iar_uint16_read(PTR)
#endif
#ifndef __UNALIGNED_UINT16_WRITE
#pragma language=save
#pragma language=extended
__IAR_FT void __iar_uint16_write(void const *ptr, uint16_t val)
{
*(__packed uint16_t*)(ptr) = val;;
}
#pragma language=restore
#define __UNALIGNED_UINT16_WRITE(PTR,VAL) __iar_uint16_write(PTR,VAL)
#endif
#ifndef __UNALIGNED_UINT32_READ
#pragma language=save
#pragma language=extended
__IAR_FT uint32_t __iar_uint32_read(void const *ptr)
{
return *(__packed uint32_t*)(ptr);
}
#pragma language=restore
#define __UNALIGNED_UINT32_READ(PTR) __iar_uint32_read(PTR)
#endif
#ifndef __UNALIGNED_UINT32_WRITE
#pragma language=save
#pragma language=extended
__IAR_FT void __iar_uint32_write(void const *ptr, uint32_t val)
{
*(__packed uint32_t*)(ptr) = val;;
}
#pragma language=restore
#define __UNALIGNED_UINT32_WRITE(PTR,VAL) __iar_uint32_write(PTR,VAL)
#endif
#ifndef __UNALIGNED_UINT32 /* deprecated */
#pragma language=save
#pragma language=extended
__packed struct __iar_u32 { uint32_t v; };
#pragma language=restore
#define __UNALIGNED_UINT32(PTR) (((struct __iar_u32 *)(PTR))->v)
#endif
#ifndef __USED
#if __ICCARM_V8
#define __USED __attribute__((used))
#else
#define __USED _Pragma("__root")
#endif
#endif
#ifndef __WEAK
#if __ICCARM_V8
#define __WEAK __attribute__((weak))
#else
#define __WEAK _Pragma("__weak")
#endif
#endif
#ifndef __PROGRAM_START
#define __PROGRAM_START __iar_program_start
#endif
#ifndef __INITIAL_SP
#define __INITIAL_SP CSTACK$$Limit
#endif
#ifndef __STACK_LIMIT
#define __STACK_LIMIT CSTACK$$Base
#endif
#ifndef __VECTOR_TABLE
#define __VECTOR_TABLE __vector_table
#endif
#ifndef __VECTOR_TABLE_ATTRIBUTE
#define __VECTOR_TABLE_ATTRIBUTE @".intvec"
#endif
#ifndef __ICCARM_INTRINSICS_VERSION__
#define __ICCARM_INTRINSICS_VERSION__ 0
#endif
#if __ICCARM_INTRINSICS_VERSION__ == 2
#if defined(__CLZ)
#undef __CLZ
#endif
#if defined(__REVSH)
#undef __REVSH
#endif
#if defined(__RBIT)
#undef __RBIT
#endif
#if defined(__SSAT)
#undef __SSAT
#endif
#if defined(__USAT)
#undef __USAT
#endif
#include "iccarm_builtin.h"
#define __disable_fault_irq __iar_builtin_disable_fiq
#define __disable_irq __iar_builtin_disable_interrupt
#define __enable_fault_irq __iar_builtin_enable_fiq
#define __enable_irq __iar_builtin_enable_interrupt
#define __arm_rsr __iar_builtin_rsr
#define __arm_wsr __iar_builtin_wsr
#define __get_APSR() (__arm_rsr("APSR"))
#define __get_BASEPRI() (__arm_rsr("BASEPRI"))
#define __get_CONTROL() (__arm_rsr("CONTROL"))
#define __get_FAULTMASK() (__arm_rsr("FAULTMASK"))
#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
(defined (__FPU_USED ) && (__FPU_USED == 1U)) )
#define __get_FPSCR() (__arm_rsr("FPSCR"))
#define __set_FPSCR(VALUE) (__arm_wsr("FPSCR", (VALUE)))
#else
#define __get_FPSCR() ( 0 )
#define __set_FPSCR(VALUE) ((void)VALUE)
#endif
#define __get_IPSR() (__arm_rsr("IPSR"))
#define __get_MSP() (__arm_rsr("MSP"))
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure MSPLIM is RAZ/WI
#define __get_MSPLIM() (0U)
#else
#define __get_MSPLIM() (__arm_rsr("MSPLIM"))
#endif
#define __get_PRIMASK() (__arm_rsr("PRIMASK"))
#define __get_PSP() (__arm_rsr("PSP"))
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
#define __get_PSPLIM() (0U)
#else
#define __get_PSPLIM() (__arm_rsr("PSPLIM"))
#endif
#define __get_xPSR() (__arm_rsr("xPSR"))
#define __set_BASEPRI(VALUE) (__arm_wsr("BASEPRI", (VALUE)))
#define __set_BASEPRI_MAX(VALUE) (__arm_wsr("BASEPRI_MAX", (VALUE)))
#define __set_CONTROL(VALUE) (__arm_wsr("CONTROL", (VALUE)))
#define __set_FAULTMASK(VALUE) (__arm_wsr("FAULTMASK", (VALUE)))
#define __set_MSP(VALUE) (__arm_wsr("MSP", (VALUE)))
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure MSPLIM is RAZ/WI
#define __set_MSPLIM(VALUE) ((void)(VALUE))
#else
#define __set_MSPLIM(VALUE) (__arm_wsr("MSPLIM", (VALUE)))
#endif
#define __set_PRIMASK(VALUE) (__arm_wsr("PRIMASK", (VALUE)))
#define __set_PSP(VALUE) (__arm_wsr("PSP", (VALUE)))
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
#define __set_PSPLIM(VALUE) ((void)(VALUE))
#else
#define __set_PSPLIM(VALUE) (__arm_wsr("PSPLIM", (VALUE)))
#endif
#define __TZ_get_CONTROL_NS() (__arm_rsr("CONTROL_NS"))
#define __TZ_set_CONTROL_NS(VALUE) (__arm_wsr("CONTROL_NS", (VALUE)))
#define __TZ_get_PSP_NS() (__arm_rsr("PSP_NS"))
#define __TZ_set_PSP_NS(VALUE) (__arm_wsr("PSP_NS", (VALUE)))
#define __TZ_get_MSP_NS() (__arm_rsr("MSP_NS"))
#define __TZ_set_MSP_NS(VALUE) (__arm_wsr("MSP_NS", (VALUE)))
#define __TZ_get_SP_NS() (__arm_rsr("SP_NS"))
#define __TZ_set_SP_NS(VALUE) (__arm_wsr("SP_NS", (VALUE)))
#define __TZ_get_PRIMASK_NS() (__arm_rsr("PRIMASK_NS"))
#define __TZ_set_PRIMASK_NS(VALUE) (__arm_wsr("PRIMASK_NS", (VALUE)))
#define __TZ_get_BASEPRI_NS() (__arm_rsr("BASEPRI_NS"))
#define __TZ_set_BASEPRI_NS(VALUE) (__arm_wsr("BASEPRI_NS", (VALUE)))
#define __TZ_get_FAULTMASK_NS() (__arm_rsr("FAULTMASK_NS"))
#define __TZ_set_FAULTMASK_NS(VALUE)(__arm_wsr("FAULTMASK_NS", (VALUE)))
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
#define __TZ_get_PSPLIM_NS() (0U)
#define __TZ_set_PSPLIM_NS(VALUE) ((void)(VALUE))
#else
#define __TZ_get_PSPLIM_NS() (__arm_rsr("PSPLIM_NS"))
#define __TZ_set_PSPLIM_NS(VALUE) (__arm_wsr("PSPLIM_NS", (VALUE)))
#endif
#define __TZ_get_MSPLIM_NS() (__arm_rsr("MSPLIM_NS"))
#define __TZ_set_MSPLIM_NS(VALUE) (__arm_wsr("MSPLIM_NS", (VALUE)))
#define __NOP __iar_builtin_no_operation
#define __CLZ __iar_builtin_CLZ
#define __CLREX __iar_builtin_CLREX
#define __DMB __iar_builtin_DMB
#define __DSB __iar_builtin_DSB
#define __ISB __iar_builtin_ISB
#define __LDREXB __iar_builtin_LDREXB
#define __LDREXH __iar_builtin_LDREXH
#define __LDREXW __iar_builtin_LDREX
#define __RBIT __iar_builtin_RBIT
#define __REV __iar_builtin_REV
#define __REV16 __iar_builtin_REV16
__IAR_FT int16_t __REVSH(int16_t val)
{
return (int16_t) __iar_builtin_REVSH(val);
}
#define __ROR __iar_builtin_ROR
#define __RRX __iar_builtin_RRX
#define __SEV __iar_builtin_SEV
#if !__IAR_M0_FAMILY
#define __SSAT __iar_builtin_SSAT
#endif
#define __STREXB __iar_builtin_STREXB
#define __STREXH __iar_builtin_STREXH
#define __STREXW __iar_builtin_STREX
#if !__IAR_M0_FAMILY
#define __USAT __iar_builtin_USAT
#endif
#define __WFE __iar_builtin_WFE
#define __WFI __iar_builtin_WFI
#if __ARM_MEDIA__
#define __SADD8 __iar_builtin_SADD8
#define __QADD8 __iar_builtin_QADD8
#define __SHADD8 __iar_builtin_SHADD8
#define __UADD8 __iar_builtin_UADD8
#define __UQADD8 __iar_builtin_UQADD8
#define __UHADD8 __iar_builtin_UHADD8
#define __SSUB8 __iar_builtin_SSUB8
#define __QSUB8 __iar_builtin_QSUB8
#define __SHSUB8 __iar_builtin_SHSUB8
#define __USUB8 __iar_builtin_USUB8
#define __UQSUB8 __iar_builtin_UQSUB8
#define __UHSUB8 __iar_builtin_UHSUB8
#define __SADD16 __iar_builtin_SADD16
#define __QADD16 __iar_builtin_QADD16
#define __SHADD16 __iar_builtin_SHADD16
#define __UADD16 __iar_builtin_UADD16
#define __UQADD16 __iar_builtin_UQADD16
#define __UHADD16 __iar_builtin_UHADD16
#define __SSUB16 __iar_builtin_SSUB16
#define __QSUB16 __iar_builtin_QSUB16
#define __SHSUB16 __iar_builtin_SHSUB16
#define __USUB16 __iar_builtin_USUB16
#define __UQSUB16 __iar_builtin_UQSUB16
#define __UHSUB16 __iar_builtin_UHSUB16
#define __SASX __iar_builtin_SASX
#define __QASX __iar_builtin_QASX
#define __SHASX __iar_builtin_SHASX
#define __UASX __iar_builtin_UASX
#define __UQASX __iar_builtin_UQASX
#define __UHASX __iar_builtin_UHASX
#define __SSAX __iar_builtin_SSAX
#define __QSAX __iar_builtin_QSAX
#define __SHSAX __iar_builtin_SHSAX
#define __USAX __iar_builtin_USAX
#define __UQSAX __iar_builtin_UQSAX
#define __UHSAX __iar_builtin_UHSAX
#define __USAD8 __iar_builtin_USAD8
#define __USADA8 __iar_builtin_USADA8
#define __SSAT16 __iar_builtin_SSAT16
#define __USAT16 __iar_builtin_USAT16
#define __UXTB16 __iar_builtin_UXTB16
#define __UXTAB16 __iar_builtin_UXTAB16
#define __SXTB16 __iar_builtin_SXTB16
#define __SXTAB16 __iar_builtin_SXTAB16
#define __SMUAD __iar_builtin_SMUAD
#define __SMUADX __iar_builtin_SMUADX
#define __SMMLA __iar_builtin_SMMLA
#define __SMLAD __iar_builtin_SMLAD
#define __SMLADX __iar_builtin_SMLADX
#define __SMLALD __iar_builtin_SMLALD
#define __SMLALDX __iar_builtin_SMLALDX
#define __SMUSD __iar_builtin_SMUSD
#define __SMUSDX __iar_builtin_SMUSDX
#define __SMLSD __iar_builtin_SMLSD
#define __SMLSDX __iar_builtin_SMLSDX
#define __SMLSLD __iar_builtin_SMLSLD
#define __SMLSLDX __iar_builtin_SMLSLDX
#define __SEL __iar_builtin_SEL
#define __QADD __iar_builtin_QADD
#define __QSUB __iar_builtin_QSUB
#define __PKHBT __iar_builtin_PKHBT
#define __PKHTB __iar_builtin_PKHTB
#endif
#else /* __ICCARM_INTRINSICS_VERSION__ == 2 */
#if __IAR_M0_FAMILY
/* Avoid clash between intrinsics.h and arm_math.h when compiling for Cortex-M0. */
#define __CLZ __cmsis_iar_clz_not_active
#define __SSAT __cmsis_iar_ssat_not_active
#define __USAT __cmsis_iar_usat_not_active
#define __RBIT __cmsis_iar_rbit_not_active
#define __get_APSR __cmsis_iar_get_APSR_not_active
#endif
#if (!((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
(defined (__FPU_USED ) && (__FPU_USED == 1U)) ))
#define __get_FPSCR __cmsis_iar_get_FPSR_not_active
#define __set_FPSCR __cmsis_iar_set_FPSR_not_active
#endif
#ifdef __INTRINSICS_INCLUDED
#error intrinsics.h is already included previously!
#endif
#include <intrinsics.h>
#if __IAR_M0_FAMILY
/* Avoid clash between intrinsics.h and arm_math.h when compiling for Cortex-M0. */
#undef __CLZ
#undef __SSAT
#undef __USAT
#undef __RBIT
#undef __get_APSR
__STATIC_INLINE uint8_t __CLZ(uint32_t data)
{
if (data == 0U) { return 32U; }
uint32_t count = 0U;
uint32_t mask = 0x80000000U;
while ((data & mask) == 0U)
{
count += 1U;
mask = mask >> 1U;
}
return count;
}
__STATIC_INLINE uint32_t __RBIT(uint32_t v)
{
uint8_t sc = 31U;
uint32_t r = v;
for (v >>= 1U; v; v >>= 1U)
{
r <<= 1U;
r |= v & 1U;
sc--;
}
return (r << sc);
}
__STATIC_INLINE uint32_t __get_APSR(void)
{
uint32_t res;
__asm("MRS %0,APSR" : "=r" (res));
return res;
}
#endif
#if (!((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
(defined (__FPU_USED ) && (__FPU_USED == 1U)) ))
#undef __get_FPSCR
#undef __set_FPSCR
#define __get_FPSCR() (0)
#define __set_FPSCR(VALUE) ((void)VALUE)
#endif
#pragma diag_suppress=Pe940
#pragma diag_suppress=Pe177
#define __enable_irq __enable_interrupt
#define __disable_irq __disable_interrupt
#define __NOP __no_operation
#define __get_xPSR __get_PSR
#if (!defined(__ARM_ARCH_6M__) || __ARM_ARCH_6M__==0)
__IAR_FT uint32_t __LDREXW(uint32_t volatile *ptr)
{
return __LDREX((unsigned long *)ptr);
}
__IAR_FT uint32_t __STREXW(uint32_t value, uint32_t volatile *ptr)
{
return __STREX(value, (unsigned long *)ptr);
}
#endif
/* __CORTEX_M is defined in core_cm0.h, core_cm3.h and core_cm4.h. */
#if (__CORTEX_M >= 0x03)
__IAR_FT uint32_t __RRX(uint32_t value)
{
uint32_t result;
__ASM volatile("RRX %0, %1" : "=r"(result) : "r" (value));
return(result);
}
__IAR_FT void __set_BASEPRI_MAX(uint32_t value)
{
__asm volatile("MSR BASEPRI_MAX,%0"::"r" (value));
}
#define __enable_fault_irq __enable_fiq
#define __disable_fault_irq __disable_fiq
#endif /* (__CORTEX_M >= 0x03) */
__IAR_FT uint32_t __ROR(uint32_t op1, uint32_t op2)
{
return (op1 >> op2) | (op1 << ((sizeof(op1)*8)-op2));
}
#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \
(defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) )
__IAR_FT uint32_t __get_MSPLIM(void)
{
uint32_t res;
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure MSPLIM is RAZ/WI
res = 0U;
#else
__asm volatile("MRS %0,MSPLIM" : "=r" (res));
#endif
return res;
}
__IAR_FT void __set_MSPLIM(uint32_t value)
{
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure MSPLIM is RAZ/WI
(void)value;
#else
__asm volatile("MSR MSPLIM,%0" :: "r" (value));
#endif
}
__IAR_FT uint32_t __get_PSPLIM(void)
{
uint32_t res;
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
res = 0U;
#else
__asm volatile("MRS %0,PSPLIM" : "=r" (res));
#endif
return res;
}
__IAR_FT void __set_PSPLIM(uint32_t value)
{
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
(void)value;
#else
__asm volatile("MSR PSPLIM,%0" :: "r" (value));
#endif
}
__IAR_FT uint32_t __TZ_get_CONTROL_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,CONTROL_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_CONTROL_NS(uint32_t value)
{
__asm volatile("MSR CONTROL_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_PSP_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,PSP_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_PSP_NS(uint32_t value)
{
__asm volatile("MSR PSP_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_MSP_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,MSP_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_MSP_NS(uint32_t value)
{
__asm volatile("MSR MSP_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_SP_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,SP_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_SP_NS(uint32_t value)
{
__asm volatile("MSR SP_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_PRIMASK_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,PRIMASK_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_PRIMASK_NS(uint32_t value)
{
__asm volatile("MSR PRIMASK_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_BASEPRI_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,BASEPRI_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_BASEPRI_NS(uint32_t value)
{
__asm volatile("MSR BASEPRI_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_FAULTMASK_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,FAULTMASK_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_FAULTMASK_NS(uint32_t value)
{
__asm volatile("MSR FAULTMASK_NS,%0" :: "r" (value));
}
__IAR_FT uint32_t __TZ_get_PSPLIM_NS(void)
{
uint32_t res;
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
res = 0U;
#else
__asm volatile("MRS %0,PSPLIM_NS" : "=r" (res));
#endif
return res;
}
__IAR_FT void __TZ_set_PSPLIM_NS(uint32_t value)
{
#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
(!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3)))
// without main extensions, the non-secure PSPLIM is RAZ/WI
(void)value;
#else
__asm volatile("MSR PSPLIM_NS,%0" :: "r" (value));
#endif
}
__IAR_FT uint32_t __TZ_get_MSPLIM_NS(void)
{
uint32_t res;
__asm volatile("MRS %0,MSPLIM_NS" : "=r" (res));
return res;
}
__IAR_FT void __TZ_set_MSPLIM_NS(uint32_t value)
{
__asm volatile("MSR MSPLIM_NS,%0" :: "r" (value));
}
#endif /* __ARM_ARCH_8M_MAIN__ or __ARM_ARCH_8M_BASE__ */
#endif /* __ICCARM_INTRINSICS_VERSION__ == 2 */
#define __BKPT(value) __asm volatile ("BKPT %0" : : "i"(value))
#if __IAR_M0_FAMILY
__STATIC_INLINE int32_t __SSAT(int32_t val, uint32_t sat)
{
if ((sat >= 1U) && (sat <= 32U))
{
const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U);
const int32_t min = -1 - max ;
if (val > max)
{
return max;
}
else if (val < min)
{
return min;
}
}
return val;
}
__STATIC_INLINE uint32_t __USAT(int32_t val, uint32_t sat)
{
if (sat <= 31U)
{
const uint32_t max = ((1U << sat) - 1U);
if (val > (int32_t)max)
{
return max;
}
else if (val < 0)
{
return 0U;
}
}
return (uint32_t)val;
}
#endif
#if (__CORTEX_M >= 0x03) /* __CORTEX_M is defined in core_cm0.h, core_cm3.h and core_cm4.h. */
__IAR_FT uint8_t __LDRBT(volatile uint8_t *addr)
{
uint32_t res;
__ASM volatile ("LDRBT %0, [%1]" : "=r" (res) : "r" (addr) : "memory");
return ((uint8_t)res);
}
__IAR_FT uint16_t __LDRHT(volatile uint16_t *addr)
{
uint32_t res;
__ASM volatile ("LDRHT %0, [%1]" : "=r" (res) : "r" (addr) : "memory");
return ((uint16_t)res);
}
__IAR_FT uint32_t __LDRT(volatile uint32_t *addr)
{
uint32_t res;
__ASM volatile ("LDRT %0, [%1]" : "=r" (res) : "r" (addr) : "memory");
return res;
}
__IAR_FT void __STRBT(uint8_t value, volatile uint8_t *addr)
{
__ASM volatile ("STRBT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory");
}
__IAR_FT void __STRHT(uint16_t value, volatile uint16_t *addr)
{
__ASM volatile ("STRHT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory");
}
__IAR_FT void __STRT(uint32_t value, volatile uint32_t *addr)
{
__ASM volatile ("STRT %1, [%0]" : : "r" (addr), "r" (value) : "memory");
}
#endif /* (__CORTEX_M >= 0x03) */
#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \
(defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) )
__IAR_FT uint8_t __LDAB(volatile uint8_t *ptr)
{
uint32_t res;
__ASM volatile ("LDAB %0, [%1]" : "=r" (res) : "r" (ptr) : "memory");
return ((uint8_t)res);
}
__IAR_FT uint16_t __LDAH(volatile uint16_t *ptr)
{
uint32_t res;
__ASM volatile ("LDAH %0, [%1]" : "=r" (res) : "r" (ptr) : "memory");
return ((uint16_t)res);
}
__IAR_FT uint32_t __LDA(volatile uint32_t *ptr)
{
uint32_t res;
__ASM volatile ("LDA %0, [%1]" : "=r" (res) : "r" (ptr) : "memory");
return res;
}
__IAR_FT void __STLB(uint8_t value, volatile uint8_t *ptr)
{
__ASM volatile ("STLB %1, [%0]" :: "r" (ptr), "r" (value) : "memory");
}
__IAR_FT void __STLH(uint16_t value, volatile uint16_t *ptr)
{
__ASM volatile ("STLH %1, [%0]" :: "r" (ptr), "r" (value) : "memory");
}
__IAR_FT void __STL(uint32_t value, volatile uint32_t *ptr)
{
__ASM volatile ("STL %1, [%0]" :: "r" (ptr), "r" (value) : "memory");
}
__IAR_FT uint8_t __LDAEXB(volatile uint8_t *ptr)
{
uint32_t res;
__ASM volatile ("LDAEXB %0, [%1]" : "=r" (res) : "r" (ptr) : "memory");
return ((uint8_t)res);
}
__IAR_FT uint16_t __LDAEXH(volatile uint16_t *ptr)
{
uint32_t res;
__ASM volatile ("LDAEXH %0, [%1]" : "=r" (res) : "r" (ptr) : "memory");
return ((uint16_t)res);
}
__IAR_FT uint32_t __LDAEX(volatile uint32_t *ptr)
{
uint32_t res;
__ASM volatile ("LDAEX %0, [%1]" : "=r" (res) : "r" (ptr) : "memory");
return res;
}
__IAR_FT uint32_t __STLEXB(uint8_t value, volatile uint8_t *ptr)
{
uint32_t res;
__ASM volatile ("STLEXB %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory");
return res;
}
__IAR_FT uint32_t __STLEXH(uint16_t value, volatile uint16_t *ptr)
{
uint32_t res;
__ASM volatile ("STLEXH %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory");
return res;
}
__IAR_FT uint32_t __STLEX(uint32_t value, volatile uint32_t *ptr)
{
uint32_t res;
__ASM volatile ("STLEX %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory");
return res;
}
#endif /* __ARM_ARCH_8M_MAIN__ or __ARM_ARCH_8M_BASE__ */
#undef __IAR_FT
#undef __IAR_M0_FAMILY
#undef __ICCARM_V8
#pragma diag_default=Pe940
#pragma diag_default=Pe177
#define __SXTB16_RORn(ARG1, ARG2) __SXTB16(__ROR(ARG1, ARG2))
#endif /* __CMSIS_ICCARM_H__ */

View File

@ -0,0 +1,39 @@
/**************************************************************************//**
* @file cmsis_version.h
* @brief CMSIS Core(M) Version definitions
* @version V5.0.4
* @date 23. July 2019
******************************************************************************/
/*
* Copyright (c) 2009-2019 ARM Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef __CMSIS_VERSION_H
#define __CMSIS_VERSION_H
/* CMSIS Version definitions */
#define __CM_CMSIS_VERSION_MAIN ( 5U) /*!< [31:16] CMSIS Core(M) main version */
#define __CM_CMSIS_VERSION_SUB ( 4U) /*!< [15:0] CMSIS Core(M) sub version */
#define __CM_CMSIS_VERSION ((__CM_CMSIS_VERSION_MAIN << 16U) | \
__CM_CMSIS_VERSION_SUB ) /*!< CMSIS Core(M) version number */
#endif

View File

@ -0,0 +1,952 @@
/**************************************************************************//**
* @file core_cm0.h
* @brief CMSIS Cortex-M0 Core Peripheral Access Layer Header File
* @version V5.0.8
* @date 21. August 2019
******************************************************************************/
/*
* Copyright (c) 2009-2019 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef __CORE_CM0_H_GENERIC
#define __CORE_CM0_H_GENERIC
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
\page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions
CMSIS violates the following MISRA-C:2004 rules:
\li Required Rule 8.5, object/function definition in header file.<br>
Function definitions in header files are used to allow 'inlining'.
\li Required Rule 18.4, declaration of union type or object of union type: '{...}'.<br>
Unions are used for effective representation of core registers.
\li Advisory Rule 19.7, Function-like macro defined.<br>
Function-like macros are used to allow more efficient code.
*/
/*******************************************************************************
* CMSIS definitions
******************************************************************************/
/**
\ingroup Cortex_M0
@{
*/
#include "cmsis_version.h"
/* CMSIS CM0 definitions */
#define __CM0_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */
#define __CM0_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */
#define __CM0_CMSIS_VERSION ((__CM0_CMSIS_VERSION_MAIN << 16U) | \
__CM0_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */
#define __CORTEX_M (0U) /*!< Cortex-M Core */
/** __FPU_USED indicates whether an FPU is used or not.
This core does not support an FPU at all
*/
#define __FPU_USED 0U
#if defined ( __CC_ARM )
#if defined __TARGET_FPU_VFP
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
#if defined __ARM_FP
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __GNUC__ )
#if defined (__VFP_FP__) && !defined(__SOFTFP__)
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __ICCARM__ )
#if defined __ARMVFP__
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __TI_ARM__ )
#if defined __TI_VFP_SUPPORT__
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __TASKING__ )
#if defined __FPU_VFP__
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __CSMC__ )
#if ( __CSMC__ & 0x400U)
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#endif
#include "cmsis_compiler.h" /* CMSIS compiler specific defines */
#ifdef __cplusplus
}
#endif
#endif /* __CORE_CM0_H_GENERIC */
#ifndef __CMSIS_GENERIC
#ifndef __CORE_CM0_H_DEPENDANT
#define __CORE_CM0_H_DEPENDANT
#ifdef __cplusplus
extern "C" {
#endif
/* check device defines and use defaults */
#if defined __CHECK_DEVICE_DEFINES
#ifndef __CM0_REV
#define __CM0_REV 0x0000U
#warning "__CM0_REV not defined in device header file; using default!"
#endif
#ifndef __NVIC_PRIO_BITS
#define __NVIC_PRIO_BITS 2U
#warning "__NVIC_PRIO_BITS not defined in device header file; using default!"
#endif
#ifndef __Vendor_SysTickConfig
#define __Vendor_SysTickConfig 0U
#warning "__Vendor_SysTickConfig not defined in device header file; using default!"
#endif
#endif
/* IO definitions (access restrictions to peripheral registers) */
/**
\defgroup CMSIS_glob_defs CMSIS Global Defines
<strong>IO Type Qualifiers</strong> are used
\li to specify the access to peripheral variables.
\li for automatic generation of peripheral register debug information.
*/
#ifdef __cplusplus
#define __I volatile /*!< Defines 'read only' permissions */
#else
#define __I volatile const /*!< Defines 'read only' permissions */
#endif
#define __O volatile /*!< Defines 'write only' permissions */
#define __IO volatile /*!< Defines 'read / write' permissions */
/* following defines should be used for structure members */
#define __IM volatile const /*! Defines 'read only' structure member permissions */
#define __OM volatile /*! Defines 'write only' structure member permissions */
#define __IOM volatile /*! Defines 'read / write' structure member permissions */
/*@} end of group Cortex_M0 */
/*******************************************************************************
* Register Abstraction
Core Register contain:
- Core Register
- Core NVIC Register
- Core SCB Register
- Core SysTick Register
******************************************************************************/
/**
\defgroup CMSIS_core_register Defines and Type Definitions
\brief Type definitions and defines for Cortex-M processor based devices.
*/
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_CORE Status and Control Registers
\brief Core Register type definitions.
@{
*/
/**
\brief Union type to access the Application Program Status Register (APSR).
*/
typedef union
{
struct
{
uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */
uint32_t V:1; /*!< bit: 28 Overflow condition code flag */
uint32_t C:1; /*!< bit: 29 Carry condition code flag */
uint32_t Z:1; /*!< bit: 30 Zero condition code flag */
uint32_t N:1; /*!< bit: 31 Negative condition code flag */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} APSR_Type;
/* APSR Register Definitions */
#define APSR_N_Pos 31U /*!< APSR: N Position */
#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */
#define APSR_Z_Pos 30U /*!< APSR: Z Position */
#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */
#define APSR_C_Pos 29U /*!< APSR: C Position */
#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */
#define APSR_V_Pos 28U /*!< APSR: V Position */
#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */
/**
\brief Union type to access the Interrupt Program Status Register (IPSR).
*/
typedef union
{
struct
{
uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */
uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} IPSR_Type;
/* IPSR Register Definitions */
#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */
#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */
/**
\brief Union type to access the Special-Purpose Program Status Registers (xPSR).
*/
typedef union
{
struct
{
uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */
uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */
uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */
uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */
uint32_t V:1; /*!< bit: 28 Overflow condition code flag */
uint32_t C:1; /*!< bit: 29 Carry condition code flag */
uint32_t Z:1; /*!< bit: 30 Zero condition code flag */
uint32_t N:1; /*!< bit: 31 Negative condition code flag */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} xPSR_Type;
/* xPSR Register Definitions */
#define xPSR_N_Pos 31U /*!< xPSR: N Position */
#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */
#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */
#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */
#define xPSR_C_Pos 29U /*!< xPSR: C Position */
#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */
#define xPSR_V_Pos 28U /*!< xPSR: V Position */
#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */
#define xPSR_T_Pos 24U /*!< xPSR: T Position */
#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */
#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */
#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */
/**
\brief Union type to access the Control Registers (CONTROL).
*/
typedef union
{
struct
{
uint32_t _reserved0:1; /*!< bit: 0 Reserved */
uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */
uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} CONTROL_Type;
/* CONTROL Register Definitions */
#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */
#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */
/*@} end of group CMSIS_CORE */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC)
\brief Type definitions for the NVIC Registers
@{
*/
/**
\brief Structure type to access the Nested Vectored Interrupt Controller (NVIC).
*/
typedef struct
{
__IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */
uint32_t RESERVED0[31U];
__IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */
uint32_t RESERVED1[31U];
__IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */
uint32_t RESERVED2[31U];
__IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */
uint32_t RESERVED3[31U];
uint32_t RESERVED4[64U];
__IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */
} NVIC_Type;
/*@} end of group CMSIS_NVIC */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_SCB System Control Block (SCB)
\brief Type definitions for the System Control Block Registers
@{
*/
/**
\brief Structure type to access the System Control Block (SCB).
*/
typedef struct
{
__IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */
__IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */
uint32_t RESERVED0;
__IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */
__IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */
__IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */
uint32_t RESERVED1;
__IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */
__IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */
} SCB_Type;
/* SCB CPUID Register Definitions */
#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */
#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */
#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */
#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */
#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */
#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */
#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */
#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */
#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */
#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */
/* SCB Interrupt Control State Register Definitions */
#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */
#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */
#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */
#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */
#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */
#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */
#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */
#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */
#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */
#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */
#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */
#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */
#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */
#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */
#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */
#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */
#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */
/* SCB Application Interrupt and Reset Control Register Definitions */
#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */
#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */
#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */
#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */
#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */
#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */
#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */
#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */
#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */
#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */
/* SCB System Control Register Definitions */
#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */
#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */
#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */
#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */
#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */
#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */
/* SCB Configuration Control Register Definitions */
#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */
#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */
#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */
#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */
/* SCB System Handler Control and State Register Definitions */
#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */
#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */
/*@} end of group CMSIS_SCB */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_SysTick System Tick Timer (SysTick)
\brief Type definitions for the System Timer Registers.
@{
*/
/**
\brief Structure type to access the System Timer (SysTick).
*/
typedef struct
{
__IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */
__IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */
__IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */
__IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */
} SysTick_Type;
/* SysTick Control / Status Register Definitions */
#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */
#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */
#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */
#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */
#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */
#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */
#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */
#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */
/* SysTick Reload Register Definitions */
#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */
/* SysTick Current Register Definitions */
#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */
/* SysTick Calibration Register Definitions */
#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */
#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */
#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */
#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */
#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */
#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */
/*@} end of group CMSIS_SysTick */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug)
\brief Cortex-M0 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor.
Therefore they are not covered by the Cortex-M0 header file.
@{
*/
/*@} end of group CMSIS_CoreDebug */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_core_bitfield Core register bit field macros
\brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk).
@{
*/
/**
\brief Mask and shift a bit field value for use in a register bit range.
\param[in] field Name of the register bit field.
\param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type.
\return Masked and shifted value.
*/
#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk)
/**
\brief Mask and shift a register value to extract a bit filed value.
\param[in] field Name of the register bit field.
\param[in] value Value of register. This parameter is interpreted as an uint32_t type.
\return Masked and shifted bit field value.
*/
#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos)
/*@} end of group CMSIS_core_bitfield */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_core_base Core Definitions
\brief Definitions for base addresses, unions, and structures.
@{
*/
/* Memory mapping of Core Hardware */
#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */
#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */
#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */
#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */
#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */
#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */
#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */
/*@} */
/*******************************************************************************
* Hardware Abstraction Layer
Core Function Interface contains:
- Core NVIC Functions
- Core SysTick Functions
- Core Register Access Functions
******************************************************************************/
/**
\defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference
*/
/* ########################## NVIC functions #################################### */
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_NVICFunctions NVIC Functions
\brief Functions that manage interrupts and exceptions via the NVIC.
@{
*/
#ifdef CMSIS_NVIC_VIRTUAL
#ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE
#define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h"
#endif
#include CMSIS_NVIC_VIRTUAL_HEADER_FILE
#else
#define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping
#define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping
#define NVIC_EnableIRQ __NVIC_EnableIRQ
#define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ
#define NVIC_DisableIRQ __NVIC_DisableIRQ
#define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ
#define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ
#define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ
/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M0 */
#define NVIC_SetPriority __NVIC_SetPriority
#define NVIC_GetPriority __NVIC_GetPriority
#define NVIC_SystemReset __NVIC_SystemReset
#endif /* CMSIS_NVIC_VIRTUAL */
#ifdef CMSIS_VECTAB_VIRTUAL
#ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE
#define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h"
#endif
#include CMSIS_VECTAB_VIRTUAL_HEADER_FILE
#else
#define NVIC_SetVector __NVIC_SetVector
#define NVIC_GetVector __NVIC_GetVector
#endif /* (CMSIS_VECTAB_VIRTUAL) */
#define NVIC_USER_IRQ_OFFSET 16
/* The following EXC_RETURN values are saved the LR on exception entry */
#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */
#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */
#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */
/* Interrupt Priorities are WORD accessible only under Armv6-M */
/* The following MACROS handle generation of the register offset and byte masks */
#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL)
#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) )
#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) )
#define __NVIC_SetPriorityGrouping(X) (void)(X)
#define __NVIC_GetPriorityGrouping() (0U)
/**
\brief Enable Interrupt
\details Enables a device specific interrupt in the NVIC interrupt controller.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
__COMPILER_BARRIER();
NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
__COMPILER_BARRIER();
}
}
/**
\brief Get Interrupt Enable status
\details Returns a device specific interrupt enable status from the NVIC interrupt controller.
\param [in] IRQn Device specific interrupt number.
\return 0 Interrupt is not enabled.
\return 1 Interrupt is enabled.
\note IRQn must not be negative.
*/
__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL));
}
else
{
return(0U);
}
}
/**
\brief Disable Interrupt
\details Disables a device specific interrupt in the NVIC interrupt controller.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
__DSB();
__ISB();
}
}
/**
\brief Get Pending Interrupt
\details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt.
\param [in] IRQn Device specific interrupt number.
\return 0 Interrupt status is not pending.
\return 1 Interrupt status is pending.
\note IRQn must not be negative.
*/
__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL));
}
else
{
return(0U);
}
}
/**
\brief Set Pending Interrupt
\details Sets the pending bit of a device specific interrupt in the NVIC pending register.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
}
}
/**
\brief Clear Pending Interrupt
\details Clears the pending bit of a device specific interrupt in the NVIC pending register.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
}
}
/**
\brief Set Interrupt Priority
\details Sets the priority of a device specific interrupt or a processor exception.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
\param [in] IRQn Interrupt number.
\param [in] priority Priority to set.
\note The priority cannot be set for every processor exception.
*/
__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
}
else
{
SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
}
}
/**
\brief Get Interrupt Priority
\details Reads the priority of a device specific interrupt or a processor exception.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
\param [in] IRQn Interrupt number.
\return Interrupt Priority.
Value is aligned automatically to the implemented priority bits of the microcontroller.
*/
__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS)));
}
else
{
return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS)));
}
}
/**
\brief Encode Priority
\details Encodes the priority for an interrupt with the given priority group,
preemptive priority value, and subpriority value.
In case of a conflict between priority grouping and available
priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set.
\param [in] PriorityGroup Used priority group.
\param [in] PreemptPriority Preemptive priority value (starting from 0).
\param [in] SubPriority Subpriority value (starting from 0).
\return Encoded priority. Value can be used in the function \ref NVIC_SetPriority().
*/
__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority)
{
uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */
uint32_t PreemptPriorityBits;
uint32_t SubPriorityBits;
PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp);
SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS));
return (
((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) |
((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL)))
);
}
/**
\brief Decode Priority
\details Decodes an interrupt priority value with a given priority group to
preemptive priority value and subpriority value.
In case of a conflict between priority grouping and available
priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set.
\param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority().
\param [in] PriorityGroup Used priority group.
\param [out] pPreemptPriority Preemptive priority value (starting from 0).
\param [out] pSubPriority Subpriority value (starting from 0).
*/
__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority)
{
uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */
uint32_t PreemptPriorityBits;
uint32_t SubPriorityBits;
PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp);
SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS));
*pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL);
*pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL);
}
/**
\brief Set Interrupt Vector
\details Sets an interrupt vector in SRAM based interrupt vector table.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
Address 0 must be mapped to SRAM.
\param [in] IRQn Interrupt number
\param [in] vector Address of interrupt handler function
*/
__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector)
{
uint32_t *vectors = (uint32_t *)(NVIC_USER_IRQ_OFFSET << 2); /* point to 1st user interrupt */
*(vectors + (int32_t)IRQn) = vector; /* use pointer arithmetic to access vector */
/* ARM Application Note 321 states that the M0 does not require the architectural barrier */
}
/**
\brief Get Interrupt Vector
\details Reads an interrupt vector from interrupt vector table.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
\param [in] IRQn Interrupt number.
\return Address of interrupt handler function
*/
__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn)
{
uint32_t *vectors = (uint32_t *)(NVIC_USER_IRQ_OFFSET << 2); /* point to 1st user interrupt */
return *(vectors + (int32_t)IRQn); /* use pointer arithmetic to access vector */
}
/**
\brief System Reset
\details Initiates a system reset request to reset the MCU.
*/
__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void)
{
__DSB(); /* Ensure all outstanding memory accesses included
buffered write are completed before reset */
SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) |
SCB_AIRCR_SYSRESETREQ_Msk);
__DSB(); /* Ensure completion of memory access */
for(;;) /* wait until reset */
{
__NOP();
}
}
/*@} end of CMSIS_Core_NVICFunctions */
/* ########################## FPU functions #################################### */
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_FpuFunctions FPU Functions
\brief Function that provides FPU type.
@{
*/
/**
\brief get FPU type
\details returns the FPU type
\returns
- \b 0: No FPU
- \b 1: Single precision FPU
- \b 2: Double + Single precision FPU
*/
__STATIC_INLINE uint32_t SCB_GetFPUType(void)
{
return 0U; /* No FPU */
}
/*@} end of CMSIS_Core_FpuFunctions */
/* ################################## SysTick function ############################################ */
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_SysTickFunctions SysTick Functions
\brief Functions that configure the System.
@{
*/
#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U)
/**
\brief System Tick Configuration
\details Initializes the System Timer and its interrupt, and starts the System Tick Timer.
Counter is in free running mode to generate periodic interrupts.
\param [in] ticks Number of ticks between two interrupts.
\return 0 Function succeeded.
\return 1 Function failed.
\note When the variable <b>__Vendor_SysTickConfig</b> is set to 1, then the
function <b>SysTick_Config</b> is not included. In this case, the file <b><i>device</i>.h</b>
must contain a vendor-specific implementation of this function.
*/
__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks)
{
if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk)
{
return (1UL); /* Reload value impossible */
}
SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */
NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */
SysTick->VAL = 0UL; /* Load the SysTick Counter Value */
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
SysTick_CTRL_TICKINT_Msk |
SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */
return (0UL); /* Function successful */
}
#endif
/*@} end of CMSIS_Core_SysTickFunctions */
#ifdef __cplusplus
}
#endif
#endif /* __CORE_CM0_H_DEPENDANT */
#endif /* __CMSIS_GENERIC */

View File

@ -0,0 +1,979 @@
/**************************************************************************//**
* @file core_cm1.h
* @brief CMSIS Cortex-M1 Core Peripheral Access Layer Header File
* @version V1.0.1
* @date 12. November 2018
******************************************************************************/
/*
* Copyright (c) 2009-2018 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef __CORE_CM1_H_GENERIC
#define __CORE_CM1_H_GENERIC
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
\page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions
CMSIS violates the following MISRA-C:2004 rules:
\li Required Rule 8.5, object/function definition in header file.<br>
Function definitions in header files are used to allow 'inlining'.
\li Required Rule 18.4, declaration of union type or object of union type: '{...}'.<br>
Unions are used for effective representation of core registers.
\li Advisory Rule 19.7, Function-like macro defined.<br>
Function-like macros are used to allow more efficient code.
*/
/*******************************************************************************
* CMSIS definitions
******************************************************************************/
/**
\ingroup Cortex_M1
@{
*/
#include "cmsis_version.h"
/* CMSIS CM1 definitions */
#define __CM1_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */
#define __CM1_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */
#define __CM1_CMSIS_VERSION ((__CM1_CMSIS_VERSION_MAIN << 16U) | \
__CM1_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */
#define __CORTEX_M (1U) /*!< Cortex-M Core */
/** __FPU_USED indicates whether an FPU is used or not.
This core does not support an FPU at all
*/
#define __FPU_USED 0U
#if defined ( __CC_ARM )
#if defined __TARGET_FPU_VFP
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
#if defined __ARM_FP
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __GNUC__ )
#if defined (__VFP_FP__) && !defined(__SOFTFP__)
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __ICCARM__ )
#if defined __ARMVFP__
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __TI_ARM__ )
#if defined __TI_VFP_SUPPORT__
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __TASKING__ )
#if defined __FPU_VFP__
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#elif defined ( __CSMC__ )
#if ( __CSMC__ & 0x400U)
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#endif
#endif
#include "cmsis_compiler.h" /* CMSIS compiler specific defines */
#ifdef __cplusplus
}
#endif
#endif /* __CORE_CM1_H_GENERIC */
#ifndef __CMSIS_GENERIC
#ifndef __CORE_CM1_H_DEPENDANT
#define __CORE_CM1_H_DEPENDANT
#ifdef __cplusplus
extern "C" {
#endif
/* check device defines and use defaults */
#if defined __CHECK_DEVICE_DEFINES
#ifndef __CM1_REV
#define __CM1_REV 0x0100U
#warning "__CM1_REV not defined in device header file; using default!"
#endif
#ifndef __NVIC_PRIO_BITS
#define __NVIC_PRIO_BITS 2U
#warning "__NVIC_PRIO_BITS not defined in device header file; using default!"
#endif
#ifndef __Vendor_SysTickConfig
#define __Vendor_SysTickConfig 0U
#warning "__Vendor_SysTickConfig not defined in device header file; using default!"
#endif
#endif
/* IO definitions (access restrictions to peripheral registers) */
/**
\defgroup CMSIS_glob_defs CMSIS Global Defines
<strong>IO Type Qualifiers</strong> are used
\li to specify the access to peripheral variables.
\li for automatic generation of peripheral register debug information.
*/
#ifdef __cplusplus
#define __I volatile /*!< Defines 'read only' permissions */
#else
#define __I volatile const /*!< Defines 'read only' permissions */
#endif
#define __O volatile /*!< Defines 'write only' permissions */
#define __IO volatile /*!< Defines 'read / write' permissions */
/* following defines should be used for structure members */
#define __IM volatile const /*! Defines 'read only' structure member permissions */
#define __OM volatile /*! Defines 'write only' structure member permissions */
#define __IOM volatile /*! Defines 'read / write' structure member permissions */
/*@} end of group Cortex_M1 */
/*******************************************************************************
* Register Abstraction
Core Register contain:
- Core Register
- Core NVIC Register
- Core SCB Register
- Core SysTick Register
******************************************************************************/
/**
\defgroup CMSIS_core_register Defines and Type Definitions
\brief Type definitions and defines for Cortex-M processor based devices.
*/
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_CORE Status and Control Registers
\brief Core Register type definitions.
@{
*/
/**
\brief Union type to access the Application Program Status Register (APSR).
*/
typedef union
{
struct
{
uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */
uint32_t V:1; /*!< bit: 28 Overflow condition code flag */
uint32_t C:1; /*!< bit: 29 Carry condition code flag */
uint32_t Z:1; /*!< bit: 30 Zero condition code flag */
uint32_t N:1; /*!< bit: 31 Negative condition code flag */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} APSR_Type;
/* APSR Register Definitions */
#define APSR_N_Pos 31U /*!< APSR: N Position */
#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */
#define APSR_Z_Pos 30U /*!< APSR: Z Position */
#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */
#define APSR_C_Pos 29U /*!< APSR: C Position */
#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */
#define APSR_V_Pos 28U /*!< APSR: V Position */
#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */
/**
\brief Union type to access the Interrupt Program Status Register (IPSR).
*/
typedef union
{
struct
{
uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */
uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} IPSR_Type;
/* IPSR Register Definitions */
#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */
#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */
/**
\brief Union type to access the Special-Purpose Program Status Registers (xPSR).
*/
typedef union
{
struct
{
uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */
uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */
uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */
uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */
uint32_t V:1; /*!< bit: 28 Overflow condition code flag */
uint32_t C:1; /*!< bit: 29 Carry condition code flag */
uint32_t Z:1; /*!< bit: 30 Zero condition code flag */
uint32_t N:1; /*!< bit: 31 Negative condition code flag */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} xPSR_Type;
/* xPSR Register Definitions */
#define xPSR_N_Pos 31U /*!< xPSR: N Position */
#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */
#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */
#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */
#define xPSR_C_Pos 29U /*!< xPSR: C Position */
#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */
#define xPSR_V_Pos 28U /*!< xPSR: V Position */
#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */
#define xPSR_T_Pos 24U /*!< xPSR: T Position */
#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */
#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */
#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */
/**
\brief Union type to access the Control Registers (CONTROL).
*/
typedef union
{
struct
{
uint32_t _reserved0:1; /*!< bit: 0 Reserved */
uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */
uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */
} b; /*!< Structure used for bit access */
uint32_t w; /*!< Type used for word access */
} CONTROL_Type;
/* CONTROL Register Definitions */
#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */
#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */
/*@} end of group CMSIS_CORE */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC)
\brief Type definitions for the NVIC Registers
@{
*/
/**
\brief Structure type to access the Nested Vectored Interrupt Controller (NVIC).
*/
typedef struct
{
__IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */
uint32_t RESERVED0[31U];
__IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */
uint32_t RSERVED1[31U];
__IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */
uint32_t RESERVED2[31U];
__IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */
uint32_t RESERVED3[31U];
uint32_t RESERVED4[64U];
__IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */
} NVIC_Type;
/*@} end of group CMSIS_NVIC */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_SCB System Control Block (SCB)
\brief Type definitions for the System Control Block Registers
@{
*/
/**
\brief Structure type to access the System Control Block (SCB).
*/
typedef struct
{
__IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */
__IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */
uint32_t RESERVED0;
__IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */
__IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */
__IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */
uint32_t RESERVED1;
__IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */
__IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */
} SCB_Type;
/* SCB CPUID Register Definitions */
#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */
#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */
#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */
#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */
#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */
#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */
#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */
#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */
#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */
#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */
/* SCB Interrupt Control State Register Definitions */
#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */
#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */
#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */
#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */
#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */
#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */
#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */
#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */
#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */
#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */
#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */
#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */
#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */
#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */
#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */
#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */
#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */
/* SCB Application Interrupt and Reset Control Register Definitions */
#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */
#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */
#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */
#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */
#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */
#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */
#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */
#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */
#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */
#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */
/* SCB System Control Register Definitions */
#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */
#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */
#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */
#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */
#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */
#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */
/* SCB Configuration Control Register Definitions */
#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */
#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */
#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */
#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */
/* SCB System Handler Control and State Register Definitions */
#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */
#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */
/*@} end of group CMSIS_SCB */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB)
\brief Type definitions for the System Control and ID Register not in the SCB
@{
*/
/**
\brief Structure type to access the System Control and ID Register not in the SCB.
*/
typedef struct
{
uint32_t RESERVED0[2U];
__IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */
} SCnSCB_Type;
/* Auxiliary Control Register Definitions */
#define SCnSCB_ACTLR_ITCMUAEN_Pos 4U /*!< ACTLR: Instruction TCM Upper Alias Enable Position */
#define SCnSCB_ACTLR_ITCMUAEN_Msk (1UL << SCnSCB_ACTLR_ITCMUAEN_Pos) /*!< ACTLR: Instruction TCM Upper Alias Enable Mask */
#define SCnSCB_ACTLR_ITCMLAEN_Pos 3U /*!< ACTLR: Instruction TCM Lower Alias Enable Position */
#define SCnSCB_ACTLR_ITCMLAEN_Msk (1UL << SCnSCB_ACTLR_ITCMLAEN_Pos) /*!< ACTLR: Instruction TCM Lower Alias Enable Mask */
/*@} end of group CMSIS_SCnotSCB */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_SysTick System Tick Timer (SysTick)
\brief Type definitions for the System Timer Registers.
@{
*/
/**
\brief Structure type to access the System Timer (SysTick).
*/
typedef struct
{
__IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */
__IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */
__IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */
__IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */
} SysTick_Type;
/* SysTick Control / Status Register Definitions */
#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */
#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */
#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */
#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */
#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */
#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */
#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */
#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */
/* SysTick Reload Register Definitions */
#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */
/* SysTick Current Register Definitions */
#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */
/* SysTick Calibration Register Definitions */
#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */
#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */
#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */
#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */
#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */
#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */
/*@} end of group CMSIS_SysTick */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug)
\brief Cortex-M1 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor.
Therefore they are not covered by the Cortex-M1 header file.
@{
*/
/*@} end of group CMSIS_CoreDebug */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_core_bitfield Core register bit field macros
\brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk).
@{
*/
/**
\brief Mask and shift a bit field value for use in a register bit range.
\param[in] field Name of the register bit field.
\param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type.
\return Masked and shifted value.
*/
#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk)
/**
\brief Mask and shift a register value to extract a bit filed value.
\param[in] field Name of the register bit field.
\param[in] value Value of register. This parameter is interpreted as an uint32_t type.
\return Masked and shifted bit field value.
*/
#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos)
/*@} end of group CMSIS_core_bitfield */
/**
\ingroup CMSIS_core_register
\defgroup CMSIS_core_base Core Definitions
\brief Definitions for base addresses, unions, and structures.
@{
*/
/* Memory mapping of Core Hardware */
#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */
#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */
#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */
#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */
#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */
#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */
#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */
#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */
/*@} */
/*******************************************************************************
* Hardware Abstraction Layer
Core Function Interface contains:
- Core NVIC Functions
- Core SysTick Functions
- Core Register Access Functions
******************************************************************************/
/**
\defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference
*/
/* ########################## NVIC functions #################################### */
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_NVICFunctions NVIC Functions
\brief Functions that manage interrupts and exceptions via the NVIC.
@{
*/
#ifdef CMSIS_NVIC_VIRTUAL
#ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE
#define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h"
#endif
#include CMSIS_NVIC_VIRTUAL_HEADER_FILE
#else
#define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping
#define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping
#define NVIC_EnableIRQ __NVIC_EnableIRQ
#define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ
#define NVIC_DisableIRQ __NVIC_DisableIRQ
#define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ
#define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ
#define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ
/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M1 */
#define NVIC_SetPriority __NVIC_SetPriority
#define NVIC_GetPriority __NVIC_GetPriority
#define NVIC_SystemReset __NVIC_SystemReset
#endif /* CMSIS_NVIC_VIRTUAL */
#ifdef CMSIS_VECTAB_VIRTUAL
#ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE
#define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h"
#endif
#include CMSIS_VECTAB_VIRTUAL_HEADER_FILE
#else
#define NVIC_SetVector __NVIC_SetVector
#define NVIC_GetVector __NVIC_GetVector
#endif /* (CMSIS_VECTAB_VIRTUAL) */
#define NVIC_USER_IRQ_OFFSET 16
/* The following EXC_RETURN values are saved the LR on exception entry */
#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */
#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */
#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */
/* Interrupt Priorities are WORD accessible only under Armv6-M */
/* The following MACROS handle generation of the register offset and byte masks */
#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL)
#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) )
#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) )
#define __NVIC_SetPriorityGrouping(X) (void)(X)
#define __NVIC_GetPriorityGrouping() (0U)
/**
\brief Enable Interrupt
\details Enables a device specific interrupt in the NVIC interrupt controller.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
__COMPILER_BARRIER();
NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
__COMPILER_BARRIER();
}
}
/**
\brief Get Interrupt Enable status
\details Returns a device specific interrupt enable status from the NVIC interrupt controller.
\param [in] IRQn Device specific interrupt number.
\return 0 Interrupt is not enabled.
\return 1 Interrupt is enabled.
\note IRQn must not be negative.
*/
__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL));
}
else
{
return(0U);
}
}
/**
\brief Disable Interrupt
\details Disables a device specific interrupt in the NVIC interrupt controller.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
__DSB();
__ISB();
}
}
/**
\brief Get Pending Interrupt
\details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt.
\param [in] IRQn Device specific interrupt number.
\return 0 Interrupt status is not pending.
\return 1 Interrupt status is pending.
\note IRQn must not be negative.
*/
__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL));
}
else
{
return(0U);
}
}
/**
\brief Set Pending Interrupt
\details Sets the pending bit of a device specific interrupt in the NVIC pending register.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
}
}
/**
\brief Clear Pending Interrupt
\details Clears the pending bit of a device specific interrupt in the NVIC pending register.
\param [in] IRQn Device specific interrupt number.
\note IRQn must not be negative.
*/
__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
}
}
/**
\brief Set Interrupt Priority
\details Sets the priority of a device specific interrupt or a processor exception.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
\param [in] IRQn Interrupt number.
\param [in] priority Priority to set.
\note The priority cannot be set for every processor exception.
*/
__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
{
if ((int32_t)(IRQn) >= 0)
{
NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
}
else
{
SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
}
}
/**
\brief Get Interrupt Priority
\details Reads the priority of a device specific interrupt or a processor exception.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
\param [in] IRQn Interrupt number.
\return Interrupt Priority.
Value is aligned automatically to the implemented priority bits of the microcontroller.
*/
__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn)
{
if ((int32_t)(IRQn) >= 0)
{
return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS)));
}
else
{
return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS)));
}
}
/**
\brief Encode Priority
\details Encodes the priority for an interrupt with the given priority group,
preemptive priority value, and subpriority value.
In case of a conflict between priority grouping and available
priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set.
\param [in] PriorityGroup Used priority group.
\param [in] PreemptPriority Preemptive priority value (starting from 0).
\param [in] SubPriority Subpriority value (starting from 0).
\return Encoded priority. Value can be used in the function \ref NVIC_SetPriority().
*/
__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority)
{
uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */
uint32_t PreemptPriorityBits;
uint32_t SubPriorityBits;
PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp);
SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS));
return (
((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) |
((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL)))
);
}
/**
\brief Decode Priority
\details Decodes an interrupt priority value with a given priority group to
preemptive priority value and subpriority value.
In case of a conflict between priority grouping and available
priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set.
\param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority().
\param [in] PriorityGroup Used priority group.
\param [out] pPreemptPriority Preemptive priority value (starting from 0).
\param [out] pSubPriority Subpriority value (starting from 0).
*/
__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority)
{
uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */
uint32_t PreemptPriorityBits;
uint32_t SubPriorityBits;
PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp);
SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS));
*pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL);
*pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL);
}
/**
\brief Set Interrupt Vector
\details Sets an interrupt vector in SRAM based interrupt vector table.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
Address 0 must be mapped to SRAM.
\param [in] IRQn Interrupt number
\param [in] vector Address of interrupt handler function
*/
__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector)
{
uint32_t *vectors = (uint32_t *)0x0U;
vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector;
/* ARM Application Note 321 states that the M1 does not require the architectural barrier */
}
/**
\brief Get Interrupt Vector
\details Reads an interrupt vector from interrupt vector table.
The interrupt number can be positive to specify a device specific interrupt,
or negative to specify a processor exception.
\param [in] IRQn Interrupt number.
\return Address of interrupt handler function
*/
__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn)
{
uint32_t *vectors = (uint32_t *)0x0U;
return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET];
}
/**
\brief System Reset
\details Initiates a system reset request to reset the MCU.
*/
__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void)
{
__DSB(); /* Ensure all outstanding memory accesses included
buffered write are completed before reset */
SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) |
SCB_AIRCR_SYSRESETREQ_Msk);
__DSB(); /* Ensure completion of memory access */
for(;;) /* wait until reset */
{
__NOP();
}
}
/*@} end of CMSIS_Core_NVICFunctions */
/* ########################## FPU functions #################################### */
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_FpuFunctions FPU Functions
\brief Function that provides FPU type.
@{
*/
/**
\brief get FPU type
\details returns the FPU type
\returns
- \b 0: No FPU
- \b 1: Single precision FPU
- \b 2: Double + Single precision FPU
*/
__STATIC_INLINE uint32_t SCB_GetFPUType(void)
{
return 0U; /* No FPU */
}
/*@} end of CMSIS_Core_FpuFunctions */
/* ################################## SysTick function ############################################ */
/**
\ingroup CMSIS_Core_FunctionInterface
\defgroup CMSIS_Core_SysTickFunctions SysTick Functions
\brief Functions that configure the System.
@{
*/
#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U)
/**
\brief System Tick Configuration
\details Initializes the System Timer and its interrupt, and starts the System Tick Timer.
Counter is in free running mode to generate periodic interrupts.
\param [in] ticks Number of ticks between two interrupts.
\return 0 Function succeeded.
\return 1 Function failed.
\note When the variable <b>__Vendor_SysTickConfig</b> is set to 1, then the
function <b>SysTick_Config</b> is not included. In this case, the file <b><i>device</i>.h</b>
must contain a vendor-specific implementation of this function.
*/
__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks)
{
if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk)
{
return (1UL); /* Reload value impossible */
}
SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */
NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */
SysTick->VAL = 0UL; /* Load the SysTick Counter Value */
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
SysTick_CTRL_TICKINT_Msk |
SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */
return (0UL); /* Function successful */
}
#endif
/*@} end of CMSIS_Core_SysTickFunctions */
#ifdef __cplusplus
}
#endif
#endif /* __CORE_CM1_H_DEPENDANT */
#endif /* __CMSIS_GENERIC */

View File

@ -0,0 +1,275 @@
/******************************************************************************
* @file mpu_armv7.h
* @brief CMSIS MPU API for Armv7-M MPU
* @version V5.1.1
* @date 10. February 2020
******************************************************************************/
/*
* Copyright (c) 2017-2020 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef ARM_MPU_ARMV7_H
#define ARM_MPU_ARMV7_H
#define ARM_MPU_REGION_SIZE_32B ((uint8_t)0x04U) ///!< MPU Region Size 32 Bytes
#define ARM_MPU_REGION_SIZE_64B ((uint8_t)0x05U) ///!< MPU Region Size 64 Bytes
#define ARM_MPU_REGION_SIZE_128B ((uint8_t)0x06U) ///!< MPU Region Size 128 Bytes
#define ARM_MPU_REGION_SIZE_256B ((uint8_t)0x07U) ///!< MPU Region Size 256 Bytes
#define ARM_MPU_REGION_SIZE_512B ((uint8_t)0x08U) ///!< MPU Region Size 512 Bytes
#define ARM_MPU_REGION_SIZE_1KB ((uint8_t)0x09U) ///!< MPU Region Size 1 KByte
#define ARM_MPU_REGION_SIZE_2KB ((uint8_t)0x0AU) ///!< MPU Region Size 2 KBytes
#define ARM_MPU_REGION_SIZE_4KB ((uint8_t)0x0BU) ///!< MPU Region Size 4 KBytes
#define ARM_MPU_REGION_SIZE_8KB ((uint8_t)0x0CU) ///!< MPU Region Size 8 KBytes
#define ARM_MPU_REGION_SIZE_16KB ((uint8_t)0x0DU) ///!< MPU Region Size 16 KBytes
#define ARM_MPU_REGION_SIZE_32KB ((uint8_t)0x0EU) ///!< MPU Region Size 32 KBytes
#define ARM_MPU_REGION_SIZE_64KB ((uint8_t)0x0FU) ///!< MPU Region Size 64 KBytes
#define ARM_MPU_REGION_SIZE_128KB ((uint8_t)0x10U) ///!< MPU Region Size 128 KBytes
#define ARM_MPU_REGION_SIZE_256KB ((uint8_t)0x11U) ///!< MPU Region Size 256 KBytes
#define ARM_MPU_REGION_SIZE_512KB ((uint8_t)0x12U) ///!< MPU Region Size 512 KBytes
#define ARM_MPU_REGION_SIZE_1MB ((uint8_t)0x13U) ///!< MPU Region Size 1 MByte
#define ARM_MPU_REGION_SIZE_2MB ((uint8_t)0x14U) ///!< MPU Region Size 2 MBytes
#define ARM_MPU_REGION_SIZE_4MB ((uint8_t)0x15U) ///!< MPU Region Size 4 MBytes
#define ARM_MPU_REGION_SIZE_8MB ((uint8_t)0x16U) ///!< MPU Region Size 8 MBytes
#define ARM_MPU_REGION_SIZE_16MB ((uint8_t)0x17U) ///!< MPU Region Size 16 MBytes
#define ARM_MPU_REGION_SIZE_32MB ((uint8_t)0x18U) ///!< MPU Region Size 32 MBytes
#define ARM_MPU_REGION_SIZE_64MB ((uint8_t)0x19U) ///!< MPU Region Size 64 MBytes
#define ARM_MPU_REGION_SIZE_128MB ((uint8_t)0x1AU) ///!< MPU Region Size 128 MBytes
#define ARM_MPU_REGION_SIZE_256MB ((uint8_t)0x1BU) ///!< MPU Region Size 256 MBytes
#define ARM_MPU_REGION_SIZE_512MB ((uint8_t)0x1CU) ///!< MPU Region Size 512 MBytes
#define ARM_MPU_REGION_SIZE_1GB ((uint8_t)0x1DU) ///!< MPU Region Size 1 GByte
#define ARM_MPU_REGION_SIZE_2GB ((uint8_t)0x1EU) ///!< MPU Region Size 2 GBytes
#define ARM_MPU_REGION_SIZE_4GB ((uint8_t)0x1FU) ///!< MPU Region Size 4 GBytes
#define ARM_MPU_AP_NONE 0U ///!< MPU Access Permission no access
#define ARM_MPU_AP_PRIV 1U ///!< MPU Access Permission privileged access only
#define ARM_MPU_AP_URO 2U ///!< MPU Access Permission unprivileged access read-only
#define ARM_MPU_AP_FULL 3U ///!< MPU Access Permission full access
#define ARM_MPU_AP_PRO 5U ///!< MPU Access Permission privileged access read-only
#define ARM_MPU_AP_RO 6U ///!< MPU Access Permission read-only access
/** MPU Region Base Address Register Value
*
* \param Region The region to be configured, number 0 to 15.
* \param BaseAddress The base address for the region.
*/
#define ARM_MPU_RBAR(Region, BaseAddress) \
(((BaseAddress) & MPU_RBAR_ADDR_Msk) | \
((Region) & MPU_RBAR_REGION_Msk) | \
(MPU_RBAR_VALID_Msk))
/**
* MPU Memory Access Attributes
*
* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral.
* \param IsShareable Region is shareable between multiple bus masters.
* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache.
* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy.
*/
#define ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable) \
((((TypeExtField) << MPU_RASR_TEX_Pos) & MPU_RASR_TEX_Msk) | \
(((IsShareable) << MPU_RASR_S_Pos) & MPU_RASR_S_Msk) | \
(((IsCacheable) << MPU_RASR_C_Pos) & MPU_RASR_C_Msk) | \
(((IsBufferable) << MPU_RASR_B_Pos) & MPU_RASR_B_Msk))
/**
* MPU Region Attribute and Size Register Value
*
* \param DisableExec Instruction access disable bit, 1= disable instruction fetches.
* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode.
* \param AccessAttributes Memory access attribution, see \ref ARM_MPU_ACCESS_.
* \param SubRegionDisable Sub-region disable field.
* \param Size Region size of the region to be configured, for example 4K, 8K.
*/
#define ARM_MPU_RASR_EX(DisableExec, AccessPermission, AccessAttributes, SubRegionDisable, Size) \
((((DisableExec) << MPU_RASR_XN_Pos) & MPU_RASR_XN_Msk) | \
(((AccessPermission) << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk) | \
(((AccessAttributes) & (MPU_RASR_TEX_Msk | MPU_RASR_S_Msk | MPU_RASR_C_Msk | MPU_RASR_B_Msk))) | \
(((SubRegionDisable) << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk) | \
(((Size) << MPU_RASR_SIZE_Pos) & MPU_RASR_SIZE_Msk) | \
(((MPU_RASR_ENABLE_Msk))))
/**
* MPU Region Attribute and Size Register Value
*
* \param DisableExec Instruction access disable bit, 1= disable instruction fetches.
* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode.
* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral.
* \param IsShareable Region is shareable between multiple bus masters.
* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache.
* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy.
* \param SubRegionDisable Sub-region disable field.
* \param Size Region size of the region to be configured, for example 4K, 8K.
*/
#define ARM_MPU_RASR(DisableExec, AccessPermission, TypeExtField, IsShareable, IsCacheable, IsBufferable, SubRegionDisable, Size) \
ARM_MPU_RASR_EX(DisableExec, AccessPermission, ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable), SubRegionDisable, Size)
/**
* MPU Memory Access Attribute for strongly ordered memory.
* - TEX: 000b
* - Shareable
* - Non-cacheable
* - Non-bufferable
*/
#define ARM_MPU_ACCESS_ORDERED ARM_MPU_ACCESS_(0U, 1U, 0U, 0U)
/**
* MPU Memory Access Attribute for device memory.
* - TEX: 000b (if shareable) or 010b (if non-shareable)
* - Shareable or non-shareable
* - Non-cacheable
* - Bufferable (if shareable) or non-bufferable (if non-shareable)
*
* \param IsShareable Configures the device memory as shareable or non-shareable.
*/
#define ARM_MPU_ACCESS_DEVICE(IsShareable) ((IsShareable) ? ARM_MPU_ACCESS_(0U, 1U, 0U, 1U) : ARM_MPU_ACCESS_(2U, 0U, 0U, 0U))
/**
* MPU Memory Access Attribute for normal memory.
* - TEX: 1BBb (reflecting outer cacheability rules)
* - Shareable or non-shareable
* - Cacheable or non-cacheable (reflecting inner cacheability rules)
* - Bufferable or non-bufferable (reflecting inner cacheability rules)
*
* \param OuterCp Configures the outer cache policy.
* \param InnerCp Configures the inner cache policy.
* \param IsShareable Configures the memory as shareable or non-shareable.
*/
#define ARM_MPU_ACCESS_NORMAL(OuterCp, InnerCp, IsShareable) ARM_MPU_ACCESS_((4U | (OuterCp)), IsShareable, ((InnerCp) >> 1U), ((InnerCp) & 1U))
/**
* MPU Memory Access Attribute non-cacheable policy.
*/
#define ARM_MPU_CACHEP_NOCACHE 0U
/**
* MPU Memory Access Attribute write-back, write and read allocate policy.
*/
#define ARM_MPU_CACHEP_WB_WRA 1U
/**
* MPU Memory Access Attribute write-through, no write allocate policy.
*/
#define ARM_MPU_CACHEP_WT_NWA 2U
/**
* MPU Memory Access Attribute write-back, no write allocate policy.
*/
#define ARM_MPU_CACHEP_WB_NWA 3U
/**
* Struct for a single MPU Region
*/
typedef struct {
uint32_t RBAR; //!< The region base address register value (RBAR)
uint32_t RASR; //!< The region attribute and size register value (RASR) \ref MPU_RASR
} ARM_MPU_Region_t;
/** Enable the MPU.
* \param MPU_Control Default access permissions for unconfigured regions.
*/
__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control)
{
__DMB();
MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk;
#ifdef SCB_SHCSR_MEMFAULTENA_Msk
SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
#endif
__DSB();
__ISB();
}
/** Disable the MPU.
*/
__STATIC_INLINE void ARM_MPU_Disable(void)
{
__DMB();
#ifdef SCB_SHCSR_MEMFAULTENA_Msk
SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk;
#endif
MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk;
__DSB();
__ISB();
}
/** Clear and disable the given MPU region.
* \param rnr Region number to be cleared.
*/
__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr)
{
MPU->RNR = rnr;
MPU->RASR = 0U;
}
/** Configure an MPU region.
* \param rbar Value for RBAR register.
* \param rsar Value for RSAR register.
*/
__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rbar, uint32_t rasr)
{
MPU->RBAR = rbar;
MPU->RASR = rasr;
}
/** Configure the given MPU region.
* \param rnr Region number to be configured.
* \param rbar Value for RBAR register.
* \param rsar Value for RSAR register.
*/
__STATIC_INLINE void ARM_MPU_SetRegionEx(uint32_t rnr, uint32_t rbar, uint32_t rasr)
{
MPU->RNR = rnr;
MPU->RBAR = rbar;
MPU->RASR = rasr;
}
/** Memcopy with strictly ordered memory access, e.g. for register targets.
* \param dst Destination data is copied to.
* \param src Source data is copied from.
* \param len Amount of data words to be copied.
*/
__STATIC_INLINE void ARM_MPU_OrderedMemcpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len)
{
uint32_t i;
for (i = 0U; i < len; ++i)
{
dst[i] = src[i];
}
}
/** Load the given number of MPU regions from a table.
* \param table Pointer to the MPU configuration table.
* \param cnt Amount of regions to be configured.
*/
__STATIC_INLINE void ARM_MPU_Load(ARM_MPU_Region_t const* table, uint32_t cnt)
{
const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U;
while (cnt > MPU_TYPE_RALIASES) {
ARM_MPU_OrderedMemcpy(&(MPU->RBAR), &(table->RBAR), MPU_TYPE_RALIASES*rowWordSize);
table += MPU_TYPE_RALIASES;
cnt -= MPU_TYPE_RALIASES;
}
ARM_MPU_OrderedMemcpy(&(MPU->RBAR), &(table->RBAR), cnt*rowWordSize);
}
#endif

View File

@ -0,0 +1,352 @@
/******************************************************************************
* @file mpu_armv8.h
* @brief CMSIS MPU API for Armv8-M and Armv8.1-M MPU
* @version V5.1.2
* @date 10. February 2020
******************************************************************************/
/*
* Copyright (c) 2017-2020 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef ARM_MPU_ARMV8_H
#define ARM_MPU_ARMV8_H
/** \brief Attribute for device memory (outer only) */
#define ARM_MPU_ATTR_DEVICE ( 0U )
/** \brief Attribute for non-cacheable, normal memory */
#define ARM_MPU_ATTR_NON_CACHEABLE ( 4U )
/** \brief Attribute for normal memory (outer and inner)
* \param NT Non-Transient: Set to 1 for non-transient data.
* \param WB Write-Back: Set to 1 to use write-back update policy.
* \param RA Read Allocation: Set to 1 to use cache allocation on read miss.
* \param WA Write Allocation: Set to 1 to use cache allocation on write miss.
*/
#define ARM_MPU_ATTR_MEMORY_(NT, WB, RA, WA) \
((((NT) & 1U) << 3U) | (((WB) & 1U) << 2U) | (((RA) & 1U) << 1U) | ((WA) & 1U))
/** \brief Device memory type non Gathering, non Re-ordering, non Early Write Acknowledgement */
#define ARM_MPU_ATTR_DEVICE_nGnRnE (0U)
/** \brief Device memory type non Gathering, non Re-ordering, Early Write Acknowledgement */
#define ARM_MPU_ATTR_DEVICE_nGnRE (1U)
/** \brief Device memory type non Gathering, Re-ordering, Early Write Acknowledgement */
#define ARM_MPU_ATTR_DEVICE_nGRE (2U)
/** \brief Device memory type Gathering, Re-ordering, Early Write Acknowledgement */
#define ARM_MPU_ATTR_DEVICE_GRE (3U)
/** \brief Memory Attribute
* \param O Outer memory attributes
* \param I O == ARM_MPU_ATTR_DEVICE: Device memory attributes, else: Inner memory attributes
*/
#define ARM_MPU_ATTR(O, I) ((((O) & 0xFU) << 4U) | ((((O) & 0xFU) != 0U) ? ((I) & 0xFU) : (((I) & 0x3U) << 2U)))
/** \brief Normal memory non-shareable */
#define ARM_MPU_SH_NON (0U)
/** \brief Normal memory outer shareable */
#define ARM_MPU_SH_OUTER (2U)
/** \brief Normal memory inner shareable */
#define ARM_MPU_SH_INNER (3U)
/** \brief Memory access permissions
* \param RO Read-Only: Set to 1 for read-only memory.
* \param NP Non-Privileged: Set to 1 for non-privileged memory.
*/
#define ARM_MPU_AP_(RO, NP) ((((RO) & 1U) << 1U) | ((NP) & 1U))
/** \brief Region Base Address Register value
* \param BASE The base address bits [31:5] of a memory region. The value is zero extended. Effective address gets 32 byte aligned.
* \param SH Defines the Shareability domain for this memory region.
* \param RO Read-Only: Set to 1 for a read-only memory region.
* \param NP Non-Privileged: Set to 1 for a non-privileged memory region.
* \oaram XN eXecute Never: Set to 1 for a non-executable memory region.
*/
#define ARM_MPU_RBAR(BASE, SH, RO, NP, XN) \
(((BASE) & MPU_RBAR_BASE_Msk) | \
(((SH) << MPU_RBAR_SH_Pos) & MPU_RBAR_SH_Msk) | \
((ARM_MPU_AP_(RO, NP) << MPU_RBAR_AP_Pos) & MPU_RBAR_AP_Msk) | \
(((XN) << MPU_RBAR_XN_Pos) & MPU_RBAR_XN_Msk))
/** \brief Region Limit Address Register value
* \param LIMIT The limit address bits [31:5] for this memory region. The value is one extended.
* \param IDX The attribute index to be associated with this memory region.
*/
#define ARM_MPU_RLAR(LIMIT, IDX) \
(((LIMIT) & MPU_RLAR_LIMIT_Msk) | \
(((IDX) << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \
(MPU_RLAR_EN_Msk))
#if defined(MPU_RLAR_PXN_Pos)
/** \brief Region Limit Address Register with PXN value
* \param LIMIT The limit address bits [31:5] for this memory region. The value is one extended.
* \param PXN Privileged execute never. Defines whether code can be executed from this privileged region.
* \param IDX The attribute index to be associated with this memory region.
*/
#define ARM_MPU_RLAR_PXN(LIMIT, PXN, IDX) \
(((LIMIT) & MPU_RLAR_LIMIT_Msk) | \
(((PXN) << MPU_RLAR_PXN_Pos) & MPU_RLAR_PXN_Msk) | \
(((IDX) << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \
(MPU_RLAR_EN_Msk))
#endif
/**
* Struct for a single MPU Region
*/
typedef struct {
uint32_t RBAR; /*!< Region Base Address Register value */
uint32_t RLAR; /*!< Region Limit Address Register value */
} ARM_MPU_Region_t;
/** Enable the MPU.
* \param MPU_Control Default access permissions for unconfigured regions.
*/
__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control)
{
__DMB();
MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk;
#ifdef SCB_SHCSR_MEMFAULTENA_Msk
SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
#endif
__DSB();
__ISB();
}
/** Disable the MPU.
*/
__STATIC_INLINE void ARM_MPU_Disable(void)
{
__DMB();
#ifdef SCB_SHCSR_MEMFAULTENA_Msk
SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk;
#endif
MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk;
__DSB();
__ISB();
}
#ifdef MPU_NS
/** Enable the Non-secure MPU.
* \param MPU_Control Default access permissions for unconfigured regions.
*/
__STATIC_INLINE void ARM_MPU_Enable_NS(uint32_t MPU_Control)
{
__DMB();
MPU_NS->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk;
#ifdef SCB_SHCSR_MEMFAULTENA_Msk
SCB_NS->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
#endif
__DSB();
__ISB();
}
/** Disable the Non-secure MPU.
*/
__STATIC_INLINE void ARM_MPU_Disable_NS(void)
{
__DMB();
#ifdef SCB_SHCSR_MEMFAULTENA_Msk
SCB_NS->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk;
#endif
MPU_NS->CTRL &= ~MPU_CTRL_ENABLE_Msk;
__DSB();
__ISB();
}
#endif
/** Set the memory attribute encoding to the given MPU.
* \param mpu Pointer to the MPU to be configured.
* \param idx The attribute index to be set [0-7]
* \param attr The attribute value to be set.
*/
__STATIC_INLINE void ARM_MPU_SetMemAttrEx(MPU_Type* mpu, uint8_t idx, uint8_t attr)
{
const uint8_t reg = idx / 4U;
const uint32_t pos = ((idx % 4U) * 8U);
const uint32_t mask = 0xFFU << pos;
if (reg >= (sizeof(mpu->MAIR) / sizeof(mpu->MAIR[0]))) {
return; // invalid index
}
mpu->MAIR[reg] = ((mpu->MAIR[reg] & ~mask) | ((attr << pos) & mask));
}
/** Set the memory attribute encoding.
* \param idx The attribute index to be set [0-7]
* \param attr The attribute value to be set.
*/
__STATIC_INLINE void ARM_MPU_SetMemAttr(uint8_t idx, uint8_t attr)
{
ARM_MPU_SetMemAttrEx(MPU, idx, attr);
}
#ifdef MPU_NS
/** Set the memory attribute encoding to the Non-secure MPU.
* \param idx The attribute index to be set [0-7]
* \param attr The attribute value to be set.
*/
__STATIC_INLINE void ARM_MPU_SetMemAttr_NS(uint8_t idx, uint8_t attr)
{
ARM_MPU_SetMemAttrEx(MPU_NS, idx, attr);
}
#endif
/** Clear and disable the given MPU region of the given MPU.
* \param mpu Pointer to MPU to be used.
* \param rnr Region number to be cleared.
*/
__STATIC_INLINE void ARM_MPU_ClrRegionEx(MPU_Type* mpu, uint32_t rnr)
{
mpu->RNR = rnr;
mpu->RLAR = 0U;
}
/** Clear and disable the given MPU region.
* \param rnr Region number to be cleared.
*/
__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr)
{
ARM_MPU_ClrRegionEx(MPU, rnr);
}
#ifdef MPU_NS
/** Clear and disable the given Non-secure MPU region.
* \param rnr Region number to be cleared.
*/
__STATIC_INLINE void ARM_MPU_ClrRegion_NS(uint32_t rnr)
{
ARM_MPU_ClrRegionEx(MPU_NS, rnr);
}
#endif
/** Configure the given MPU region of the given MPU.
* \param mpu Pointer to MPU to be used.
* \param rnr Region number to be configured.
* \param rbar Value for RBAR register.
* \param rlar Value for RLAR register.
*/
__STATIC_INLINE void ARM_MPU_SetRegionEx(MPU_Type* mpu, uint32_t rnr, uint32_t rbar, uint32_t rlar)
{
mpu->RNR = rnr;
mpu->RBAR = rbar;
mpu->RLAR = rlar;
}
/** Configure the given MPU region.
* \param rnr Region number to be configured.
* \param rbar Value for RBAR register.
* \param rlar Value for RLAR register.
*/
__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rnr, uint32_t rbar, uint32_t rlar)
{
ARM_MPU_SetRegionEx(MPU, rnr, rbar, rlar);
}
#ifdef MPU_NS
/** Configure the given Non-secure MPU region.
* \param rnr Region number to be configured.
* \param rbar Value for RBAR register.
* \param rlar Value for RLAR register.
*/
__STATIC_INLINE void ARM_MPU_SetRegion_NS(uint32_t rnr, uint32_t rbar, uint32_t rlar)
{
ARM_MPU_SetRegionEx(MPU_NS, rnr, rbar, rlar);
}
#endif
/** Memcopy with strictly ordered memory access, e.g. for register targets.
* \param dst Destination data is copied to.
* \param src Source data is copied from.
* \param len Amount of data words to be copied.
*/
__STATIC_INLINE void ARM_MPU_OrderedMemcpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len)
{
uint32_t i;
for (i = 0U; i < len; ++i)
{
dst[i] = src[i];
}
}
/** Load the given number of MPU regions from a table to the given MPU.
* \param mpu Pointer to the MPU registers to be used.
* \param rnr First region number to be configured.
* \param table Pointer to the MPU configuration table.
* \param cnt Amount of regions to be configured.
*/
__STATIC_INLINE void ARM_MPU_LoadEx(MPU_Type* mpu, uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt)
{
const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U;
if (cnt == 1U) {
mpu->RNR = rnr;
ARM_MPU_OrderedMemcpy(&(mpu->RBAR), &(table->RBAR), rowWordSize);
} else {
uint32_t rnrBase = rnr & ~(MPU_TYPE_RALIASES-1U);
uint32_t rnrOffset = rnr % MPU_TYPE_RALIASES;
mpu->RNR = rnrBase;
while ((rnrOffset + cnt) > MPU_TYPE_RALIASES) {
uint32_t c = MPU_TYPE_RALIASES - rnrOffset;
ARM_MPU_OrderedMemcpy(&(mpu->RBAR)+(rnrOffset*2U), &(table->RBAR), c*rowWordSize);
table += c;
cnt -= c;
rnrOffset = 0U;
rnrBase += MPU_TYPE_RALIASES;
mpu->RNR = rnrBase;
}
ARM_MPU_OrderedMemcpy(&(mpu->RBAR)+(rnrOffset*2U), &(table->RBAR), cnt*rowWordSize);
}
}
/** Load the given number of MPU regions from a table.
* \param rnr First region number to be configured.
* \param table Pointer to the MPU configuration table.
* \param cnt Amount of regions to be configured.
*/
__STATIC_INLINE void ARM_MPU_Load(uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt)
{
ARM_MPU_LoadEx(MPU, rnr, table, cnt);
}
#ifdef MPU_NS
/** Load the given number of MPU regions from a table to the Non-secure MPU.
* \param rnr First region number to be configured.
* \param table Pointer to the MPU configuration table.
* \param cnt Amount of regions to be configured.
*/
__STATIC_INLINE void ARM_MPU_Load_NS(uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt)
{
ARM_MPU_LoadEx(MPU_NS, rnr, table, cnt);
}
#endif
#endif

View File

@ -0,0 +1,337 @@
/******************************************************************************
* @file pmu_armv8.h
* @brief CMSIS PMU API for Armv8.1-M PMU
* @version V1.0.0
* @date 24. March 2020
******************************************************************************/
/*
* Copyright (c) 2020 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef ARM_PMU_ARMV8_H
#define ARM_PMU_ARMV8_H
/**
* \brief PMU Events
* \note See the Armv8.1-M Architecture Reference Manual for full details on these PMU events.
* */
#define ARM_PMU_SW_INCR 0x0000 /*!< Software update to the PMU_SWINC register, architecturally executed and condition code check pass */
#define ARM_PMU_L1I_CACHE_REFILL 0x0001 /*!< L1 I-Cache refill */
#define ARM_PMU_L1D_CACHE_REFILL 0x0003 /*!< L1 D-Cache refill */
#define ARM_PMU_L1D_CACHE 0x0004 /*!< L1 D-Cache access */
#define ARM_PMU_LD_RETIRED 0x0006 /*!< Memory-reading instruction architecturally executed and condition code check pass */
#define ARM_PMU_ST_RETIRED 0x0007 /*!< Memory-writing instruction architecturally executed and condition code check pass */
#define ARM_PMU_INST_RETIRED 0x0008 /*!< Instruction architecturally executed */
#define ARM_PMU_EXC_TAKEN 0x0009 /*!< Exception entry */
#define ARM_PMU_EXC_RETURN 0x000A /*!< Exception return instruction architecturally executed and the condition code check pass */
#define ARM_PMU_PC_WRITE_RETIRED 0x000C /*!< Software change to the Program Counter (PC). Instruction is architecturally executed and condition code check pass */
#define ARM_PMU_BR_IMMED_RETIRED 0x000D /*!< Immediate branch architecturally executed */
#define ARM_PMU_BR_RETURN_RETIRED 0x000E /*!< Function return instruction architecturally executed and the condition code check pass */
#define ARM_PMU_UNALIGNED_LDST_RETIRED 0x000F /*!< Unaligned memory memory-reading or memory-writing instruction architecturally executed and condition code check pass */
#define ARM_PMU_BR_MIS_PRED 0x0010 /*!< Mispredicted or not predicted branch speculatively executed */
#define ARM_PMU_CPU_CYCLES 0x0011 /*!< Cycle */
#define ARM_PMU_BR_PRED 0x0012 /*!< Predictable branch speculatively executed */
#define ARM_PMU_MEM_ACCESS 0x0013 /*!< Data memory access */
#define ARM_PMU_L1I_CACHE 0x0014 /*!< Level 1 instruction cache access */
#define ARM_PMU_L1D_CACHE_WB 0x0015 /*!< Level 1 data cache write-back */
#define ARM_PMU_L2D_CACHE 0x0016 /*!< Level 2 data cache access */
#define ARM_PMU_L2D_CACHE_REFILL 0x0017 /*!< Level 2 data cache refill */
#define ARM_PMU_L2D_CACHE_WB 0x0018 /*!< Level 2 data cache write-back */
#define ARM_PMU_BUS_ACCESS 0x0019 /*!< Bus access */
#define ARM_PMU_MEMORY_ERROR 0x001A /*!< Local memory error */
#define ARM_PMU_INST_SPEC 0x001B /*!< Instruction speculatively executed */
#define ARM_PMU_BUS_CYCLES 0x001D /*!< Bus cycles */
#define ARM_PMU_CHAIN 0x001E /*!< For an odd numbered counter, increment when an overflow occurs on the preceding even-numbered counter on the same PE */
#define ARM_PMU_L1D_CACHE_ALLOCATE 0x001F /*!< Level 1 data cache allocation without refill */
#define ARM_PMU_L2D_CACHE_ALLOCATE 0x0020 /*!< Level 2 data cache allocation without refill */
#define ARM_PMU_BR_RETIRED 0x0021 /*!< Branch instruction architecturally executed */
#define ARM_PMU_BR_MIS_PRED_RETIRED 0x0022 /*!< Mispredicted branch instruction architecturally executed */
#define ARM_PMU_STALL_FRONTEND 0x0023 /*!< No operation issued because of the frontend */
#define ARM_PMU_STALL_BACKEND 0x0024 /*!< No operation issued because of the backend */
#define ARM_PMU_L2I_CACHE 0x0027 /*!< Level 2 instruction cache access */
#define ARM_PMU_L2I_CACHE_REFILL 0x0028 /*!< Level 2 instruction cache refill */
#define ARM_PMU_L3D_CACHE_ALLOCATE 0x0029 /*!< Level 3 data cache allocation without refill */
#define ARM_PMU_L3D_CACHE_REFILL 0x002A /*!< Level 3 data cache refill */
#define ARM_PMU_L3D_CACHE 0x002B /*!< Level 3 data cache access */
#define ARM_PMU_L3D_CACHE_WB 0x002C /*!< Level 3 data cache write-back */
#define ARM_PMU_LL_CACHE_RD 0x0036 /*!< Last level data cache read */
#define ARM_PMU_LL_CACHE_MISS_RD 0x0037 /*!< Last level data cache read miss */
#define ARM_PMU_L1D_CACHE_MISS_RD 0x0039 /*!< Level 1 data cache read miss */
#define ARM_PMU_OP_COMPLETE 0x003A /*!< Operation retired */
#define ARM_PMU_OP_SPEC 0x003B /*!< Operation speculatively executed */
#define ARM_PMU_STALL 0x003C /*!< Stall cycle for instruction or operation not sent for execution */
#define ARM_PMU_STALL_OP_BACKEND 0x003D /*!< Stall cycle for instruction or operation not sent for execution due to pipeline backend */
#define ARM_PMU_STALL_OP_FRONTEND 0x003E /*!< Stall cycle for instruction or operation not sent for execution due to pipeline frontend */
#define ARM_PMU_STALL_OP 0x003F /*!< Instruction or operation slots not occupied each cycle */
#define ARM_PMU_L1D_CACHE_RD 0x0040 /*!< Level 1 data cache read */
#define ARM_PMU_LE_RETIRED 0x0100 /*!< Loop end instruction executed */
#define ARM_PMU_LE_SPEC 0x0101 /*!< Loop end instruction speculatively executed */
#define ARM_PMU_BF_RETIRED 0x0104 /*!< Branch future instruction architecturally executed and condition code check pass */
#define ARM_PMU_BF_SPEC 0x0105 /*!< Branch future instruction speculatively executed and condition code check pass */
#define ARM_PMU_LE_CANCEL 0x0108 /*!< Loop end instruction not taken */
#define ARM_PMU_BF_CANCEL 0x0109 /*!< Branch future instruction not taken */
#define ARM_PMU_SE_CALL_S 0x0114 /*!< Call to secure function, resulting in Security state change */
#define ARM_PMU_SE_CALL_NS 0x0115 /*!< Call to non-secure function, resulting in Security state change */
#define ARM_PMU_DWT_CMPMATCH0 0x0118 /*!< DWT comparator 0 match */
#define ARM_PMU_DWT_CMPMATCH1 0x0119 /*!< DWT comparator 1 match */
#define ARM_PMU_DWT_CMPMATCH2 0x011A /*!< DWT comparator 2 match */
#define ARM_PMU_DWT_CMPMATCH3 0x011B /*!< DWT comparator 3 match */
#define ARM_PMU_MVE_INST_RETIRED 0x0200 /*!< MVE instruction architecturally executed */
#define ARM_PMU_MVE_INST_SPEC 0x0201 /*!< MVE instruction speculatively executed */
#define ARM_PMU_MVE_FP_RETIRED 0x0204 /*!< MVE floating-point instruction architecturally executed */
#define ARM_PMU_MVE_FP_SPEC 0x0205 /*!< MVE floating-point instruction speculatively executed */
#define ARM_PMU_MVE_FP_HP_RETIRED 0x0208 /*!< MVE half-precision floating-point instruction architecturally executed */
#define ARM_PMU_MVE_FP_HP_SPEC 0x0209 /*!< MVE half-precision floating-point instruction speculatively executed */
#define ARM_PMU_MVE_FP_SP_RETIRED 0x020C /*!< MVE single-precision floating-point instruction architecturally executed */
#define ARM_PMU_MVE_FP_SP_SPEC 0x020D /*!< MVE single-precision floating-point instruction speculatively executed */
#define ARM_PMU_MVE_FP_MAC_RETIRED 0x0214 /*!< MVE floating-point multiply or multiply-accumulate instruction architecturally executed */
#define ARM_PMU_MVE_FP_MAC_SPEC 0x0215 /*!< MVE floating-point multiply or multiply-accumulate instruction speculatively executed */
#define ARM_PMU_MVE_INT_RETIRED 0x0224 /*!< MVE integer instruction architecturally executed */
#define ARM_PMU_MVE_INT_SPEC 0x0225 /*!< MVE integer instruction speculatively executed */
#define ARM_PMU_MVE_INT_MAC_RETIRED 0x0228 /*!< MVE multiply or multiply-accumulate instruction architecturally executed */
#define ARM_PMU_MVE_INT_MAC_SPEC 0x0229 /*!< MVE multiply or multiply-accumulate instruction speculatively executed */
#define ARM_PMU_MVE_LDST_RETIRED 0x0238 /*!< MVE load or store instruction architecturally executed */
#define ARM_PMU_MVE_LDST_SPEC 0x0239 /*!< MVE load or store instruction speculatively executed */
#define ARM_PMU_MVE_LD_RETIRED 0x023C /*!< MVE load instruction architecturally executed */
#define ARM_PMU_MVE_LD_SPEC 0x023D /*!< MVE load instruction speculatively executed */
#define ARM_PMU_MVE_ST_RETIRED 0x0240 /*!< MVE store instruction architecturally executed */
#define ARM_PMU_MVE_ST_SPEC 0x0241 /*!< MVE store instruction speculatively executed */
#define ARM_PMU_MVE_LDST_CONTIG_RETIRED 0x0244 /*!< MVE contiguous load or store instruction architecturally executed */
#define ARM_PMU_MVE_LDST_CONTIG_SPEC 0x0245 /*!< MVE contiguous load or store instruction speculatively executed */
#define ARM_PMU_MVE_LD_CONTIG_RETIRED 0x0248 /*!< MVE contiguous load instruction architecturally executed */
#define ARM_PMU_MVE_LD_CONTIG_SPEC 0x0249 /*!< MVE contiguous load instruction speculatively executed */
#define ARM_PMU_MVE_ST_CONTIG_RETIRED 0x024C /*!< MVE contiguous store instruction architecturally executed */
#define ARM_PMU_MVE_ST_CONTIG_SPEC 0x024D /*!< MVE contiguous store instruction speculatively executed */
#define ARM_PMU_MVE_LDST_NONCONTIG_RETIRED 0x0250 /*!< MVE non-contiguous load or store instruction architecturally executed */
#define ARM_PMU_MVE_LDST_NONCONTIG_SPEC 0x0251 /*!< MVE non-contiguous load or store instruction speculatively executed */
#define ARM_PMU_MVE_LD_NONCONTIG_RETIRED 0x0254 /*!< MVE non-contiguous load instruction architecturally executed */
#define ARM_PMU_MVE_LD_NONCONTIG_SPEC 0x0255 /*!< MVE non-contiguous load instruction speculatively executed */
#define ARM_PMU_MVE_ST_NONCONTIG_RETIRED 0x0258 /*!< MVE non-contiguous store instruction architecturally executed */
#define ARM_PMU_MVE_ST_NONCONTIG_SPEC 0x0259 /*!< MVE non-contiguous store instruction speculatively executed */
#define ARM_PMU_MVE_LDST_MULTI_RETIRED 0x025C /*!< MVE memory instruction targeting multiple registers architecturally executed */
#define ARM_PMU_MVE_LDST_MULTI_SPEC 0x025D /*!< MVE memory instruction targeting multiple registers speculatively executed */
#define ARM_PMU_MVE_LD_MULTI_RETIRED 0x0260 /*!< MVE memory load instruction targeting multiple registers architecturally executed */
#define ARM_PMU_MVE_LD_MULTI_SPEC 0x0261 /*!< MVE memory load instruction targeting multiple registers speculatively executed */
#define ARM_PMU_MVE_ST_MULTI_RETIRED 0x0261 /*!< MVE memory store instruction targeting multiple registers architecturally executed */
#define ARM_PMU_MVE_ST_MULTI_SPEC 0x0265 /*!< MVE memory store instruction targeting multiple registers speculatively executed */
#define ARM_PMU_MVE_LDST_UNALIGNED_RETIRED 0x028C /*!< MVE unaligned memory load or store instruction architecturally executed */
#define ARM_PMU_MVE_LDST_UNALIGNED_SPEC 0x028D /*!< MVE unaligned memory load or store instruction speculatively executed */
#define ARM_PMU_MVE_LD_UNALIGNED_RETIRED 0x0290 /*!< MVE unaligned load instruction architecturally executed */
#define ARM_PMU_MVE_LD_UNALIGNED_SPEC 0x0291 /*!< MVE unaligned load instruction speculatively executed */
#define ARM_PMU_MVE_ST_UNALIGNED_RETIRED 0x0294 /*!< MVE unaligned store instruction architecturally executed */
#define ARM_PMU_MVE_ST_UNALIGNED_SPEC 0x0295 /*!< MVE unaligned store instruction speculatively executed */
#define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_RETIRED 0x0298 /*!< MVE unaligned noncontiguous load or store instruction architecturally executed */
#define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_SPEC 0x0299 /*!< MVE unaligned noncontiguous load or store instruction speculatively executed */
#define ARM_PMU_MVE_VREDUCE_RETIRED 0x02A0 /*!< MVE vector reduction instruction architecturally executed */
#define ARM_PMU_MVE_VREDUCE_SPEC 0x02A1 /*!< MVE vector reduction instruction speculatively executed */
#define ARM_PMU_MVE_VREDUCE_FP_RETIRED 0x02A4 /*!< MVE floating-point vector reduction instruction architecturally executed */
#define ARM_PMU_MVE_VREDUCE_FP_SPEC 0x02A5 /*!< MVE floating-point vector reduction instruction speculatively executed */
#define ARM_PMU_MVE_VREDUCE_INT_RETIRED 0x02A8 /*!< MVE integer vector reduction instruction architecturally executed */
#define ARM_PMU_MVE_VREDUCE_INT_SPEC 0x02A9 /*!< MVE integer vector reduction instruction speculatively executed */
#define ARM_PMU_MVE_PRED 0x02B8 /*!< Cycles where one or more predicated beats architecturally executed */
#define ARM_PMU_MVE_STALL 0x02CC /*!< Stall cycles caused by an MVE instruction */
#define ARM_PMU_MVE_STALL_RESOURCE 0x02CD /*!< Stall cycles caused by an MVE instruction because of resource conflicts */
#define ARM_PMU_MVE_STALL_RESOURCE_MEM 0x02CE /*!< Stall cycles caused by an MVE instruction because of memory resource conflicts */
#define ARM_PMU_MVE_STALL_RESOURCE_FP 0x02CF /*!< Stall cycles caused by an MVE instruction because of floating-point resource conflicts */
#define ARM_PMU_MVE_STALL_RESOURCE_INT 0x02D0 /*!< Stall cycles caused by an MVE instruction because of integer resource conflicts */
#define ARM_PMU_MVE_STALL_BREAK 0x02D3 /*!< Stall cycles caused by an MVE chain break */
#define ARM_PMU_MVE_STALL_DEPENDENCY 0x02D4 /*!< Stall cycles caused by MVE register dependency */
#define ARM_PMU_ITCM_ACCESS 0x4007 /*!< Instruction TCM access */
#define ARM_PMU_DTCM_ACCESS 0x4008 /*!< Data TCM access */
#define ARM_PMU_TRCEXTOUT0 0x4010 /*!< ETM external output 0 */
#define ARM_PMU_TRCEXTOUT1 0x4011 /*!< ETM external output 1 */
#define ARM_PMU_TRCEXTOUT2 0x4012 /*!< ETM external output 2 */
#define ARM_PMU_TRCEXTOUT3 0x4013 /*!< ETM external output 3 */
#define ARM_PMU_CTI_TRIGOUT4 0x4018 /*!< Cross-trigger Interface output trigger 4 */
#define ARM_PMU_CTI_TRIGOUT5 0x4019 /*!< Cross-trigger Interface output trigger 5 */
#define ARM_PMU_CTI_TRIGOUT6 0x401A /*!< Cross-trigger Interface output trigger 6 */
#define ARM_PMU_CTI_TRIGOUT7 0x401B /*!< Cross-trigger Interface output trigger 7 */
/** \brief PMU Functions */
__STATIC_INLINE void ARM_PMU_Enable(void);
__STATIC_INLINE void ARM_PMU_Disable(void);
__STATIC_INLINE void ARM_PMU_Set_EVTYPER(uint32_t num, uint32_t type);
__STATIC_INLINE void ARM_PMU_CYCCNT_Reset(void);
__STATIC_INLINE void ARM_PMU_EVCNTR_ALL_Reset(void);
__STATIC_INLINE void ARM_PMU_CNTR_Enable(uint32_t mask);
__STATIC_INLINE void ARM_PMU_CNTR_Disable(uint32_t mask);
__STATIC_INLINE uint32_t ARM_PMU_Get_CCNTR(void);
__STATIC_INLINE uint32_t ARM_PMU_Get_EVCNTR(uint32_t num);
__STATIC_INLINE uint32_t ARM_PMU_Get_CNTR_OVS(void);
__STATIC_INLINE void ARM_PMU_Set_CNTR_OVS(uint32_t mask);
__STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Enable(uint32_t mask);
__STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Disable(uint32_t mask);
__STATIC_INLINE void ARM_PMU_CNTR_Increment(uint32_t mask);
/**
\brief Enable the PMU
*/
__STATIC_INLINE void ARM_PMU_Enable(void)
{
PMU->CTRL |= PMU_CTRL_ENABLE_Msk;
}
/**
\brief Disable the PMU
*/
__STATIC_INLINE void ARM_PMU_Disable(void)
{
PMU->CTRL &= ~PMU_CTRL_ENABLE_Msk;
}
/**
\brief Set event to count for PMU eventer counter
\param [in] num Event counter (0-30) to configure
\param [in] type Event to count
*/
__STATIC_INLINE void ARM_PMU_Set_EVTYPER(uint32_t num, uint32_t type)
{
PMU->EVTYPER[num] = type;
}
/**
\brief Reset cycle counter
*/
__STATIC_INLINE void ARM_PMU_CYCCNT_Reset(void)
{
PMU->CTRL |= PMU_CTRL_CYCCNT_RESET_Msk;
}
/**
\brief Reset all event counters
*/
__STATIC_INLINE void ARM_PMU_EVCNTR_ALL_Reset(void)
{
PMU->CTRL |= PMU_CTRL_EVENTCNT_RESET_Msk;
}
/**
\brief Enable counters
\param [in] mask Counters to enable
\note Enables one or more of the following:
- event counters (0-30)
- cycle counter
*/
__STATIC_INLINE void ARM_PMU_CNTR_Enable(uint32_t mask)
{
PMU->CNTENSET = mask;
}
/**
\brief Disable counters
\param [in] mask Counters to enable
\note Disables one or more of the following:
- event counters (0-30)
- cycle counter
*/
__STATIC_INLINE void ARM_PMU_CNTR_Disable(uint32_t mask)
{
PMU->CNTENCLR = mask;
}
/**
\brief Read cycle counter
\return Cycle count
*/
__STATIC_INLINE uint32_t ARM_PMU_Get_CCNTR(void)
{
return PMU->CCNTR;
}
/**
\brief Read event counter
\param [in] num Event counter (0-30) to read
\return Event count
*/
__STATIC_INLINE uint32_t ARM_PMU_Get_EVCNTR(uint32_t num)
{
return PMU->EVCNTR[num];
}
/**
\brief Read counter overflow status
\return Counter overflow status bits for the following:
- event counters (0-30)
- cycle counter
*/
__STATIC_INLINE uint32_t ARM_PMU_Get_CNTR_OVS(void)
{
return PMU->OVSSET;
}
/**
\brief Clear counter overflow status
\param [in] mask Counter overflow status bits to clear
\note Clears overflow status bits for one or more of the following:
- event counters (0-30)
- cycle counter
*/
__STATIC_INLINE void ARM_PMU_Set_CNTR_OVS(uint32_t mask)
{
PMU->OVSCLR = mask;
}
/**
\brief Enable counter overflow interrupt request
\param [in] mask Counter overflow interrupt request bits to set
\note Sets overflow interrupt request bits for one or more of the following:
- event counters (0-30)
- cycle counter
*/
__STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Enable(uint32_t mask)
{
PMU->INTENSET = mask;
}
/**
\brief Disable counter overflow interrupt request
\param [in] mask Counter overflow interrupt request bits to clear
\note Clears overflow interrupt request bits for one or more of the following:
- event counters (0-30)
- cycle counter
*/
__STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Disable(uint32_t mask)
{
PMU->INTENCLR = mask;
}
/**
\brief Software increment event counter
\param [in] mask Counters to increment
\note Software increment bits for one or more event counters (0-30)
*/
__STATIC_INLINE void ARM_PMU_CNTR_Increment(uint32_t mask)
{
PMU->SWINC = mask;
}
#endif

View File

@ -0,0 +1,70 @@
/******************************************************************************
* @file tz_context.h
* @brief Context Management for Armv8-M TrustZone
* @version V1.0.1
* @date 10. January 2018
******************************************************************************/
/*
* Copyright (c) 2017-2018 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if defined ( __ICCARM__ )
#pragma system_include /* treat file as system include file for MISRA check */
#elif defined (__clang__)
#pragma clang system_header /* treat file as system include file */
#endif
#ifndef TZ_CONTEXT_H
#define TZ_CONTEXT_H
#include <stdint.h>
#ifndef TZ_MODULEID_T
#define TZ_MODULEID_T
/// \details Data type that identifies secure software modules called by a process.
typedef uint32_t TZ_ModuleId_t;
#endif
/// \details TZ Memory ID identifies an allocated memory slot.
typedef uint32_t TZ_MemoryId_t;
/// Initialize secure context memory system
/// \return execution status (1: success, 0: error)
uint32_t TZ_InitContextSystem_S (void);
/// Allocate context memory for calling secure software modules in TrustZone
/// \param[in] module identifies software modules called from non-secure mode
/// \return value != 0 id TrustZone memory slot identifier
/// \return value 0 no memory available or internal error
TZ_MemoryId_t TZ_AllocModuleContext_S (TZ_ModuleId_t module);
/// Free context memory that was previously allocated with \ref TZ_AllocModuleContext_S
/// \param[in] id TrustZone memory slot identifier
/// \return execution status (1: success, 0: error)
uint32_t TZ_FreeModuleContext_S (TZ_MemoryId_t id);
/// Load secure context (called on RTOS thread context switch)
/// \param[in] id TrustZone memory slot identifier
/// \return execution status (1: success, 0: error)
uint32_t TZ_LoadContext_S (TZ_MemoryId_t id);
/// Store secure context (called on RTOS thread context switch)
/// \param[in] id TrustZone memory slot identifier
/// \return execution status (1: success, 0: error)
uint32_t TZ_StoreContext_S (TZ_MemoryId_t id);
#endif // TZ_CONTEXT_H

View File

@ -0,0 +1,201 @@
Apache License
Version 2.0, January 2004
http://www.apache.org/licenses/
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
1. Definitions.
"License" shall mean the terms and conditions for use, reproduction,
and distribution as defined by Sections 1 through 9 of this document.
"Licensor" shall mean the copyright owner or entity authorized by
the copyright owner that is granting the License.
"Legal Entity" shall mean the union of the acting entity and all
other entities that control, are controlled by, or are under common
control with that entity. For the purposes of this definition,
"control" means (i) the power, direct or indirect, to cause the
direction or management of such entity, whether by contract or
otherwise, or (ii) ownership of fifty percent (50%) or more of the
outstanding shares, or (iii) beneficial ownership of such entity.
"You" (or "Your") shall mean an individual or Legal Entity
exercising permissions granted by this License.
"Source" form shall mean the preferred form for making modifications,
including but not limited to software source code, documentation
source, and configuration files.
"Object" form shall mean any form resulting from mechanical
transformation or translation of a Source form, including but
not limited to compiled object code, generated documentation,
and conversions to other media types.
"Work" shall mean the work of authorship, whether in Source or
Object form, made available under the License, as indicated by a
copyright notice that is included in or attached to the work
(an example is provided in the Appendix below).
"Derivative Works" shall mean any work, whether in Source or Object
form, that is based on (or derived from) the Work and for which the
editorial revisions, annotations, elaborations, or other modifications
represent, as a whole, an original work of authorship. For the purposes
of this License, Derivative Works shall not include works that remain
separable from, or merely link (or bind by name) to the interfaces of,
the Work and Derivative Works thereof.
"Contribution" shall mean any work of authorship, including
the original version of the Work and any modifications or additions
to that Work or Derivative Works thereof, that is intentionally
submitted to Licensor for inclusion in the Work by the copyright owner
or by an individual or Legal Entity authorized to submit on behalf of
the copyright owner. For the purposes of this definition, "submitted"
means any form of electronic, verbal, or written communication sent
to the Licensor or its representatives, including but not limited to
communication on electronic mailing lists, source code control systems,
and issue tracking systems that are managed by, or on behalf of, the
Licensor for the purpose of discussing and improving the Work, but
excluding communication that is conspicuously marked or otherwise
designated in writing by the copyright owner as "Not a Contribution."
"Contributor" shall mean Licensor and any individual or Legal Entity
on behalf of whom a Contribution has been received by Licensor and
subsequently incorporated within the Work.
2. Grant of Copyright License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
copyright license to reproduce, prepare Derivative Works of,
publicly display, publicly perform, sublicense, and distribute the
Work and such Derivative Works in Source or Object form.
3. Grant of Patent License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
(except as stated in this section) patent license to make, have made,
use, offer to sell, sell, import, and otherwise transfer the Work,
where such license applies only to those patent claims licensable
by such Contributor that are necessarily infringed by their
Contribution(s) alone or by combination of their Contribution(s)
with the Work to which such Contribution(s) was submitted. If You
institute patent litigation against any entity (including a
cross-claim or counterclaim in a lawsuit) alleging that the Work
or a Contribution incorporated within the Work constitutes direct
or contributory patent infringement, then any patent licenses
granted to You under this License for that Work shall terminate
as of the date such litigation is filed.
4. Redistribution. You may reproduce and distribute copies of the
Work or Derivative Works thereof in any medium, with or without
modifications, and in Source or Object form, provided that You
meet the following conditions:
(a) You must give any other recipients of the Work or
Derivative Works a copy of this License; and
(b) You must cause any modified files to carry prominent notices
stating that You changed the files; and
(c) You must retain, in the Source form of any Derivative Works
that You distribute, all copyright, patent, trademark, and
attribution notices from the Source form of the Work,
excluding those notices that do not pertain to any part of
the Derivative Works; and
(d) If the Work includes a "NOTICE" text file as part of its
distribution, then any Derivative Works that You distribute must
include a readable copy of the attribution notices contained
within such NOTICE file, excluding those notices that do not
pertain to any part of the Derivative Works, in at least one
of the following places: within a NOTICE text file distributed
as part of the Derivative Works; within the Source form or
documentation, if provided along with the Derivative Works; or,
within a display generated by the Derivative Works, if and
wherever such third-party notices normally appear. The contents
of the NOTICE file are for informational purposes only and
do not modify the License. You may add Your own attribution
notices within Derivative Works that You distribute, alongside
or as an addendum to the NOTICE text from the Work, provided
that such additional attribution notices cannot be construed
as modifying the License.
You may add Your own copyright statement to Your modifications and
may provide additional or different license terms and conditions
for use, reproduction, or distribution of Your modifications, or
for any such Derivative Works as a whole, provided Your use,
reproduction, and distribution of the Work otherwise complies with
the conditions stated in this License.
5. Submission of Contributions. Unless You explicitly state otherwise,
any Contribution intentionally submitted for inclusion in the Work
by You to the Licensor shall be under the terms and conditions of
this License, without any additional terms or conditions.
Notwithstanding the above, nothing herein shall supersede or modify
the terms of any separate license agreement you may have executed
with Licensor regarding such Contributions.
6. Trademarks. This License does not grant permission to use the trade
names, trademarks, service marks, or product names of the Licensor,
except as required for reasonable and customary use in describing the
origin of the Work and reproducing the content of the NOTICE file.
7. Disclaimer of Warranty. Unless required by applicable law or
agreed to in writing, Licensor provides the Work (and each
Contributor provides its Contributions) on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied, including, without limitation, any warranties or conditions
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
PARTICULAR PURPOSE. You are solely responsible for determining the
appropriateness of using or redistributing the Work and assume any
risks associated with Your exercise of permissions under this License.
8. Limitation of Liability. In no event and under no legal theory,
whether in tort (including negligence), contract, or otherwise,
unless required by applicable law (such as deliberate and grossly
negligent acts) or agreed to in writing, shall any Contributor be
liable to You for damages, including any direct, indirect, special,
incidental, or consequential damages of any character arising as a
result of this License or out of the use or inability to use the
Work (including but not limited to damages for loss of goodwill,
work stoppage, computer failure or malfunction, or any and all
other commercial damages or losses), even if such Contributor
has been advised of the possibility of such damages.
9. Accepting Warranty or Additional Liability. While redistributing
the Work or Derivative Works thereof, You may choose to offer,
and charge a fee for, acceptance of support, warranty, indemnity,
or other liability obligations and/or rights consistent with this
License. However, in accepting such obligations, You may act only
on Your own behalf and on Your sole responsibility, not on behalf
of any other Contributor, and only if You agree to indemnify,
defend, and hold each Contributor harmless for any liability
incurred by, or claims asserted against, such Contributor by reason
of your accepting any such warranty or additional liability.
END OF TERMS AND CONDITIONS
APPENDIX: How to apply the Apache License to your work.
To apply the Apache License to your work, attach the following
boilerplate notice, with the fields enclosed by brackets "{}"
replaced with your own identifying information. (Don't include
the brackets!) The text should be enclosed in the appropriate
comment syntax for the file format. We also recommend that a
file or class name and description of purpose be included on the
same "printed page" as the copyright notice for easier
identification within third-party archives.
Copyright {yyyy} {name of copyright owner}
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

View File

@ -0,0 +1,5 @@
SRC_DIR :=
SRC_FILES := $(wildcard *.c)
include $(KERNEL_ROOT)/compiler.mk

View File

@ -0,0 +1,66 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : board.h
* Version : 1.00
* Description : board header
*********************************************************************************************************************/
/******************************************************************************************************************//**
* @ingroup BOARDS
* @defgroup BOARD_RZG2UL_SMARC BSP for the RZG2UL-SMARC board
* @brief BSP for the RZG2UL-SMARC Board
*
* The RZG2UL_SMARC is a evaluation kit for the Renesas R9A07G043U12GBG microcontroller in a LFBGA361 package.
*
* @{
*********************************************************************************************************************/
#ifndef BOARD_H
#define BOARD_H
/**********************************************************************************************************************
* Includes <System Includes> , "Project Includes"
*********************************************************************************************************************/
/* BSP Board Specific Includes. */
#include "board_init.h"
/**********************************************************************************************************************
* Macro definitions
*********************************************************************************************************************/
#define BOARD_RZG2UL_SMARC
/**********************************************************************************************************************
* Typedef definitions
*********************************************************************************************************************/
/**********************************************************************************************************************
* Exported global variables
*********************************************************************************************************************/
/**********************************************************************************************************************
* Exported global functions (to be accessed by other files)
*********************************************************************************************************************/
/** @} (end defgroup BOARD_RZG2UL_SMARC) */
#endif /* BOARD_H */

View File

@ -0,0 +1,68 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : board_init.c
* Version : 1.00
* Description : board_init source code
*********************************************************************************************************************/
/******************************************************************************************************************//**
* @addtogroup BOARD_RZG2UL_SMARC
*
* @{
*********************************************************************************************************************/
/**********************************************************************************************************************
* Includes <System Includes> , "Project Includes"
*********************************************************************************************************************/
#include "bsp_api.h"
#if defined(BOARD_RZG2UL_SMARC)
/**********************************************************************************************************************
* Macro definitions
*********************************************************************************************************************/
/**********************************************************************************************************************
* Typedef definitions
*********************************************************************************************************************/
/**********************************************************************************************************************
* Exported global variables (to be accessed by other files)
*********************************************************************************************************************/
/**********************************************************************************************************************
* Private global variables and functions
*********************************************************************************************************************/
/******************************************************************************************************************//**
* @brief Performs any initialization specific to this BSP.
*
* @param[in] p_args Pointer to arguments of the user's choice.
*********************************************************************************************************************/
void bsp_init (void * p_args)
{
FSP_PARAMETER_NOT_USED(p_args);
}
#endif /* BOARD_RZG2UL_SMARC */
/** @} (end addtogroup BOARD_RZG2UL_SMARC) */

View File

@ -0,0 +1,69 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : board_init.h
* Version : 1.00
* Description : board_init header
*********************************************************************************************************************/
/******************************************************************************************************************//**
* @addtogroup BOARD_RZG2UL_SMARC
* @brief Board specific code for the RZG2UL-SMARC Board
*
* This include file is specific to the RZG2UL-SMARC board.
*
* @{
*********************************************************************************************************************/
#ifndef BOARD_INIT_H
#define BOARD_INIT_H
/** Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
// FSP_HEADER
/**********************************************************************************************************************
* Macro definitions
*********************************************************************************************************************/
/**********************************************************************************************************************
* Typedef definitions
*********************************************************************************************************************/
/**********************************************************************************************************************
* Exported global variables
*********************************************************************************************************************/
extern int __HeapBase;
extern int __HeapLimit;
#define HEAP_START (&__HeapBase)
#define HEAP_END (&__HeapLimit)
/**********************************************************************************************************************
* Exported global functions (to be accessed by other files)
*********************************************************************************************************************/
void bsp_init(void * p_args);
/** Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
// FSP_FOOTER
#endif /* BOARD_INIT_H */
/** @} (end addtogroup BOARD_RZG2UL_SMARC) */

View File

@ -0,0 +1,100 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef BSP_API_H
#define BSP_API_H
/***********************************************************************************************************************
* Includes <System Includes> , "Project Includes"
**********************************************************************************************************************/
/* FSP Common Includes. */
#include "../../inc/fsp_common_api.h"
/* Gets MCU configuration information. */
#include "bsp_cfg.h"
#if defined(__GNUC__) && !defined(__ARMCC_VERSION)
/* CMSIS-CORE currently generates 2 warnings when compiling with GCC. One in core_cmInstr.h and one in core_cm4_simd.h.
* We are not modifying these files so we will ignore these warnings temporarily. */
#pragma GCC diagnostic ignored "-Wconversion"
#pragma GCC diagnostic ignored "-Wsign-conversion"
#endif
/* Vector information for this project. This is generated by the tooling. */
#include "vector_data.h"
/* CMSIS-CORE Renesas Device Files. Must come after bsp_feature.h, which is included in bsp_cfg.h. */
#include "../../src/bsp/cmsis/Device/RENESAS/Include/renesas.h"
#include "../../src/bsp/cmsis/Device/RENESAS/Include/system.h"
#if defined(__GNUC__) && !defined(__ARMCC_VERSION)
/* Restore warning settings for 'conversion' and 'sign-conversion' to as specified on command line. */
#pragma GCC diagnostic pop
#endif
/* BSP Common Includes. */
#include "../../src/bsp/mcu/all/bsp_common.h"
/* BSP MCU Specific Includes. */
#include "../../src/bsp/mcu/all/bsp_irq.h"
#include "../../src/bsp/mcu/all/bsp_io.h"
#include "../../src/bsp/mcu/all/bsp_group_irq.h"
#include "../../src/bsp/mcu/all/bsp_clocks.h"
#include "../../src/bsp/mcu/all/bsp_module_stop.h"
#include "../../src/bsp/mcu/all/bsp_security.h"
/* Factory MCU information. */
#include "../../inc/fsp_features.h"
/* BSP Common Includes (Other than bsp_common.h) */
#include "../../src/bsp/mcu/all/bsp_delay.h"
#include "../../src/bsp/mcu/all/bsp_mcu_api.h"
/** Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
// FSP_HEADER
/***********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/***********************************************************************************************************************
* Exported global variables
**********************************************************************************************************************/
/***********************************************************************************************************************
* Exported global functions (to be accessed by other files)
**********************************************************************************************************************/
int fsp_main(void);
/*******************************************************************************************************************//**
* @addtogroup BSP_MCU
* @{
**********************************************************************************************************************/
fsp_err_t R_FSP_VersionGet(fsp_pack_version_t * const p_version);
/** @} (end addtogroup BSP_MCU) */
/** Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
// FSP_FOOTER
#endif

View File

@ -0,0 +1,217 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @ingroup RENESAS_INTERFACES
* @defgroup IOPORT_API I/O Port Interface
* @brief Interface for accessing I/O ports and configuring I/O functionality.
*
* @section IOPORT_API_SUMMARY Summary
* The IOPort shared interface provides the ability to access the IOPorts of a device at both bit and port level.
* Port and pin direction can be changed.
*
* IOPORT Interface description: @ref IOPORT
*
* @{
**********************************************************************************************************************/
#ifndef R_IOPORT_API_H
#define R_IOPORT_API_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
/* Common error codes and definitions. */
#include "bsp_api.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** IO port type used with ports */
typedef uint16_t ioport_size_t; ///< IO port size on this device
/** PFS writing enable/disable. */
typedef enum e_ioport_pwpr
{
IOPORT_PFS_WRITE_DISABLE = 0, ///< Disable PFS write access
IOPORT_PFS_WRITE_ENABLE = 1 ///< Enable PFS write access
} ioport_pwpr_t;
/** Pin identifier and Pin Function Setting (PFS) value */
typedef struct st_ioport_pin_cfg
{
uint32_t pin_cfg; ///< Pin PFS configuration - Use ioport_cfg_options_t parameters to configure
bsp_io_port_pin_t pin; ///< Pin identifier
} ioport_pin_cfg_t;
/** Multiple pin configuration data for loading into each GPIO register by R_IOPORT_Init() */
typedef struct st_ioport_cfg
{
uint16_t number_of_pins; ///< Number of pins for which there is configuration data
ioport_pin_cfg_t const * p_pin_cfg_data; ///< Pin configuration data
const void * p_extend; ///< Pointer to hardware extend configuration
} ioport_cfg_t;
/** IOPORT control block. Allocate an instance specific control block to pass into the IOPORT API calls.
* @par Implemented as
* - ioport_instance_ctrl_t
*/
typedef void ioport_ctrl_t;
/** IOPort driver structure. IOPort functions implemented at the HAL layer will follow this API. */
typedef struct st_ioport_api
{
/** Initialize internal driver data and initial pin configurations. Called during startup. Do
* not call this API during runtime. Use @ref ioport_api_t::pinsCfg for runtime reconfiguration of
* multiple pins.
* @par Implemented as
* - @ref R_IOPORT_Open()
* @param[in] p_cfg Pointer to pin configuration data array.
*/
fsp_err_t (* open)(ioport_ctrl_t * const p_ctrl, const ioport_cfg_t * p_cfg);
/** Close the API.
* @par Implemented as
* - @ref R_IOPORT_Close()
*
* @param[in] p_ctrl Pointer to control structure.
**/
fsp_err_t (* close)(ioport_ctrl_t * const p_ctrl);
/** Configure multiple pins.
* @par Implemented as
* - @ref R_IOPORT_PinsCfg()
* @param[in] p_cfg Pointer to pin configuration data array.
*/
fsp_err_t (* pinsCfg)(ioport_ctrl_t * const p_ctrl, const ioport_cfg_t * p_cfg);
/** Configure settings for an individual pin.
* @par Implemented as
* - @ref R_IOPORT_PinCfg()
* @param[in] pin Pin to be read.
* @param[in] cfg Configuration options for the pin.
*/
fsp_err_t (* pinCfg)(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, uint32_t cfg);
/** Read the event input data of the specified pin and return the level.
* @par Implemented as
* - @ref R_IOPORT_PinEventInputRead()
* @param[in] pin Pin to be read.
* @param[in] p_pin_event Pointer to return the event data.
*/
fsp_err_t (* pinEventInputRead)(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t * p_pin_event);
/** Write pin event data.
* @par Implemented as
* - @ref R_IOPORT_PinEventOutputWrite()
* @param[in] pin Pin event data is to be written to.
* @param[in] pin_value Level to be written to pin output event.
*/
fsp_err_t (* pinEventOutputWrite)(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t pin_value);
/** Read level of a pin.
* @par Implemented as
* - @ref R_IOPORT_PinRead()
* @param[in] pin Pin to be read.
* @param[in] p_pin_value Pointer to return the pin level.
*/
fsp_err_t (* pinRead)(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t * p_pin_value);
/** Write specified level to a pin.
* @par Implemented as
* - @ref R_IOPORT_PinWrite()
* @param[in] pin Pin to be written to.
* @param[in] level State to be written to the pin.
*/
fsp_err_t (* pinWrite)(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t level);
/** Set the direction of one or more pins on a port.
* @par Implemented as
* - @ref R_IOPORT_PortDirectionSet()
* @param[in] port Port being configured.
* @param[in] direction_values Value controlling direction of pins on port
* (3 - output (input enable), 2 - output (input disable), 1 input, 0 - Hi-Z).
* @param[in] mask Mask controlling which pins on the port are to be configured.
*/
fsp_err_t (* portDirectionSet)(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t direction_values,
ioport_size_t mask);
/** Read captured event data for a port.
* @par Implemented as
* - @ref R_IOPORT_PortEventInputRead()
* @param[in] port Port to be read.
* @param[in] p_event_data Pointer to return the event data.
*/
fsp_err_t (* portEventInputRead)(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t * p_event_data);
/** Write event output data for a port.
* @par Implemented as
* - @ref R_IOPORT_PortEventOutputWrite()
* @param[in] port Port event data will be written to.
* @param[in] event_data Data to be written as event data to specified port.
* @param[in] mask_value Each bit set to 1 in the mask corresponds to that bit's value in event data.
* being written to port.
*/
fsp_err_t (* portEventOutputWrite)(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t event_data,
ioport_size_t mask_value);
/** Read states of pins on the specified port.
* @par Implemented as
* - @ref R_IOPORT_PortRead()
* @param[in] port Port to be read.
* @param[in] p_port_value Pointer to return the port value.
*/
fsp_err_t (* portRead)(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t * p_port_value);
/** Write to multiple pins on a port.
* @par Implemented as
* - @ref R_IOPORT_PortWrite()
* @param[in] port Port to be written to.
* @param[in] value Value to be written to the port.
* @param[in] mask Mask controlling which pins on the port are written to.
*/
fsp_err_t (* portWrite)(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t value, ioport_size_t mask);
} ioport_api_t;
/** This structure encompasses everything that is needed to use an instance of this interface. */
typedef struct st_ioport_instance
{
ioport_ctrl_t * p_ctrl; ///< Pointer to the control structure for this instance
ioport_cfg_t const * p_cfg; ///< Pointer to the configuration structure for this instance
ioport_api_t const * p_api; ///< Pointer to the API structure for this instance
} ioport_instance_t;
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif
/*******************************************************************************************************************//**
* @} (end defgroup IOPORT_API)
**********************************************************************************************************************/

View File

@ -0,0 +1,161 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @ingroup RENESAS_INTERFACES
* @defgroup MHU_API MHU Interface (for secure and non secure channels)
* @brief Interface for Message Handling Unit
*
* @section MHU_API_SUMMARY Summary
* The Message Handling Unit interface provides a common API for MHU HAL drivers.
* The Message Handling Unit interface supports:
* - Message communication between Cortex-A55 and Cortex-M33.
* - 32-bit data can be communicated between CPUs via shared memory.
*
* Implemented by:
* - @ref MHU_S
* - @ref MHU_NS
*
* @{
**********************************************************************************************************************/
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
/* Register definitions, common services and error codes. */
#include "bsp_api.h"
#ifndef R_MHU_API_H
#define R_MHU_API_H
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
typedef enum e_mhu_send_type
{
MHU_SEND_TYPE_MSG = 0, ///< Channel for sending "message" and receiving "response".
MHU_SEND_TYPE_RSP, ///< Channel for sending "response" and receiving "message".
} mhu_send_type_t;
/** MHU callback parameter definition */
typedef struct st_mhu_callback_args
{
/** Placeholder for user data. Set in @ref mhu_api_t::open function in @ref mhu_cfg_t. */
void const * p_context;
uint32_t channel; ///< Channel where the receive interrupt occurred.
uint32_t msg; ///< 32-bit received data.
} mhu_callback_args_t;
/** MHU configuration block */
typedef struct st_mhu_cfg
{
/** Generic configuration */
uint32_t channel; ///< Identifier recognizable by implementation
uint8_t rx_ipl; ///< Receive interrupt priority
IRQn_Type rx_irq; ///< Receive interrupt ID
/** Parameters to control software behavior */
void (* p_callback)(mhu_callback_args_t * p_args); ///< Pointer to callback function
void const * p_shared_memory; ///< Pointer to 64-bit send/receive data buffer.
/** Placeholder for user data. Passed to the user callback in @ref mhu_callback_args_t. */
void const * p_context;
} mhu_cfg_t;
/** MHU control block. Allocate an instance specific control block to pass into the MHU API calls.
* @par Implemented as
* - mhu_instance_ctrl_t
*/
typedef void mhu_ctrl_t;
/** Interface definition for MHU */
typedef struct st_mhu_api
{
/** Opens the MHU driver and initializes the hardware.
* @par Implemented as
* - @ref R_MHU_S_Open()
* - @ref R_MHU_NS_Open()
*
* @param[in] p_ctrl Pointer to control block. Must be declared by user. Elements are set here.
* @param[in] p_cfg Pointer to configuration structure.
*/
fsp_err_t (* open)(mhu_ctrl_t * const p_ctrl, mhu_cfg_t const * const p_cfg);
/** Performs a send operation on an MHU device.
* @par Implemented as
* - @ref R_MHU_S_MsgSend()
* - @ref R_MHU_NS_MsgSend()
*
* @param[in] p_ctrl Pointer to control block set in mhu_api_t::open call.
* @param[in] msg 32bit send data.
*/
fsp_err_t (* msgSend)(mhu_ctrl_t * const p_ctrl, uint32_t const msg);
/**
* Specify callback function and optional context pointer and working memory pointer.
* @par Implemented as
* - @ref R_MHU_S_CallbackSet()
* - @ref R_MHU_NS_CallbackSet()
*
* @param[in] p_ctrl Control block set in @ref mhu_api_t::open call for this channel.
* @param[in] p_callback Callback function to register
* @param[in] p_context Pointer to send to callback function
* @param[in] p_callback_memory Pointer to volatile memory where callback structure can be allocated.
* Callback arguments allocated here are only valid during the callback.
*/
fsp_err_t (* callbackSet)(mhu_ctrl_t * const p_api_ctrl, void (* p_callback) (mhu_callback_args_t *),
void const * const p_context, mhu_callback_args_t * const p_callback_memory);
/** Closes the driver and releases the MHU device.
* @par Implemented as
* - @ref R_MHU_S_Close()
* - @ref R_MHU_NS_Close()
*
* @param[in] p_ctrl Pointer to control block set in mhu_api_t::open call.
*/
fsp_err_t (* close)(mhu_ctrl_t * const p_ctrl);
} mhu_api_t;
/** This structure encompasses everything that is needed to use an instance of this interface. */
typedef struct st_mhu_instance
{
mhu_ctrl_t * p_ctrl; ///< Pointer to the control structure for this instance
mhu_cfg_t const * p_cfg; ///< Pointer to the configuration structure for this instance
mhu_api_t const * p_api; ///< Pointer to the API structure for this instance
} mhu_instance_t;
/******************************************************************************************************************//**
* @} (end addtogroup MHU_API)
*********************************************************************************************************************/
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif /* R_MHU_API_H */

View File

@ -0,0 +1,351 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef R_TIMER_API_H
#define R_TIMER_API_H
/*******************************************************************************************************************//**
* @defgroup TIMER_API Timer Interface
* @ingroup RENESAS_INTERFACES
* @brief Interface for timer functions.
*
* @section TIMER_API_SUMMARY Summary
* The general timer interface provides standard timer functionality including periodic mode, one-shot mode, PWM output,
* and free-running timer mode. After each timer cycle (overflow or underflow), an interrupt can be triggered.
*
* If an instance supports output compare mode, it is provided in the extension configuration
* timer_on_<instance>_cfg_t defined in r_<instance>.h.
*
* Implemented by:
* - @ref GPT
* - @ref GTM
* - @ref MTU3
*
* @{
**********************************************************************************************************************/
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
/* Includes board and MCU related header files. */
#include "bsp_api.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** Events that can trigger a callback function */
typedef enum e_timer_event
{
TIMER_EVENT_CYCLE_END, ///< Requested timer delay has expired or timer has wrapped around
TIMER_EVENT_CREST = TIMER_EVENT_CYCLE_END, ///< Timer crest event (counter is at a maximum, triangle-wave PWM only)
TIMER_EVENT_CAPTURE_A, ///< A capture has occurred on signal A
TIMER_EVENT_CAPTURE_B, ///< A capture has occurred on signal B
TIMER_EVENT_TROUGH, ///< Timer trough event (counter is 0, triangle-wave PWM only
TIMER_EVENT_OUTPUT_COMPARE_0, ///< An output has occurred on signal 0
TIMER_EVENT_OUTPUT_COMPARE_1, ///< An output has occurred on signal 1
TIMER_EVENT_DEAD_TIME, ///< Dead time event
TIMER_EVENT_CAPTURE_U, ///< A capture has occurred on signal U
TIMER_EVENT_CAPTURE_V, ///< A capture has occurred on signal V
TIMER_EVENT_CAPTURE_W, ///< A capture has occurred on signal W
} timer_event_t;
/** Timer variant types. */
typedef enum e_timer_variant
{
TIMER_VARIANT_32_BIT, ///< 32-bit timer
TIMER_VARIANT_16_BIT ///< 16-bit timer
} timer_variant_t;
/** Callback function parameter data */
typedef struct st_timer_callback_args
{
/** Placeholder for user data. Set in @ref timer_api_t::open function in @ref timer_cfg_t. */
void const * p_context;
timer_event_t event; ///< The event can be used to identify what caused the callback.
/** Most recent capture, only valid if event is TIMER_EVENT_CAPTURE_A or TIMER_EVENT_CAPTURE_B. */
uint32_t capture;
} timer_callback_args_t;
/** Timer control block. Allocate an instance specific control block to pass into the timer API calls.
* @par Implemented as
* - gpt_instance_ctrl_t
* - gtm_instance_ctrl_t
* - mtu3_instance_ctrl_t
*/
typedef void timer_ctrl_t;
/** Possible status values returned by @ref timer_api_t::statusGet. */
typedef enum e_timer_state
{
TIMER_STATE_STOPPED = 0, ///< Timer is stopped
TIMER_STATE_COUNTING = 1, ///< Timer is running
} timer_state_t;
/** Timer operational modes */
typedef enum e_timer_mode
{
TIMER_MODE_PERIODIC, ///< Timer restarts after period elapses.
TIMER_MODE_ONE_SHOT, ///< Timer stops after period elapses.
TIMER_MODE_PWM, ///< Timer generates saw-wave PWM output.
TIMER_MODE_ONE_SHOT_PULSE, ///< Saw-wave one-shot pulse mode (fixed buffer operation).
TIMER_MODE_TRIANGLE_WAVE_SYMMETRIC_PWM = 4U, ///< Timer generates symmetric triangle-wave PWM output.
TIMER_MODE_TRIANGLE_WAVE_ASYMMETRIC_PWM = 5U, ///< Timer generates asymmetric triangle-wave PWM output.
/**
* Timer generates Asymmetric Triangle-wave PWM output. In PWM mode 3, the duty cycle does
* not need to be updated at each tough/crest interrupt. Instead, the trough and crest duty cycle values can be
* set once and only need to be updated when the application needs to change the duty cycle.
*/
TIMER_MODE_TRIANGLE_WAVE_ASYMMETRIC_PWM_MODE3 = 6U,
} timer_mode_t;
/** Direction of timer count */
typedef enum e_timer_direction
{
TIMER_DIRECTION_DOWN = 0, ///< Timer count goes up
TIMER_DIRECTION_UP = 1 ///< Timer count goes down
} timer_direction_t;
/** Clock source divisors */
typedef enum e_timer_source_div
{
TIMER_SOURCE_DIV_1 = 0, ///< Timer clock source divided by 1
TIMER_SOURCE_DIV_2 = 1, ///< Timer clock source divided by 2
TIMER_SOURCE_DIV_4 = 2, ///< Timer clock source divided by 4
TIMER_SOURCE_DIV_8 = 3, ///< Timer clock source divided by 8
TIMER_SOURCE_DIV_16 = 4, ///< Timer clock source divided by 16
TIMER_SOURCE_DIV_32 = 5, ///< Timer clock source divided by 32
TIMER_SOURCE_DIV_64 = 6, ///< Timer clock source divided by 64
TIMER_SOURCE_DIV_128 = 7, ///< Timer clock source divided by 128
TIMER_SOURCE_DIV_256 = 8, ///< Timer clock source divided by 256
TIMER_SOURCE_DIV_512 = 9, ///< Timer clock source divided by 512
TIMER_SOURCE_DIV_1024 = 10, ///< Timer clock source divided by 1024
} timer_source_div_t;
/** Timer information structure to store various information for a timer resource */
typedef struct st_timer_info
{
timer_direction_t count_direction; ///< Clock counting direction of the timer.
uint32_t clock_frequency; ///< Clock frequency of the timer counter.
/** Period in raw timer counts.
* @note For triangle wave PWM modes, the full period is double this value.
*/
uint32_t period_counts;
} timer_info_t;
/** Current timer status. */
typedef struct st_timer_status
{
uint32_t counter; ///< Current counter value
timer_state_t state; ///< Current timer state (running or stopped)
} timer_status_t;
/** User configuration structure, used in open function */
typedef struct st_timer_cfg
{
timer_mode_t mode; ///< Select enumerated value from @ref timer_mode_t
/* Period in raw timer counts.
* @note For triangle wave PWM modes, enter the period of half the triangle wave, or half the desired period.
*/
uint32_t period_counts; ///< Period in raw timer counts
timer_source_div_t source_div; ///< Source clock divider
uint32_t duty_cycle_counts; ///< Duty cycle in counts
/** Select a channel corresponding to the channel number of the hardware. */
uint8_t channel;
uint8_t cycle_end_ipl; ///< Cycle end interrupt priority
IRQn_Type cycle_end_irq; ///< Cycle end interrupt
/** Callback provided when a timer ISR occurs. Set to NULL for no CPU interrupt. */
void (* p_callback)(timer_callback_args_t * p_args);
/** Placeholder for user data. Passed to the user callback in @ref timer_callback_args_t. */
void const * p_context;
void const * p_extend; ///< Extension parameter for hardware specific settings.
} timer_cfg_t;
/** Timer API structure. General timer functions implemented at the HAL layer follow this API. */
typedef struct st_timer_api
{
/** Initial configuration.
* @par Implemented as
* - @ref R_GPT_Open()
* - @ref R_GTM_Open()
* - @ref R_MTU3_Open()
*
* @param[in] p_ctrl Pointer to control block. Must be declared by user. Elements set here.
* @param[in] p_cfg Pointer to configuration structure. All elements of this structure must be set by user.
*/
fsp_err_t (* open)(timer_ctrl_t * const p_ctrl, timer_cfg_t const * const p_cfg);
/** Start the counter.
* @par Implemented as
* - @ref R_GPT_Start()
* - @ref R_GTM_Start()
* - @ref R_MTU3_Start()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
*/
fsp_err_t (* start)(timer_ctrl_t * const p_ctrl);
/** Stop the counter.
* @par Implemented as
* - @ref R_GPT_Stop()
* - @ref R_GTM_Stop()
* - @ref R_MTU3_Stop()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
*/
fsp_err_t (* stop)(timer_ctrl_t * const p_ctrl);
/** Reset the counter to the initial value.
* @par Implemented as
* - @ref R_GPT_Reset()
* - @ref R_GTM_Reset()
* - @ref R_MTU3_Reset()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
*/
fsp_err_t (* reset)(timer_ctrl_t * const p_ctrl);
/** Enables input capture.
* @par Implemented as
* - @ref R_GPT_Enable()
* - @ref R_GTM_Enable()
* - @ref R_MTU3_Enable()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
*/
fsp_err_t (* enable)(timer_ctrl_t * const p_ctrl);
/** Disables input capture.
* @par Implemented as
* - @ref R_GPT_Disable()
* - @ref R_GTM_Disable()
* - @ref R_MTU3_Disable()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
*/
fsp_err_t (* disable)(timer_ctrl_t * const p_ctrl);
/** Set the time until the timer expires. See implementation for details of period update timing.
*
* @par Implemented as
* - @ref R_GPT_PeriodSet()
* - @ref R_GTM_PeriodSet()
* - @ref R_MTU3_PeriodSet()
*
* @note Timer expiration may or may not generate a CPU interrupt based on how the timer is configured in
* @ref timer_api_t::open.
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
* @param[in] p_period Time until timer should expire.
*/
fsp_err_t (* periodSet)(timer_ctrl_t * const p_ctrl, uint32_t const period);
/** Sets the number of counts for the pin level to be high. If the timer is counting, the updated duty cycle is
* reflected after the next timer expiration.
*
* @par Implemented as
* - @ref R_GPT_DutyCycleSet()
* - @ref R_GTM_DutyCycleSet()
* - @ref R_MTU3_DutyCycleSet()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
* @param[in] duty_cycle_counts Time until duty cycle should expire.
* @param[in] pin Which output pin to update. See implementation for details.
*/
fsp_err_t (* dutyCycleSet)(timer_ctrl_t * const p_ctrl, uint32_t const duty_cycle_counts, uint32_t const pin);
/** Stores timer information in p_info.
* @par Implemented as
* - @ref R_GPT_InfoGet()
* - @ref R_GTM_InfoGet()
* - @ref R_MTU3_InfoGet()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
* @param[out] p_info Collection of information for this timer.
*/
fsp_err_t (* infoGet)(timer_ctrl_t * const p_ctrl, timer_info_t * const p_info);
/** Get the current counter value and timer state and store it in p_status.
* @par Implemented as
* - @ref R_GPT_StatusGet()
* - @ref R_GTM_StatusGet()
* - @ref R_MTU3_StatusGet()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
* @param[out] p_status Current status of this timer.
*/
fsp_err_t (* statusGet)(timer_ctrl_t * const p_ctrl, timer_status_t * const p_status);
/** Specify callback function and optional context pointer and working memory pointer.
* @par Implemented as
* - @ref R_GPT_CallbackSet()
* - @ref R_GTM_CallbackSet()
* - @ref R_MTU3_CallbackSet()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
* @param[in] p_callback Callback function to register
* @param[in] p_context Pointer to send to callback function
* @param[in] p_working_memory Pointer to volatile memory where callback structure can be allocated.
* Callback arguments allocated here are only valid during the callback.
*/
fsp_err_t (* callbackSet)(timer_ctrl_t * const p_api_ctrl, void (* p_callback)(timer_callback_args_t *),
void const * const p_context, timer_callback_args_t * const p_callback_memory);
/** Allows driver to be reconfigured and may reduce power consumption.
* @par Implemented as
* - @ref R_GPT_Close()
* - @ref R_GTM_Close()
* - @ref R_MTU3_Close()
*
* @param[in] p_ctrl Control block set in @ref timer_api_t::open call for this timer.
*/
fsp_err_t (* close)(timer_ctrl_t * const p_ctrl);
} timer_api_t;
/** This structure encompasses everything that is needed to use an instance of this interface. */
typedef struct st_timer_instance
{
timer_ctrl_t * p_ctrl; ///< Pointer to the control structure for this instance
timer_cfg_t const * p_cfg; ///< Pointer to the configuration structure for this instance
timer_api_t const * p_api; ///< Pointer to the API structure for this instance
} timer_instance_t;
/*******************************************************************************************************************//**
* @} (end defgroup TIMER_API)
**********************************************************************************************************************/
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif

View File

@ -0,0 +1,406 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @ingroup RENESAS_INTERFACES
* @defgroup TRANSFER_API Transfer Interface
*
* @brief Interface for data transfer functions.
*
* @section TRANSFER_API_SUMMARY Summary
* The transfer interface supports background data transfer (no CPU intervention).
*
* Implemented by:
* - @ref DMAC_B
*
* @{
**********************************************************************************************************************/
#ifndef R_TRANSFER_API_H
#define R_TRANSFER_API_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
/* Common error codes and definitions. */
#include "bsp_api.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
#define TRANSFER_SETTINGS_MODE_BITS (30U)
#define TRANSFER_SETTINGS_SIZE_BITS (28U)
#define TRANSFER_SETTINGS_SRC_ADDR_BITS (26U)
#define TRANSFER_SETTINGS_CHAIN_MODE_BITS (22U)
#define TRANSFER_SETTINGS_IRQ_BITS (21U)
#define TRANSFER_SETTINGS_REPEAT_AREA_BITS (20U)
#define TRANSFER_SETTINGS_DEST_ADDR_BITS (18U)
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** Transfer control block. Allocate an instance specific control block to pass into the transfer API calls.
* @par Implemented as
* - dmac_b_instance_ctrl_t
*/
typedef void transfer_ctrl_t;
#ifndef BSP_OVERRIDE_TRANSFER_MODE_T
/** Transfer mode describes what will happen when a transfer request occurs. */
typedef enum e_transfer_mode
{
/** In normal mode, each transfer request causes a transfer of @ref transfer_size_t from the source pointer to
* the destination pointer. The transfer length is decremented and the source and address pointers are
* updated according to @ref transfer_addr_mode_t. After the transfer length reaches 0, transfer requests
* will not cause any further transfers. */
TRANSFER_MODE_NORMAL = 0,
/** Repeat mode is like normal mode, except that when the transfer length reaches 0, the pointer to the
* repeat area and the transfer length will be reset to their initial values. If DMAC is used, the
* transfer repeats only transfer_info_t::num_blocks times. After the transfer repeats
* transfer_info_t::num_blocks times, transfer requests will not cause any further transfers. If DTC is
* used, the transfer repeats continuously (no limit to the number of repeat transfers). */
TRANSFER_MODE_REPEAT = 1,
/** In block mode, each transfer request causes transfer_info_t::length transfers of @ref transfer_size_t.
* After each individual transfer, the source and destination pointers are updated according to
* @ref transfer_addr_mode_t. After the block transfer is complete, transfer_info_t::num_blocks is
* decremented. After the transfer_info_t::num_blocks reaches 0, transfer requests will not cause any
* further transfers. */
TRANSFER_MODE_BLOCK = 2,
/** In addition to block mode features, repeat-block mode supports a ring buffer of blocks and offsets
* within a block (to split blocks into arrays of their first data, second data, etc.) */
TRANSFER_MODE_REPEAT_BLOCK = 3
} transfer_mode_t;
#endif
#ifndef BSP_OVERRIDE_TRANSFER_SIZE_T
/** Transfer size specifies the size of each individual transfer.
* Total transfer length = transfer_size_t * transfer_length_t
*/
typedef enum e_transfer_size
{
TRANSFER_SIZE_1_BYTE = 0, ///< Each transfer transfers a 8-bit value
TRANSFER_SIZE_2_BYTE = 1, ///< Each transfer transfers a 16-bit value
TRANSFER_SIZE_4_BYTE = 2 ///< Each transfer transfers a 32-bit value
} transfer_size_t;
#endif
#ifndef BSP_OVERRIDE_TRANSFER_ADDR_MODE_T
/** Address mode specifies whether to modify (increment or decrement) pointer after each transfer. */
typedef enum e_transfer_addr_mode
{
/** Address pointer remains fixed after each transfer. */
TRANSFER_ADDR_MODE_FIXED = 0,
/** Offset is added to the address pointer after each transfer. */
TRANSFER_ADDR_MODE_OFFSET = 1,
/** Address pointer is incremented by associated @ref transfer_size_t after each transfer. */
TRANSFER_ADDR_MODE_INCREMENTED = 2,
/** Address pointer is decremented by associated @ref transfer_size_t after each transfer. */
TRANSFER_ADDR_MODE_DECREMENTED = 3
} transfer_addr_mode_t;
#endif
#ifndef BSP_OVERRIDE_TRANSFER_REPEAT_AREA_T
/** Repeat area options (source or destination). In @ref TRANSFER_MODE_REPEAT, the selected pointer returns to its
* original value after transfer_info_t::length transfers. In @ref TRANSFER_MODE_BLOCK and @ref TRANSFER_MODE_REPEAT_BLOCK,
* the selected pointer returns to its original value after each transfer. */
typedef enum e_transfer_repeat_area
{
/** Destination area repeated in @ref TRANSFER_MODE_REPEAT or @ref TRANSFER_MODE_BLOCK or @ref TRANSFER_MODE_REPEAT_BLOCK. */
TRANSFER_REPEAT_AREA_DESTINATION = 0,
/** Source area repeated in @ref TRANSFER_MODE_REPEAT or @ref TRANSFER_MODE_BLOCK or @ref TRANSFER_MODE_REPEAT_BLOCK. */
TRANSFER_REPEAT_AREA_SOURCE = 1
} transfer_repeat_area_t;
#endif
#ifndef BSP_OVERRIDE_TRANSFER_CHAIN_MODE_T
/** Chain transfer mode options.
* @note Only applies for DTC. */
typedef enum e_transfer_chain_mode
{
/** Chain mode not used. */
TRANSFER_CHAIN_MODE_DISABLED = 0,
/** Switch to next transfer after a single transfer from this @ref transfer_info_t. */
TRANSFER_CHAIN_MODE_EACH = 2,
/** Complete the entire transfer defined in this @ref transfer_info_t before chaining to next transfer. */
TRANSFER_CHAIN_MODE_END = 3
} transfer_chain_mode_t;
#endif
#ifndef BSP_OVERRIDE_TRANSFER_IRQ_T
/** Interrupt options. */
typedef enum e_transfer_irq
{
/** Interrupt occurs only after last transfer. If this transfer is chained to a subsequent transfer,
* the interrupt will occur only after subsequent chained transfer(s) are complete.
* @warning DTC triggers the interrupt of the activation source. Choosing TRANSFER_IRQ_END with DTC will
* prevent activation source interrupts until the transfer is complete. */
TRANSFER_IRQ_END = 0,
/** Interrupt occurs after each transfer.
* @note Not available in all HAL drivers. See HAL driver for details. */
TRANSFER_IRQ_EACH = 1
} transfer_irq_t;
#endif
/** Driver specific information. */
typedef struct st_transfer_properties
{
uint32_t block_count_max; ///< Maximum number of blocks
uint32_t block_count_remaining; ///< Number of blocks remaining
uint32_t transfer_length_max; ///< Maximum number of transfers
uint32_t transfer_length_remaining; ///< Number of transfers remaining
} transfer_properties_t;
#ifndef BSP_OVERRIDE_TRANSFER_INFO_T
/** This structure specifies the properties of the transfer.
* @warning When using DTC, this structure corresponds to the descriptor block registers required by the DTC.
* The following components may be modified by the driver: p_src, p_dest, num_blocks, and length.
* @warning When using DTC, do NOT reuse this structure to configure multiple transfers. Each transfer must
* have a unique transfer_info_t.
* @warning When using DTC, this structure must not be allocated in a temporary location. Any instance of this
* structure must remain in scope until the transfer it is used for is closed.
* @note When using DTC, consider placing instances of this structure in a protected section of memory. */
typedef struct st_transfer_info
{
union
{
struct
{
uint32_t : 16;
uint32_t : 2;
/** Select what happens to destination pointer after each transfer. */
transfer_addr_mode_t dest_addr_mode : 2;
/** Select to repeat source or destination area, unused in @ref TRANSFER_MODE_NORMAL. */
transfer_repeat_area_t repeat_area : 1;
/** Select if interrupts should occur after each individual transfer or after the completion of all planned
* transfers. */
transfer_irq_t irq : 1;
/** Select when the chain transfer ends. */
transfer_chain_mode_t chain_mode : 2;
uint32_t : 2;
/** Select what happens to source pointer after each transfer. */
transfer_addr_mode_t src_addr_mode : 2;
/** Select number of bytes to transfer at once. @see transfer_info_t::length. */
transfer_size_t size : 2;
/** Select mode from @ref transfer_mode_t. */
transfer_mode_t mode : 2;
} transfer_settings_word_b;
uint32_t transfer_settings_word;
};
void const * volatile p_src; ///< Source pointer
void * volatile p_dest; ///< Destination pointer
/** Number of blocks to transfer when using @ref TRANSFER_MODE_BLOCK (both DTC an DMAC) or
* @ref TRANSFER_MODE_REPEAT (DMAC only) or
* @ref TRANSFER_MODE_REPEAT_BLOCK (DMAC only), unused in other modes. */
volatile uint16_t num_blocks;
/** Length of each transfer. Range limited for @ref TRANSFER_MODE_BLOCK, @ref TRANSFER_MODE_REPEAT,
* and @ref TRANSFER_MODE_REPEAT_BLOCK
* see HAL driver for details. */
volatile uint16_t length;
} transfer_info_t;
#endif
/** Driver configuration set in @ref transfer_api_t::open. All elements except p_extend are required and must be
* initialized. */
typedef struct st_transfer_cfg
{
/** Pointer to transfer configuration options. If using chain transfer (DTC only), this can be a pointer to
* an array of chained transfers that will be completed in order. */
transfer_info_t * p_info;
void const * p_extend; ///< Extension parameter for hardware specific settings.
} transfer_cfg_t;
/** Select whether to start single or repeated transfer with software start. */
typedef enum e_transfer_start_mode
{
TRANSFER_START_MODE_SINGLE = 0, ///< Software start triggers single transfer.
TRANSFER_START_MODE_REPEAT = 1 ///< Software start transfer continues until transfer is complete.
} transfer_start_mode_t;
/** Transfer functions implemented at the HAL layer will follow this API. */
typedef struct st_transfer_api
{
/** Initial configuration.
* @par Implemented as
* - @ref R_DMAC_B_Open()
*
* @param[in,out] p_ctrl Pointer to control block. Must be declared by user. Elements set here.
* @param[in] p_cfg Pointer to configuration structure. All elements of this structure
* must be set by user.
*/
fsp_err_t (* open)(transfer_ctrl_t * const p_ctrl, transfer_cfg_t const * const p_cfg);
/** Reconfigure the transfer.
* Enable the transfer if p_info is valid.
* @par Implemented as
* - @ref R_DMAC_B_Reconfigure()
*
* @param[in,out] p_ctrl Pointer to control block. Must be declared by user. Elements set here.
* @param[in] p_info Pointer to a new transfer info structure.
*/
fsp_err_t (* reconfigure)(transfer_ctrl_t * const p_ctrl, transfer_info_t * p_info);
/** Reset source address pointer, destination address pointer, and/or length, keeping all other settings the same.
* Enable the transfer if p_src, p_dest, and length are valid.
* @par Implemented as
* - @ref R_DMAC_B_Reset()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
* @param[in] p_src Pointer to source. Set to NULL if source pointer should not change.
* @param[in] p_dest Pointer to destination. Set to NULL if destination pointer should not change.
* @param[in] num_transfers Transfer length in normal mode or number of blocks in block mode. In DMAC only,
* resets number of repeats (initially stored in transfer_info_t::num_blocks) in
* repeat mode. Not used in repeat mode for DTC.
*/
fsp_err_t (* reset)(transfer_ctrl_t * const p_ctrl, void const * p_src, void * p_dest,
uint16_t const num_transfers);
/** Enable transfer. Transfers occur after the activation source event (or when
* @ref transfer_api_t::softwareStart is called if no peripheral event is chosen as activation source).
* @par Implemented as
* - @ref R_DMAC_B_Enable()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
*/
fsp_err_t (* enable)(transfer_ctrl_t * const p_ctrl);
/** Disable transfer. Transfers do not occur after the activation source event (or when
* @ref transfer_api_t::softwareStart is called if no peripheral event is chosen as the DMAC activation source).
* @note If a transfer is in progress, it will be completed. Subsequent transfer requests do not cause a
* transfer.
* @par Implemented as
* - @ref R_DMAC_B_Disable()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
*/
fsp_err_t (* disable)(transfer_ctrl_t * const p_ctrl);
/** Start transfer in software.
* @warning Only works if no peripheral event is chosen as the DMAC activation source.
* @note Not supported for DTC.
* @par Implemented as
* - @ref R_DMAC_B_SoftwareStart()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
* @param[in] mode Select mode from @ref transfer_start_mode_t.
*/
fsp_err_t (* softwareStart)(transfer_ctrl_t * const p_ctrl, transfer_start_mode_t mode);
/** Stop transfer in software. The transfer will stop after completion of the current transfer.
* @note Not supported for DTC.
* @note Only applies for transfers started with TRANSFER_START_MODE_REPEAT.
* @warning Only works if no peripheral event is chosen as the DMAC activation source.
* @par Implemented as
* - @ref R_DMAC_B_SoftwareStop()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
*/
fsp_err_t (* softwareStop)(transfer_ctrl_t * const p_ctrl);
/** Provides information about this transfer.
* @par Implemented as
* - @ref R_DMAC_B_InfoGet()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
* @param[out] p_properties Driver specific information.
*/
fsp_err_t (* infoGet)(transfer_ctrl_t * const p_ctrl, transfer_properties_t * const p_properties);
/** Releases hardware lock. This allows a transfer to be reconfigured using @ref transfer_api_t::open.
* @par Implemented as
* - @ref R_DMAC_B_Close()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
*/
fsp_err_t (* close)(transfer_ctrl_t * const p_ctrl);
/** To update next transfer information without interruption during transfer.
* Allow further transfer continuation.
* @par Implemented as
* - @ref R_DMAC_B_Reload()
*
* @param[in] p_ctrl Control block set in @ref transfer_api_t::open call for this transfer.
* @param[in] p_src Pointer to source. Set to NULL if source pointer should not change.
* @param[in] p_dest Pointer to destination. Set to NULL if destination pointer should not change.
* @param[in] num_transfers Transfer length in normal mode or block mode.
*/
fsp_err_t (* reload)(transfer_ctrl_t * const p_ctrl, void const * p_src, void * p_dest,
uint32_t const num_transfers);
} transfer_api_t;
/** This structure encompasses everything that is needed to use an instance of this interface. */
typedef struct st_transfer_instance
{
transfer_ctrl_t * p_ctrl; ///< Pointer to the control structure for this instance
transfer_cfg_t const * p_cfg; ///< Pointer to the configuration structure for this instance
transfer_api_t const * p_api; ///< Pointer to the API structure for this instance
} transfer_instance_t;
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif
/*******************************************************************************************************************//**
* @} (end defgroup TRANSFER_API)
**********************************************************************************************************************/

View File

@ -0,0 +1,283 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @ingroup RENESAS_INTERFACES
* @defgroup UART_API UART Interface
* @brief Interface for UART communications.
*
* @section UART_INTERFACE_SUMMARY Summary
* The UART interface provides common APIs for UART HAL drivers. The UART interface supports the following features:
* - Full-duplex UART communication
* - Interrupt driven transmit/receive processing
* - Callback function with returned event code
* - Runtime baud-rate change
* - Hardware resource locking during a transaction
* - CTS/RTS hardware flow control support (with an associated IOPORT pin)
*
* Implemented by:
* - @ref SCIF_UART
*
* @{
**********************************************************************************************************************/
#ifndef R_UART_API_H
#define R_UART_API_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
/* Includes board and MCU related header files. */
#include "bsp_api.h"
#include "r_transfer_api.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** UART Event codes */
typedef enum e_sf_event
{
UART_EVENT_RX_COMPLETE = (1UL << 0), ///< Receive complete event
UART_EVENT_TX_COMPLETE = (1UL << 1), ///< Transmit complete event
UART_EVENT_RX_CHAR = (1UL << 2), ///< Character received
UART_EVENT_ERR_PARITY = (1UL << 3), ///< Parity error event
UART_EVENT_ERR_FRAMING = (1UL << 4), ///< Mode fault error event
UART_EVENT_ERR_OVERFLOW = (1UL << 5), ///< FIFO Overflow error event
UART_EVENT_BREAK_DETECT = (1UL << 6), ///< Break detect error event
UART_EVENT_TX_DATA_EMPTY = (1UL << 7), ///< Last byte is transmitting, ready for more data
} uart_event_t;
/** UART Data bit length definition */
typedef enum e_uart_data_bits
{
UART_DATA_BITS_9 = 0U, ///< Data bits 9-bit
UART_DATA_BITS_8 = 2U, ///< Data bits 8-bit
UART_DATA_BITS_7 = 3U, ///< Data bits 7-bit
} uart_data_bits_t;
/** UART Parity definition */
typedef enum e_uart_parity
{
UART_PARITY_OFF = 0U, ///< No parity
UART_PARITY_EVEN = 2U, ///< Even parity
UART_PARITY_ODD = 3U, ///< Odd parity
} uart_parity_t;
/** UART Stop bits definition */
typedef enum e_uart_stop_bits
{
UART_STOP_BITS_1 = 0U, ///< Stop bit 1-bit
UART_STOP_BITS_2 = 1U, ///< Stop bits 2-bit
} uart_stop_bits_t;
/** UART transaction definition */
typedef enum e_uart_dir
{
UART_DIR_RX_TX = 3U, ///< Both RX and TX
UART_DIR_RX = 1U, ///< Only RX
UART_DIR_TX = 2U, ///< Only TX
} uart_dir_t;
/** UART driver specific information */
typedef struct st_uart_info
{
/** Maximum bytes that can be written at this time. Only applies if uart_cfg_t::p_transfer_tx is not NULL. */
uint32_t write_bytes_max;
/** Maximum bytes that are available to read at one time. Only applies if uart_cfg_t::p_transfer_rx is not NULL. */
uint32_t read_bytes_max;
} uart_info_t;
/** UART Callback parameter definition */
typedef struct st_uart_callback_arg
{
uint32_t channel; ///< Device channel number
uart_event_t event; ///< Event code
/** Contains the next character received for the events UART_EVENT_RX_CHAR, UART_EVENT_ERR_PARITY,
* UART_EVENT_ERR_FRAMING, or UART_EVENT_ERR_OVERFLOW. Otherwise unused. */
uint32_t data;
void const * p_context; ///< Context provided to user during callback
} uart_callback_args_t;
/** UART Configuration */
typedef struct st_uart_cfg
{
/* UART generic configuration */
uint8_t channel; ///< Select a channel corresponding to the channel number of the hardware.
uart_data_bits_t data_bits; ///< Data bit length (8 or 7 or 9)
uart_parity_t parity; ///< Parity type (none or odd or even)
uart_stop_bits_t stop_bits; ///< Stop bit length (1 or 2)
uint8_t rxi_ipl; ///< Receive interrupt priority
IRQn_Type rxi_irq; ///< Receive interrupt IRQ number
uint8_t txi_ipl; ///< Transmit interrupt priority
IRQn_Type txi_irq; ///< Transmit interrupt IRQ number
uint8_t tei_ipl; ///< Transmit end interrupt priority
IRQn_Type tei_irq; ///< Transmit end interrupt IRQ number
uint8_t eri_ipl; ///< Error interrupt priority
IRQn_Type eri_irq; ///< Error interrupt IRQ number
/** Optional transfer instance used to receive multiple bytes without interrupts. Set to NULL if unused.
* If NULL, the number of bytes allowed in the read API is limited to one byte at a time. */
transfer_instance_t const * p_transfer_rx;
/** Optional transfer instance used to send multiple bytes without interrupts. Set to NULL if unused.
* If NULL, the number of bytes allowed in the write APIs is limited to one byte at a time. */
transfer_instance_t const * p_transfer_tx;
/* Configuration for UART Event processing */
void (* p_callback)(uart_callback_args_t * p_args); ///< Pointer to callback function
void const * p_context; ///< User defined context passed into callback function
/* Pointer to UART peripheral specific configuration */
void const * p_extend; ///< UART hardware dependent configuration
} uart_cfg_t;
/** UART control block. Allocate an instance specific control block to pass into the UART API calls.
* @par Implemented as
* - scif_uart_instance_ctrl_t
*/
typedef void uart_ctrl_t;
/** Shared Interface definition for UART */
typedef struct st_uart_api
{
/** Open UART device.
* @par Implemented as
* - @ref R_SCIF_UART_Open()
*
* @param[in,out] p_ctrl Pointer to the UART control block. Must be declared by user. Value set here.
* @param[in] uart_cfg_t Pointer to UART configuration structure. All elements of this structure must be set by
* user.
*/
fsp_err_t (* open)(uart_ctrl_t * const p_ctrl, uart_cfg_t const * const p_cfg);
/** Read from UART device. The read buffer is used until the read is complete. When a transfer is complete, the
* callback is called with event UART_EVENT_RX_COMPLETE. Bytes received outside an active transfer are received in
* the callback function with event UART_EVENT_RX_CHAR.
* The maximum transfer size is reported by infoGet().
* @par Implemented as
* - @ref R_SCIF_UART_Read()
*
* @param[in] p_ctrl Pointer to the UART control block for the channel.
* @param[in] p_dest Destination address to read data from.
* @param[in] bytes Read data length.
*/
fsp_err_t (* read)(uart_ctrl_t * const p_ctrl, uint8_t * const p_dest, uint32_t const bytes);
/** Write to UART device. The write buffer is used until write is complete. Do not overwrite write buffer
* contents until the write is finished. When the write is complete (all bytes are fully transmitted on the wire),
* the callback called with event UART_EVENT_TX_COMPLETE.
* The maximum transfer size is reported by infoGet().
* @par Implemented as
* - @ref R_SCIF_UART_Write()
*
* @param[in] p_ctrl Pointer to the UART control block.
* @param[in] p_src Source address to write data to.
* @param[in] bytes Write data length.
*/
fsp_err_t (* write)(uart_ctrl_t * const p_ctrl, uint8_t const * const p_src, uint32_t const bytes);
/** Change baud rate.
* @warning Calling this API aborts any in-progress transmission and disables reception until the new baud
* settings have been applied.
*
* @par Implemented as
* - @ref R_SCIF_UART_BaudSet()
*
* @param[in] p_ctrl Pointer to the UART control block.
* @param[in] p_baudrate_info Pointer to module specific information for configuring baud rate.
*/
fsp_err_t (* baudSet)(uart_ctrl_t * const p_ctrl, void const * const p_baudrate_info);
/** Get the driver specific information.
* @par Implemented as
* - @ref R_SCIF_UART_InfoGet()
*
* @param[in] p_ctrl Pointer to the UART control block.
* @param[in] baudrate Baud rate in bps.
*/
fsp_err_t (* infoGet)(uart_ctrl_t * const p_ctrl, uart_info_t * const p_info);
/**
* Abort ongoing transfer.
* @par Implemented as
* - @ref R_SCIF_UART_Abort()
*
* @param[in] p_ctrl Pointer to the UART control block.
* @param[in] communication_to_abort Type of abort request.
*/
fsp_err_t (* communicationAbort)(uart_ctrl_t * const p_ctrl, uart_dir_t communication_to_abort);
/**
* Specify callback function and optional context pointer and working memory pointer.
* @par Implemented as
* - R_SCIF_Uart_CallbackSet()
*
* @param[in] p_api_ctrl Pointer to the UART control block.
* @param[in] p_callback Callback function
* @param[in] p_context Pointer to send to callback function
* @param[in] p_working_memory Pointer to volatile memory where callback structure can be allocated.
* Callback arguments allocated here are only valid during the callback.
*/
fsp_err_t (* callbackSet)(uart_ctrl_t * const p_api_ctrl, void (* p_callback)(uart_callback_args_t *),
void const * const p_context, uart_callback_args_t * const p_callback_memory);
/** Close UART device.
* @par Implemented as
* - @ref R_SCIF_UART_Close()
*
* @param[in] p_ctrl Pointer to the UART control block.
*/
fsp_err_t (* close)(uart_ctrl_t * const p_ctrl);
/** Stop ongoing read and return the number of bytes remaining in the read.
* @par Implemented as
* - @ref R_SCIF_UART_ReadStop()
*
* @param[in] p_ctrl Pointer to the UART control block.
* @param[in,out] remaining_bytes Pointer to location to store remaining bytes for read.
*/
fsp_err_t (* readStop)(uart_ctrl_t * const p_ctrl, uint32_t * remaining_bytes);
} uart_api_t;
/** This structure encompasses everything that is needed to use an instance of this interface. */
typedef struct st_uart_instance
{
uart_ctrl_t * p_ctrl; ///< Pointer to the control structure for this instance
uart_cfg_t const * p_cfg; ///< Pointer to the configuration structure for this instance
uart_api_t const * p_api; ///< Pointer to the API structure for this instance
} uart_instance_t;
/** @} (end defgroup UART_API) */
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif

View File

@ -0,0 +1,359 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef FSP_COMMON_API_H
#define FSP_COMMON_API_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
#include <assert.h>
#include <stdint.h>
/* Includes FSP version macros. */
#include "fsp_version.h"
/*******************************************************************************************************************//**
* @ingroup RENESAS_COMMON
* @defgroup RENESAS_ERROR_CODES Common Error Codes
* All FSP modules share these common error codes.
* @{
**********************************************************************************************************************/
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/** This macro is used to suppress compiler messages about a parameter not being used in a function. The nice thing
* about using this implementation is that it does not take any extra RAM or ROM. */
#define FSP_PARAMETER_NOT_USED(p) (void) ((p))
/** Determine if a C++ compiler is being used.
* If so, ensure that standard C is used to process the API information. */
#if defined(__cplusplus)
#define FSP_CPP_HEADER extern "C" {
#define FSP_CPP_FOOTER }
#else
#define FSP_CPP_HEADER
#define FSP_CPP_FOOTER
#endif
/** FSP Header and Footer definitions */
#define FSP_HEADER FSP_CPP_HEADER
#define FSP_FOOTER FSP_CPP_FOOTER
/** Macro to be used when argument to function is ignored since function call is NSC and the parameter is statically
* defined on the Secure side. */
#define FSP_SECURE_ARGUMENT (NULL)
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** Common error codes */
typedef enum e_fsp_err
{
FSP_SUCCESS = 0,
FSP_ERR_ASSERTION = 1, ///< A critical assertion has failed
FSP_ERR_INVALID_POINTER = 2, ///< Pointer points to invalid memory location
FSP_ERR_INVALID_ARGUMENT = 3, ///< Invalid input parameter
FSP_ERR_INVALID_CHANNEL = 4, ///< Selected channel does not exist
FSP_ERR_INVALID_MODE = 5, ///< Unsupported or incorrect mode
FSP_ERR_UNSUPPORTED = 6, ///< Selected mode not supported by this API
FSP_ERR_NOT_OPEN = 7, ///< Requested channel is not configured or API not open
FSP_ERR_IN_USE = 8, ///< Channel/peripheral is running/busy
FSP_ERR_OUT_OF_MEMORY = 9, ///< Allocate more memory in the driver's cfg.h
FSP_ERR_HW_LOCKED = 10, ///< Hardware is locked
FSP_ERR_IRQ_BSP_DISABLED = 11, ///< IRQ not enabled in BSP
FSP_ERR_OVERFLOW = 12, ///< Hardware overflow
FSP_ERR_UNDERFLOW = 13, ///< Hardware underflow
FSP_ERR_ALREADY_OPEN = 14, ///< Requested channel is already open in a different configuration
FSP_ERR_APPROXIMATION = 15, ///< Could not set value to exact result
FSP_ERR_CLAMPED = 16, ///< Value had to be limited for some reason
FSP_ERR_INVALID_RATE = 17, ///< Selected rate could not be met
FSP_ERR_ABORTED = 18, ///< An operation was aborted
FSP_ERR_NOT_ENABLED = 19, ///< Requested operation is not enabled
FSP_ERR_TIMEOUT = 20, ///< Timeout error
FSP_ERR_INVALID_BLOCKS = 21, ///< Invalid number of blocks supplied
FSP_ERR_INVALID_ADDRESS = 22, ///< Invalid address supplied
FSP_ERR_INVALID_SIZE = 23, ///< Invalid size/length supplied for operation
FSP_ERR_WRITE_FAILED = 24, ///< Write operation failed
FSP_ERR_ERASE_FAILED = 25, ///< Erase operation failed
FSP_ERR_INVALID_CALL = 26, ///< Invalid function call is made
FSP_ERR_INVALID_HW_CONDITION = 27, ///< Detected hardware is in invalid condition
FSP_ERR_INVALID_FACTORY_FLASH = 28, ///< Factory flash is not available on this MCU
FSP_ERR_INVALID_STATE = 30, ///< API or command not valid in the current state
FSP_ERR_NOT_ERASED = 31, ///< Erase verification failed
FSP_ERR_SECTOR_RELEASE_FAILED = 32, ///< Sector release failed
FSP_ERR_NOT_INITIALIZED = 33, ///< Required initialization not complete
FSP_ERR_NOT_FOUND = 34, ///< The requested item could not be found
FSP_ERR_NO_CALLBACK_MEMORY = 35, ///< Non-secure callback memory not provided for non-secure callback
FSP_ERR_BUFFER_EMPTY = 36, ///< No data available in buffer
/* Start of RTOS only error codes */
FSP_ERR_INTERNAL = 100, ///< Internal error
FSP_ERR_WAIT_ABORTED = 101, ///< Wait aborted
/* Start of UART specific */
FSP_ERR_FRAMING = 200, ///< Framing error occurs
FSP_ERR_BREAK_DETECT = 201, ///< Break signal detects
FSP_ERR_PARITY = 202, ///< Parity error occurs
FSP_ERR_RXBUF_OVERFLOW = 203, ///< Receive queue overflow
FSP_ERR_QUEUE_UNAVAILABLE = 204, ///< Can't open s/w queue
FSP_ERR_INSUFFICIENT_SPACE = 205, ///< Not enough space in transmission circular buffer
FSP_ERR_INSUFFICIENT_DATA = 206, ///< Not enough data in receive circular buffer
/* Start of SPI specific */
FSP_ERR_TRANSFER_ABORTED = 300, ///< The data transfer was aborted.
FSP_ERR_MODE_FAULT = 301, ///< Mode fault error.
FSP_ERR_READ_OVERFLOW = 302, ///< Read overflow.
FSP_ERR_SPI_PARITY = 303, ///< Parity error.
FSP_ERR_OVERRUN = 304, ///< Overrun error.
/* Start of CGC Specific */
FSP_ERR_CLOCK_INACTIVE = 400, ///< Inactive clock specified as system clock.
FSP_ERR_CLOCK_ACTIVE = 401, ///< Active clock source cannot be modified without stopping first.
FSP_ERR_NOT_STABILIZED = 403, ///< Clock has not stabilized after its been turned on/off
FSP_ERR_PLL_SRC_INACTIVE = 404, ///< PLL initialization attempted when PLL source is turned off
FSP_ERR_OSC_STOP_DET_ENABLED = 405, ///< Illegal attempt to stop LOCO when Oscillation stop is enabled
FSP_ERR_OSC_STOP_DETECTED = 406, ///< The Oscillation stop detection status flag is set
FSP_ERR_OSC_STOP_CLOCK_ACTIVE = 407, ///< Attempt to clear Oscillation Stop Detect Status with PLL/MAIN_OSC active
FSP_ERR_CLKOUT_EXCEEDED = 408, ///< Output on target output clock pin exceeds maximum supported limit
FSP_ERR_USB_MODULE_ENABLED = 409, ///< USB clock configure request with USB Module enabled
FSP_ERR_HARDWARE_TIMEOUT = 410, ///< A register read or write timed out
FSP_ERR_LOW_VOLTAGE_MODE = 411, ///< Invalid clock setting attempted in low voltage mode
/* Start of FLASH Specific */
FSP_ERR_PE_FAILURE = 500, ///< Unable to enter Programming mode.
FSP_ERR_CMD_LOCKED = 501, ///< Peripheral in command locked state
FSP_ERR_FCLK = 502, ///< FCLK must be >= 4 MHz
FSP_ERR_INVALID_LINKED_ADDRESS = 503, ///< Function or data are linked at an invalid region of memory
FSP_ERR_BLANK_CHECK_FAILED = 504, ///< Blank check operation failed
/* Start of CAC Specific */
FSP_ERR_INVALID_CAC_REF_CLOCK = 600, ///< Measured clock rate < reference clock rate
/* Start of GLCD Specific */
FSP_ERR_CLOCK_GENERATION = 1000, ///< Clock cannot be specified as system clock
FSP_ERR_INVALID_TIMING_SETTING = 1001, ///< Invalid timing parameter
FSP_ERR_INVALID_LAYER_SETTING = 1002, ///< Invalid layer parameter
FSP_ERR_INVALID_ALIGNMENT = 1003, ///< Invalid memory alignment found
FSP_ERR_INVALID_GAMMA_SETTING = 1004, ///< Invalid gamma correction parameter
FSP_ERR_INVALID_LAYER_FORMAT = 1005, ///< Invalid color format in layer
FSP_ERR_INVALID_UPDATE_TIMING = 1006, ///< Invalid timing for register update
FSP_ERR_INVALID_CLUT_ACCESS = 1007, ///< Invalid access to CLUT entry
FSP_ERR_INVALID_FADE_SETTING = 1008, ///< Invalid fade-in/fade-out setting
FSP_ERR_INVALID_BRIGHTNESS_SETTING = 1009, ///< Invalid gamma correction parameter
/* Start of JPEG Specific */
FSP_ERR_JPEG_ERR = 1100, ///< JPEG error
FSP_ERR_JPEG_SOI_NOT_DETECTED = 1101, ///< SOI not detected until EOI detected.
FSP_ERR_JPEG_SOF1_TO_SOFF_DETECTED = 1102, ///< SOF1 to SOFF detected.
FSP_ERR_JPEG_UNSUPPORTED_PIXEL_FORMAT = 1103, ///< Unprovided pixel format detected.
FSP_ERR_JPEG_SOF_ACCURACY_ERROR = 1104, ///< SOF accuracy error: other than 8 detected.
FSP_ERR_JPEG_DQT_ACCURACY_ERROR = 1105, ///< DQT accuracy error: other than 0 detected.
FSP_ERR_JPEG_COMPONENT_ERROR1 = 1106, ///< Component error 1: the number of SOF0 header components detected is other than 1, 3, or 4.
FSP_ERR_JPEG_COMPONENT_ERROR2 = 1107, ///< Component error 2: the number of components differs between SOF0 header and SOS.
FSP_ERR_JPEG_SOF0_DQT_DHT_NOT_DETECTED = 1108, ///< SOF0, DQT, and DHT not detected when SOS detected.
FSP_ERR_JPEG_SOS_NOT_DETECTED = 1109, ///< SOS not detected: SOS not detected until EOI detected.
FSP_ERR_JPEG_EOI_NOT_DETECTED = 1110, ///< EOI not detected (default)
FSP_ERR_JPEG_RESTART_INTERVAL_DATA_NUMBER_ERROR = 1111, ///< Restart interval data number error detected.
FSP_ERR_JPEG_IMAGE_SIZE_ERROR = 1112, ///< Image size error detected.
FSP_ERR_JPEG_LAST_MCU_DATA_NUMBER_ERROR = 1113, ///< Last MCU data number error detected.
FSP_ERR_JPEG_BLOCK_DATA_NUMBER_ERROR = 1114, ///< Block data number error detected.
FSP_ERR_JPEG_BUFFERSIZE_NOT_ENOUGH = 1115, ///< User provided buffer size not enough
FSP_ERR_JPEG_UNSUPPORTED_IMAGE_SIZE = 1116, ///< JPEG Image size is not aligned with MCU
/* Start of touch panel framework specific */
FSP_ERR_CALIBRATE_FAILED = 1200, ///< Calibration failed
/* Start of IP specific */
FSP_ERR_IP_HARDWARE_NOT_PRESENT = 1400, ///< Requested IP does not exist on this device
FSP_ERR_IP_UNIT_NOT_PRESENT = 1401, ///< Requested unit does not exist on this device
FSP_ERR_IP_CHANNEL_NOT_PRESENT = 1402, ///< Requested channel does not exist on this device
/* Start of USB specific */
FSP_ERR_USB_FAILED = 1500,
FSP_ERR_USB_BUSY = 1501,
FSP_ERR_USB_SIZE_SHORT = 1502,
FSP_ERR_USB_SIZE_OVER = 1503,
FSP_ERR_USB_NOT_OPEN = 1504,
FSP_ERR_USB_NOT_SUSPEND = 1505,
FSP_ERR_USB_PARAMETER = 1506,
/* Start of Message framework specific */
FSP_ERR_NO_MORE_BUFFER = 2000, ///< No more buffer found in the memory block pool
FSP_ERR_ILLEGAL_BUFFER_ADDRESS = 2001, ///< Buffer address is out of block memory pool
FSP_ERR_INVALID_WORKBUFFER_SIZE = 2002, ///< Work buffer size is invalid
FSP_ERR_INVALID_MSG_BUFFER_SIZE = 2003, ///< Message buffer size is invalid
FSP_ERR_TOO_MANY_BUFFERS = 2004, ///< Number of buffer is too many
FSP_ERR_NO_SUBSCRIBER_FOUND = 2005, ///< No message subscriber found
FSP_ERR_MESSAGE_QUEUE_EMPTY = 2006, ///< No message found in the message queue
FSP_ERR_MESSAGE_QUEUE_FULL = 2007, ///< No room for new message in the message queue
FSP_ERR_ILLEGAL_SUBSCRIBER_LISTS = 2008, ///< Message subscriber lists is illegal
FSP_ERR_BUFFER_RELEASED = 2009, ///< Buffer has been released
/* Start of 2DG Driver specific */
FSP_ERR_D2D_ERROR_INIT = 3000, ///< D/AVE 2D has an error in the initialization
FSP_ERR_D2D_ERROR_DEINIT = 3001, ///< D/AVE 2D has an error in the initialization
FSP_ERR_D2D_ERROR_RENDERING = 3002, ///< D/AVE 2D has an error in the rendering
FSP_ERR_D2D_ERROR_SIZE = 3003, ///< D/AVE 2D has an error in the rendering
/* Start of ETHER Driver specific */
FSP_ERR_ETHER_ERROR_NO_DATA = 4000, ///< No Data in Receive buffer.
FSP_ERR_ETHER_ERROR_LINK = 4001, ///< ETHERC/EDMAC has an error in the Auto-negotiation
FSP_ERR_ETHER_ERROR_MAGIC_PACKET_MODE = 4002, ///< As a Magic Packet is being detected, and transmission/reception is not enabled
FSP_ERR_ETHER_ERROR_TRANSMIT_BUFFER_FULL = 4003, ///< Transmit buffer is not empty
FSP_ERR_ETHER_ERROR_FILTERING = 4004, ///< Detect multicast frame when multicast frame filtering enable
FSP_ERR_ETHER_ERROR_PHY_COMMUNICATION = 4005, ///< ETHERC/EDMAC has an error in the phy communication
/* Start of ETHER_PHY Driver specific */
FSP_ERR_ETHER_PHY_ERROR_LINK = 5000, ///< PHY is not link up.
FSP_ERR_ETHER_PHY_NOT_READY = 5001, ///< PHY has an error in the Auto-negotiation
/* Start of BYTEQ library specific */
FSP_ERR_QUEUE_FULL = 10000, ///< Queue is full, cannot queue another data
FSP_ERR_QUEUE_EMPTY = 10001, ///< Queue is empty, no data to dequeue
/* Start of CTSU Driver specific */
FSP_ERR_CTSU_SCANNING = 6000, ///< Scanning.
FSP_ERR_CTSU_NOT_GET_DATA = 6001, ///< Not processed previous scan data.
FSP_ERR_CTSU_INCOMPLETE_TUNING = 6002, ///< Incomplete initial offset tuning.
/* Start of SDMMC specific */
FSP_ERR_CARD_INIT_FAILED = 40000, ///< SD card or eMMC device failed to initialize.
FSP_ERR_CARD_NOT_INSERTED = 40001, ///< SD card not installed.
FSP_ERR_DEVICE_BUSY = 40002, ///< Device is holding DAT0 low or another operation is ongoing.
FSP_ERR_CARD_NOT_INITIALIZED = 40004, ///< SD card was removed.
FSP_ERR_CARD_WRITE_PROTECTED = 40005, ///< Media is write protected.
FSP_ERR_TRANSFER_BUSY = 40006, ///< Transfer in progress.
FSP_ERR_RESPONSE = 40007, ///< Card did not respond or responded with an error.
/* Start of FX_IO specific */
FSP_ERR_MEDIA_FORMAT_FAILED = 50000, ///< Media format failed.
FSP_ERR_MEDIA_OPEN_FAILED = 50001, ///< Media open failed.
/* Start of CAN specific */
FSP_ERR_CAN_DATA_UNAVAILABLE = 60000, ///< No data available.
FSP_ERR_CAN_MODE_SWITCH_FAILED = 60001, ///< Switching operation modes failed.
FSP_ERR_CAN_INIT_FAILED = 60002, ///< Hardware initialization failed.
FSP_ERR_CAN_TRANSMIT_NOT_READY = 60003, ///< Transmit in progress.
FSP_ERR_CAN_RECEIVE_MAILBOX = 60004, ///< Mailbox is setup as a receive mailbox.
FSP_ERR_CAN_TRANSMIT_MAILBOX = 60005, ///< Mailbox is setup as a transmit mailbox.
FSP_ERR_CAN_MESSAGE_LOST = 60006, ///< Receive message has been overwritten or overrun.
/* Start of SF_WIFI Specific */
FSP_ERR_WIFI_CONFIG_FAILED = 70000, ///< WiFi module Configuration failed.
FSP_ERR_WIFI_INIT_FAILED = 70001, ///< WiFi module initialization failed.
FSP_ERR_WIFI_TRANSMIT_FAILED = 70002, ///< Transmission failed
FSP_ERR_WIFI_INVALID_MODE = 70003, ///< API called when provisioned in client mode
FSP_ERR_WIFI_FAILED = 70004, ///< WiFi Failed.
FSP_ERR_WIFI_SCAN_COMPLETE = 70005, ///< Wifi scan has completed.
/* Start of SF_CELLULAR Specific */
FSP_ERR_CELLULAR_CONFIG_FAILED = 80000, ///< Cellular module Configuration failed.
FSP_ERR_CELLULAR_INIT_FAILED = 80001, ///< Cellular module initialization failed.
FSP_ERR_CELLULAR_TRANSMIT_FAILED = 80002, ///< Transmission failed
FSP_ERR_CELLULAR_FW_UPTODATE = 80003, ///< Firmware is uptodate
FSP_ERR_CELLULAR_FW_UPGRADE_FAILED = 80004, ///< Firmware upgrade failed
FSP_ERR_CELLULAR_FAILED = 80005, ///< Cellular Failed.
FSP_ERR_CELLULAR_INVALID_STATE = 80006, ///< API Called in invalid state.
FSP_ERR_CELLULAR_REGISTRATION_FAILED = 80007, ///< Cellular Network registration failed
/* Start of SF_BLE specific */
FSP_ERR_BLE_FAILED = 90001, ///< BLE operation failed
FSP_ERR_BLE_INIT_FAILED = 90002, ///< BLE device initialization failed
FSP_ERR_BLE_CONFIG_FAILED = 90003, ///< BLE device configuration failed
FSP_ERR_BLE_PRF_ALREADY_ENABLED = 90004, ///< BLE device Profile already enabled
FSP_ERR_BLE_PRF_NOT_ENABLED = 90005, ///< BLE device not enabled
/* Start of SF_BLE_ABS specific */
FSP_ERR_BLE_ABS_INVALID_OPERATION = 91001, ///< Invalid operation is executed.
FSP_ERR_BLE_ABS_NOT_FOUND = 91002, ///< Valid data or free space is not found.
/* Start of Crypto specific (0x10000) @note Refer to sf_cryoto_err.h for Crypto error code. */
FSP_ERR_CRYPTO_CONTINUE = 0x10000, ///< Continue executing function
FSP_ERR_CRYPTO_SCE_RESOURCE_CONFLICT = 0x10001, ///< Hardware resource busy
FSP_ERR_CRYPTO_SCE_FAIL = 0x10002, ///< Internal I/O buffer is not empty
FSP_ERR_CRYPTO_SCE_HRK_INVALID_INDEX = 0x10003, ///< Invalid index
FSP_ERR_CRYPTO_SCE_RETRY = 0x10004, ///< Retry
FSP_ERR_CRYPTO_SCE_VERIFY_FAIL = 0x10005, ///< Verify is failed
FSP_ERR_CRYPTO_SCE_ALREADY_OPEN = 0x10006, ///< HW SCE module is already opened
FSP_ERR_CRYPTO_NOT_OPEN = 0x10007, ///< Hardware module is not initialized
FSP_ERR_CRYPTO_UNKNOWN = 0x10008, ///< Some unknown error occurred
FSP_ERR_CRYPTO_NULL_POINTER = 0x10009, ///< Null pointer input as a parameter
FSP_ERR_CRYPTO_NOT_IMPLEMENTED = 0x1000a, ///< Algorithm/size not implemented
FSP_ERR_CRYPTO_RNG_INVALID_PARAM = 0x1000b, ///< An invalid parameter is specified
FSP_ERR_CRYPTO_RNG_FATAL_ERROR = 0x1000c, ///< A fatal error occurred
FSP_ERR_CRYPTO_INVALID_SIZE = 0x1000d, ///< Size specified is invalid
FSP_ERR_CRYPTO_INVALID_STATE = 0x1000e, ///< Function used in an valid state
FSP_ERR_CRYPTO_ALREADY_OPEN = 0x1000f, ///< control block is already opened
FSP_ERR_CRYPTO_INSTALL_KEY_FAILED = 0x10010, ///< Specified input key is invalid.
FSP_ERR_CRYPTO_AUTHENTICATION_FAILED = 0x10011, ///< Authentication failed
FSP_ERR_CRYPTO_SCE_KEY_SET_FAIL = 0x10012, ///< Failure to Init Cipher
FSP_ERR_CRYPTO_SCE_AUTHENTICATION = 0x10013,
/* Start of SF_CRYPTO specific */
FSP_ERR_CRYPTO_COMMON_NOT_OPENED = 0x20000, ///< Crypto Framework Common is not opened
FSP_ERR_CRYPTO_HAL_ERROR = 0x20001, ///< Cryoto HAL module returned an error
FSP_ERR_CRYPTO_KEY_BUF_NOT_ENOUGH = 0x20002, ///< Key buffer size is not enough to generate a key
FSP_ERR_CRYPTO_BUF_OVERFLOW = 0x20003, ///< Attempt to write data larger than what the buffer can hold
FSP_ERR_CRYPTO_INVALID_OPERATION_MODE = 0x20004, ///< Invalid operation mode.
FSP_ERR_MESSAGE_TOO_LONG = 0x20005, ///< Message for RSA encryption is too long.
FSP_ERR_RSA_DECRYPTION_ERROR = 0x20006, ///< RSA Decryption error.
/** @note SF_CRYPTO APIs may return an error code starting from 0x10000 which is of Crypto module.
* Refer to sf_cryoto_err.h for Crypto error codes.
*/
/* Start of Sensor specific */
FSP_ERR_SENSOR_INVALID_DATA = 0x30000, ///< Data is invalid.
FSP_ERR_SENSOR_IN_STABILIZATION = 0x30001, ///< Sensor is stabilizing.
FSP_ERR_SENSOR_MEASUREMENT_NOT_FINISHED = 0x30002, ///< Measurement is not finished.
/* Start of COMMS specific */
FSP_ERR_COMMS_BUS_NOT_OPEN = 0x40000, ///< Bus is not open.
} fsp_err_t;
/** Common version structure */
typedef union st_fsp_version
{
/** Version id */
uint32_t version_id;
/** Code version parameters */
struct
{
uint8_t code_version_minor; ///< Code minor version
uint8_t code_version_major; ///< Code major version
uint8_t api_version_minor; ///< API minor version
uint8_t api_version_major; ///< API major version
};
} fsp_version_t;
/** @} */
/***********************************************************************************************************************
* Function prototypes
**********************************************************************************************************************/
#endif

View File

@ -0,0 +1,476 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef FSP_FEATURES_H
#define FSP_FEATURES_H
/***********************************************************************************************************************
* Includes <System Includes> , "Project Includes"
**********************************************************************************************************************/
/* C99 includes. */
#include <stdint.h>
#include <stddef.h>
#include <stdbool.h>
#include <assert.h>
/* Different compiler support. */
#include "fsp_common_api.h"
#include "../../fsp/src/bsp/mcu/all/bsp_compiler_support.h"
#include "../../fsp/src/bsp/mcu/all/bsp_module_stop.h"
#include "../../fsp/src/bsp/mcu/all/bsp_clocks.h"
/***********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @addtogroup BSP_MCU
* @{
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* Cancels the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be started
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START(ip, ch) (R_BSP_MODULE_START_ ## ip(ip, ch))
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP(ip, ch) (R_BSP_MODULE_STOP_ ## ip(ip, ch))
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_GTM(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTON(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_GTM(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_MTU3(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_MTU3(ip, ch) {NULL;}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_GPT(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_GPT(ip, ch) {NULL;}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_POEG(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_POEG(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_SCIF(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_SCIF(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_RIIC(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_RIIC(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_RSPI(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_RSPI(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_MHU(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_MHU(ip, ch) {NULL;}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_DMAC(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(FSP_IP_DMAC_s, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_DMAC(ip, ch) {NULL;}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_DMAC_s(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_DMAC_s(ip, ch) {NULL;}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_SSI(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_SSI(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#if BSP_FEATURE_CANFD_LITE
#define R_BSP_MODULE_START_FSP_IP_CANFD(ip, ch) {R_BSP_MSTP_START(ip, ch);}
#else
#if BSP_FEATURE_CANFD_HAS_RSCANFD == 0
#define R_BSP_MODULE_START_FSP_IP_CANFD(ip, ch) {R_BSP_MSTP_START(ip, 0U); \
R_BSP_MODULE_CLKON(ip, 0U); \
R_BSP_MODULE_CLKON(ip, 1U); \
R_BSP_MODULE_RSTOFF(ip, 0U); \
R_BSP_MODULE_RSTOFF(ip, 1U);}
#else
#define R_BSP_MODULE_START_FSP_IP_CANFD(ip, ch) {R_BSP_MSTP_START(ip, 0U); \
R_BSP_MODULE_CLKON(ip, 0U); \
R_BSP_MODULE_RSTOFF(ip, 0U); \
R_BSP_MODULE_RSTOFF(ip, 1U);}
#endif
#endif
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#if BSP_FEATURE_CANFD_LITE
#define R_BSP_MODULE_STOP_FSP_IP_CANFD(ip, ch) {R_BSP_MSTP_STOP(ip, ch)};
#else
#define R_BSP_MODULE_STOP_FSP_IP_CANFD(ip, ch) {R_BSP_MODULE_CLKOFF(ip, 0U); \
R_BSP_MSTP_STOP(ip, 0U);}
#endif
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_ADC(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_ADC(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_TSU(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_TSU(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_WDT(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch) \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_WDT(ip, ch) {NULL;}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_SCI(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_SCI(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/*******************************************************************************************************************//**
* Cancel the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_START_FSP_IP_XSPI(ip, ch) {R_BSP_MODULE_CLKON(ip, ch); \
R_BSP_MSTP_START(ip, ch); \
R_BSP_MODULE_RSTOFF(ip, ch);}
/*******************************************************************************************************************//**
* Enables the module stop state.
*
* @param ip fsp_ip_t enum value for the module to be stopped
* @param ch The channel. Use channel 0 for modules without channels.
**********************************************************************************************************************/
#define R_BSP_MODULE_STOP_FSP_IP_XSPI(ip, ch) {R_BSP_MSTP_STOP(ip, ch); \
R_BSP_MODULE_CLKOFF(ip, ch);}
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/***********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
#ifndef BSP_OVERRIDE_FSP_IP_T
/** Available modules. */
typedef enum e_fsp_ip
{
FSP_IP_GTM = 0, ///< General Timer
FSP_IP_GPT = 1, ///< General PWM Timer
FSP_IP_POEG = 2, ///< Port Output Enable for GPT
FSP_IP_PORT = 3, ///< I/O Ports
FSP_IP_IM33 = 4, ///< IM33 (Interrupt controller)
FSP_IP_SCIF = 5, ///< Serial Communications Interface with FIFO
FSP_IP_RIIC = 6, ///< I2C Bus Interface
FSP_IP_RSPI = 7, ///< Renesas Serial Peripheral Interface
FSP_IP_MHU = 8, ///< Message Handling Unit
FSP_IP_DMAC = 9, ///< Direct Memory Access Controller
FSP_IP_DMAC_s = 9, ///< Direct Memory Access Controller
FSP_IP_SSI = 10, ///< Serial Sound Interface
FSP_IP_CANFD = 11, ///< CANFD Interface (RS-CANFD)
FSP_IP_ADC = 12, ///< A/D Converter
FSP_IP_TSU = 13, ///< Thermal Sensor Unit
FSP_IP_WDT = 14, ///< Watchdog Timer
FSP_IP_SCI = 15, ///< Serial Communications Interface
FSP_IP_MTU3 = 16, ///< Multi-Function Timer Pulse Unit 3
FSP_IP_XSPI = 17, ///< Expanded Serial Peripheral Interface
} fsp_ip_t;
#endif
typedef void (* fsp_vector_t)(void);
/** @} (end addtogroup BSP_MCU) */
/** Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif /* FSP_FEATURES_H */

View File

@ -0,0 +1,80 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef FSP_VERSION_H
#define FSP_VERSION_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
/* Includes board and MCU related header files. */
#include "bsp_api.h"
/*******************************************************************************************************************//**
* @addtogroup RENESAS_COMMON
* @{
**********************************************************************************************************************/
/**********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/** FSP pack major version. */
#define FSP_VERSION_MAJOR (2U)
/** FSP pack minor version. */
#define FSP_VERSION_MINOR (0U)
/** FSP pack patch version. */
#define FSP_VERSION_PATCH (0U)
/** FSP pack version build number (currently unused). */
#define FSP_VERSION_BUILD (0U)
/** Public FSP version name. */
#define FSP_VERSION_STRING ("2.0.0")
/** Unique FSP version ID. */
#define FSP_VERSION_BUILD_STRING ("Built with RZ/G Flexible Software Package version 2.0.0")
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** FSP Pack version structure */
typedef union st_fsp_pack_version
{
/** Version id */
uint32_t version_id;
/** Code version parameters, little endian order. */
struct
{
uint8_t build; ///< Build version of FSP Pack
uint8_t patch; ///< Patch version of FSP Pack
uint8_t minor; ///< Minor version of FSP Pack
uint8_t major; ///< Major version of FSP Pack
};
} fsp_pack_version_t;
/** @} */
#endif

View File

@ -0,0 +1,121 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef R_GTM_H
#define R_GTM_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
#include "bsp_api.h"
#include "r_gtm_cfg.h"
#include "r_timer_api.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/***********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/** Maximum number of clock counts in 32 bit timer. */
#define GTM_MAX_CLOCK_COUNTS (UINT32_MAX)
/** Maximum period value allowed for GTM. */
#define GTM_MAX_PERIOD ((uint64_t) UINT32_MAX + 1ULL)
/*******************************************************************************************************************//**
* @addtogroup GTM
* @{
**********************************************************************************************************************/
/***********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** Optional GTM interrupt setting */
typedef enum e_gtm_giws_type
{
GTM_GIWS_TYPE_DISABLED = 0, ///< Do not generate interrupt when timer started
GTM_GIWS_TYPE_ENABLED = 1, ///< Generates interrupt when timer started
} gtm_giws_type_t;
/** Optional GTM timer mode setting */
typedef enum e_gtm_timer_mode
{
GTM_TIMER_MODE_INTERVAL = 0, ///< Use interval timer mode
GTM_TIMER_MODE_FREERUN = 1, ///< Use free-running comparison mode
} gtm_timer_mode_t;
/** Channel control block. DO NOT INITIALIZE. Initialization occurs when @ref timer_api_t::open is called. */
typedef struct st_gtm_instance_ctrl
{
uint32_t open; // Whether or not channel is open
const timer_cfg_t * p_cfg; // Pointer to initial configurations
R_GTM0_Type * p_reg; // Base register for this channel
uint32_t period; // Current timer period (counts)
void (* p_callback)(timer_callback_args_t * p_arg); // Pointer to callback
timer_callback_args_t * p_callback_memory; // Pointer to pre-allocated callback argument
void const * p_context; // Pointer to context to be passed into callback function
} gtm_instance_ctrl_t;
/** Optional GTM extension data structure.*/
typedef struct st_gtm_extended_cfg
{
gtm_giws_type_t generate_interrupt_when_starts; // Controls enabling/disabling of interrupt requests when start
gtm_timer_mode_t gtm_mode; // Select GTM timer mode
} gtm_extended_cfg_t;
/**********************************************************************************************************************
* Exported global variables
**********************************************************************************************************************/
/** @cond INC_HEADER_DEFS_SEC */
/** Filled in Interface API structure for this Instance. */
extern const timer_api_t g_timer_on_gtm;
/** @endcond */
fsp_err_t R_GTM_Close(timer_ctrl_t * const p_ctrl);
fsp_err_t R_GTM_PeriodSet(timer_ctrl_t * const p_ctrl, uint32_t const period_counts);
fsp_err_t R_GTM_DutyCycleSet(timer_ctrl_t * const p_ctrl, uint32_t const duty_cycle_counts, uint32_t const pin);
fsp_err_t R_GTM_Reset(timer_ctrl_t * const p_ctrl);
fsp_err_t R_GTM_Start(timer_ctrl_t * const p_ctrl);
fsp_err_t R_GTM_Enable(timer_ctrl_t * const p_ctrl);
fsp_err_t R_GTM_Disable(timer_ctrl_t * const p_ctrl);
fsp_err_t R_GTM_InfoGet(timer_ctrl_t * const p_ctrl, timer_info_t * const p_info);
fsp_err_t R_GTM_StatusGet(timer_ctrl_t * const p_ctrl, timer_status_t * const p_status);
fsp_err_t R_GTM_Stop(timer_ctrl_t * const p_ctrl);
fsp_err_t R_GTM_Open(timer_ctrl_t * const p_ctrl, timer_cfg_t const * const p_cfg);
fsp_err_t R_GTM_CallbackSet(timer_ctrl_t * const p_api_ctrl,
void ( * p_callback)(timer_callback_args_t * p_arg),
void const * const p_context,
timer_callback_args_t * const p_callback_memory);
/*******************************************************************************************************************//**
* @} (end defgroup GTM)
**********************************************************************************************************************/
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif /* R_GTM_H */

View File

@ -0,0 +1,331 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @addtogroup IOPORT
* @{
**********************************************************************************************************************/
#ifndef R_IOPORT_H
#define R_IOPORT_H
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
#include "bsp_api.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
#include "r_ioport_api.h"
#include "r_ioport_cfg.h"
/***********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/* Private definition to set enumeration values. */
#define IOPORT_PRV_PFS_PSEL_OFFSET (24)
/***********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** IOPORT private control block. DO NOT MODIFY. Initialization occurs when R_IOPORT_Open() is called. */
typedef struct st_ioport_instance_ctrl
{
uint32_t open;
void const * p_context;
ioport_cfg_t const * p_cfg;
} ioport_instance_ctrl_t;
#ifndef BSP_OVERRIDE_IOPORT_PERIPHERAL_T
/** Superset of all peripheral functions. */
typedef enum e_ioport_peripheral
{
/** Pin will function as a Mode0 peripheral pin */
IOPORT_PERIPHERAL_MODE0 = (0x0UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode1 peripheral pin */
IOPORT_PERIPHERAL_MODE1 = (0x1UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode2 peripheral pin */
IOPORT_PERIPHERAL_MODE2 = (0x2UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode3 peripheral pin */
IOPORT_PERIPHERAL_MODE3 = (0x3UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode4 peripheral pin */
IOPORT_PERIPHERAL_MODE4 = (0x4UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode5 peripheral pin */
IOPORT_PERIPHERAL_MODE5 = (0x5UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode6 peripheral pin */
IOPORT_PERIPHERAL_MODE6 = (0x6UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode7 peripheral pin */
IOPORT_PERIPHERAL_MODE7 = (0x7UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode8 peripheral pin */
IOPORT_PERIPHERAL_MODE8 = (0x8UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode9 peripheral pin */
IOPORT_PERIPHERAL_MODE9 = (0x9UL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode10 peripheral pin */
IOPORT_PERIPHERAL_MODE10 = (0xAUL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode11 peripheral pin */
IOPORT_PERIPHERAL_MODE11 = (0xBUL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode12 peripheral pin */
IOPORT_PERIPHERAL_MODE12 = (0xCUL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode13 peripheral pin */
IOPORT_PERIPHERAL_MODE13 = (0xDUL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode14 peripheral pin */
IOPORT_PERIPHERAL_MODE14 = (0xEUL << IOPORT_PRV_PFS_PSEL_OFFSET),
/** Pin will function as a Mode15 peripheral pin */
IOPORT_PERIPHERAL_MODE15 = (0xFUL << IOPORT_PRV_PFS_PSEL_OFFSET),
} ioport_peripheral_t;
#endif
#ifndef BSP_OVERRIDE_IOPORT_OPTIONS_T
/** Options to configure pin functions */
typedef enum e_ioport_cfg_options
{
/* For PM Register */
IOPORT_CFG_PORT_DIRECTION_HIZ = 0x00000000, ///< Sets the pin direction to Hi-Z (default)
IOPORT_CFG_PORT_DIRECTION_INPUT = 0x00000004, ///< Sets the pin direction to input
IOPORT_CFG_PORT_DIRECTION_OUTPUT = 0x00000008, ///< Sets the pin direction to output (input disable)
IOPORT_CFG_PORT_DIRECTION_OUTPUT_INPUT = 0x0000000C, ///< Sets the pin direction to output (input enable)
/* For P Register */
IOPORT_CFG_PORT_OUTPUT_LOW = 0x00000000, ///< Sets the pin level to low
IOPORT_CFG_PORT_OUTPUT_HIGH = 0x00000001, ///< Sets the pin level to high
/* For PUPD Register */
IOPORT_CFG_PULLUP_PULLDOWN_DISABLE = 0x00000000, ///< Disable the pin's internal pull-up and pull-down
IOPORT_CFG_PULLUP_ENABLE = 0x00000010, ///< Enables the pin's internal pull-up
IOPORT_CFG_PULLDOWN_ENABLE = 0x00000020, ///< Enables the pin's internal pull-down
/* For NOD Register */
IOPORT_CFG_NOD_DISABLE = 0x00000000, ///< Disable the pin's N-ch open-drain
IOPORT_CFG_NOD_ENABLE = 0x00000040, ///< Enables the pin's N-ch open-drain
/* For SMT Register */
IOPORT_CFG_SCHMITT_DISABLE = 0x00000000, ///< Disable the pin's Schmitt-trigger input
IOPORT_CFG_SCHMITT_ENABLE = 0x80000000, ///< Enables the pin's Schmitt-trigger input
/* For IOLH Register */
IOPORT_CFG_DRIVE_B00 = 0x00000000, ///< Sets the IOLH register value to b'00
IOPORT_CFG_DRIVE_B01 = 0x00000400, ///< Sets the IOLH register value to b'01
IOPORT_CFG_DRIVE_B10 = 0x00000800, ///< Sets the IOLH register value to b'10
IOPORT_CFG_DRIVE_B11 = 0x00000C00, ///< Sets the IOLH register value to b'11
/* For ISEL Register */
IOPORT_CFG_TINT_DISABLE = 0x00000000, ///< Disable IRQ functionality for a pin
IOPORT_CFG_TINT_ENABLE = 0x00004000, ///< Sets pin as an IRQ pin
/* For SR Register */
IOPORT_CFG_SLEW_RATE_SLOW = 0x00000000, ///< Sets the pin slew-rate to slow
IOPORT_CFG_SLEW_RATE_FAST = 0x00020000, ///< Sets the pin slew-rate to fast
/* For IEN Register */
IOPORT_CFG_SPECIAL_PURPOSE_PORT_INPUT_DISABLE = 0x00000000, ///< Disable input the pin of special purpose port
IOPORT_CFG_SPECIAL_PURPOSE_PORT_INPUT_ENABLE = 0x00040000, ///< Sets the pin of special purpose port to input
/* For FILONOFF Register */
IOPORT_CFG_NOISE_FILTER_OFF = 0x00000000, ///< Noise filter disable
IOPORT_CFG_NOISE_FILTER_ON = 0x00080000, ///< Noise filter enable
/* For FILNUM Register */
IOPORT_CFG_NOISE_FILTER_NUM_4STAGE = 0x00000000, ///< Sets the pin noise filter to 4-stage filter
IOPORT_CFG_NOISE_FILTER_NUM_8STAGE = 0x00100000, ///< Sets the pin noise filter to 8-stage filter
IOPORT_CFG_NOISE_FILTER_NUM_12STAGE = 0x00200000, ///< Sets the pin noise filter to 12-stage filter
IOPORT_CFG_NOISE_FILTER_NUM_16STAGE = 0x00300000, ///< Sets the pin noise filter to 16-stage filter
/* For FILCLKSEL Register */
IOPORT_CFG_NOISE_FILTER_DIVIDED_B00 = 0x00000000, ///< Sets the FILCLKSEL register value to b'00
IOPORT_CFG_NOISE_FILTER_DIVIDED_B01 = 0x00400000, ///< Sets the FILCLKSEL register value to b'01
IOPORT_CFG_NOISE_FILTER_DIVIDED_B10 = 0x00800000, ///< Sets the FILCLKSEL register value to b'10
IOPORT_CFG_NOISE_FILTER_DIVIDED_B11 = 0x00C00000, ///< Sets the FILCLKSEL register value to b'11
/* For PMC Register */
IOPORT_CFG_PERIPHERAL_PIN = 0x00010000 ///< Enables pin to operate as a peripheral pin
} ioport_cfg_options_t;
#endif
/** Pin selection for port group
* @note Event link must be configured by the ELC
*/
typedef enum e_ioport_event_pin_selection
{
IOPORT_EVENT_PIN_SELECTION_NONE = 0x00, ///< No pin selection for port group
IOPORT_EVENT_PIN_SELECTION_PIN_0 = 0x01, ///< Select pin 0 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_1 = 0x02, ///< Select pin 1 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_2 = 0x04, ///< Select pin 2 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_3 = 0x08, ///< Select pin 3 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_4 = 0x10, ///< Select pin 4 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_5 = 0x20, ///< Select pin 5 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_6 = 0x40, ///< Select pin 6 to port group
IOPORT_EVENT_PIN_SELECTION_PIN_7 = 0x80, ///< Select pin 7 to port group
} ioport_event_pin_selection_t;
/** Port group operation
* @note Event link must be configured by the ELC
*/
typedef enum e_ioport_event_output_operation
{
IOPORT_EVENT_OUTPUT_OPERATION_LOW = 0x0, ///< Set Low output to output operation
IOPORT_EVENT_OUTPUT_OPERATION_HIGH = 0x1, ///< Set High output to output operation
IOPORT_EVENT_OUTPUT_OPERATION_TOGGLE = 0x2, ///< Set toggle output to output operation
IOPORT_EVENT_OUTPUT_OPERATION_BUFFER = 0x3, ///< Set buffer value output to output operation
} ioport_event_output_operation_t;
/** Input port group event control
* @note Event link must be configured by the ELC
*/
typedef enum e_ioport_event_control
{
IOPORT_EVENT_CONTROL_DISABLE = 0x0, ///< Disable function related with event link
IOPORT_EVENT_CONTROL_ENABLE = 0x1, ///< Enable function related with event link
} ioport_event_control_t;
/** Single port event direction
* @note Event link must be configured by the ELC
*/
typedef enum e_ioport_event_direction
{
IOPORT_EVENT_DIRECTION_OUTPUT = 0x0, ///< Set output direction to single port
IOPORT_EVENT_DIRECTION_INPUT = 0x1, ///< Set input direction to single port
} ioport_event_direction_t;
/** Input event edge detection
* @note Event link must be configured by the ELC
*/
typedef enum e_ioport_event_detection
{
IOPORT_EVENT_DETECTION_RISING_EDGE = 0x0, ///< Set rising edge to event detection for input event
IOPORT_EVENT_DETECTION_FALLING_EDGE = 0x1, ///< Set falling edge to event detection for input event
IOPORT_EVENT_DETECTION_BOTH_EGDE = 0x2, ///< Set both edges to event detection for input event
} ioport_event_detection_t;
/** Initial value for buffer register
* @note Event link must be configured by the ELC
*/
typedef enum e_ioport_event_initial_buffer_value
{
IOPORT_EVENT_INITIAL_BUFFER_VALUE_LOW = 0U, ///< Set low to initial value of buffer register for input port group
IOPORT_EVENT_INITIAL_BUFFER_VALUE_HIGH = 1U, ///< Set high to initial value of buffer register for input port group
} ioport_event_initial_buffer_value_t;
/** Single port configuration
* @note Event link must be configured by the ELC
*/
typedef struct st_ioport_event_single
{
ioport_event_control_t event_control; ///< Event link control for single port
ioport_event_direction_t direction; ///< Event direction for single port
uint16_t port_num; ///< Port number specified to single port
ioport_event_output_operation_t operation; ///< Single port operation select
ioport_event_detection_t edge_detection; ///< Edge detection select
} ioport_event_single_t;
/** Output port group configuration
* @note Event link must be configured by the ELC
*/
typedef struct st_ioport_event_group_output
{
uint8_t pin_select; ///< Port number specified to output port group
ioport_event_output_operation_t operation; ///< Port group operation select
} ioport_event_group_output_t;
/** Input port group configuration
* @note Event link must be configured by the ELC
*/
typedef struct st_ioport_event_group_input
{
ioport_event_control_t event_control; ///< Event link control for input port group
ioport_event_detection_t edge_detection; ///< Edge detection select
ioport_event_control_t overwrite_control; ///< Buffer register overwrite control
uint8_t pin_select; ///< Port number specified to input port group
uint8_t buffer_init_value; ///< Buffer register initial value
} ioport_event_group_input_t;
/** IOPORT extended configuration for event link function
* @note Event link must be configured by the ELC
*/
typedef struct st_ioport_extend_cfg
{
ioport_event_group_output_t const * p_port_group_output_cfg; ///< Pointer to output port group configuration
ioport_event_group_input_t const * p_port_group_input_cfg; ///< Pointer to input port group configuration
ioport_event_single_t const * p_single_port_cfg; ///< Pointer to single input port configuration
} ioport_extend_cfg_t;
/**********************************************************************************************************************
* Exported global variables
**********************************************************************************************************************/
/** @cond INC_HEADER_DEFS_SEC */
/** Filled in Interface API structure for this Instance. */
extern const ioport_api_t g_ioport_on_ioport;
/** @endcond */
/***********************************************************************************************************************
* Public APIs
**********************************************************************************************************************/
fsp_err_t R_IOPORT_Open(ioport_ctrl_t * const p_ctrl, const ioport_cfg_t * p_cfg);
fsp_err_t R_IOPORT_Close(ioport_ctrl_t * const p_ctrl);
fsp_err_t R_IOPORT_PinsCfg(ioport_ctrl_t * const p_ctrl, const ioport_cfg_t * p_cfg);
fsp_err_t R_IOPORT_PinCfg(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, uint32_t cfg);
fsp_err_t R_IOPORT_PinEventInputRead(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t * p_pin_event);
fsp_err_t R_IOPORT_PinEventOutputWrite(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t pin_value);
fsp_err_t R_IOPORT_PinRead(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t * p_pin_value);
fsp_err_t R_IOPORT_PinWrite(ioport_ctrl_t * const p_ctrl, bsp_io_port_pin_t pin, bsp_io_level_t level);
fsp_err_t R_IOPORT_PortDirectionSet(ioport_ctrl_t * const p_ctrl,
bsp_io_port_t port,
ioport_size_t direction_values,
ioport_size_t mask);
fsp_err_t R_IOPORT_PortEventInputRead(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t * event_data);
fsp_err_t R_IOPORT_PortEventOutputWrite(ioport_ctrl_t * const p_ctrl,
bsp_io_port_t port,
ioport_size_t event_data,
ioport_size_t mask_value);
fsp_err_t R_IOPORT_PortRead(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t * p_port_value);
fsp_err_t R_IOPORT_PortWrite(ioport_ctrl_t * const p_ctrl, bsp_io_port_t port, ioport_size_t value, ioport_size_t mask);
/*******************************************************************************************************************//**
* @} (end defgroup IOPORT)
**********************************************************************************************************************/
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif // R_IOPORT_H

View File

@ -0,0 +1,105 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*******************************************************************************************************************//**
* @addtogroup MHU_NS
* @{
**********************************************************************************************************************/
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
#include "r_mhu_api.h"
#include "r_mhu_ns_cfg.h"
#ifndef R_MHU_NS_H
#define R_MHU_NS_H
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/***********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
/*************************************************************************************************
* Type defines
*************************************************************************************************/
/** Channel control block. DO NOT INITIALIZE. Initialization occurs when @ref mhu_api_t::open is called. */
typedef struct st_mhu_ns_instance_ctrl
{
uint32_t open; ///< Indicates whether the open() API has been successfully called.
mhu_cfg_t const * p_cfg; ///< Pointer to instance configuration
R_MHU0_Type * p_regs; ///< Base register for this channel
uint32_t channel; ///< channel
mhu_send_type_t send_type; ///< Send Type: Message or Response
uint32_t * p_shared_memory_tx; ///< Pointer to send data area
uint32_t * p_shared_memory_rx; ///< Pointer to recv data area
#if BSP_TZ_SECURE_BUILD
bool callback_is_secure; ///< p_callback is in secure memory
#endif
/* Pointer to callback and optional working memory */
void (* p_callback)(mhu_callback_args_t *);
/* Pointer to non-secure memory that can be used to pass arguments to a callback in non-secure memory. */
mhu_callback_args_t * p_callback_memory;
/* Pointer to context to be passed into callback function */
void const * p_context;
} mhu_ns_instance_ctrl_t;
/**********************************************************************************************************************
* Exported global variables
**********************************************************************************************************************/
/** @cond INC_HEADER_DEFS_SEC */
/** Filled in Interface API structure for this Instance. */
extern const mhu_api_t g_mhu_ns_on_mhu_ns;
/** @endcond */
/***********************************************************************************************************************
* Public APIs
**********************************************************************************************************************/
fsp_err_t R_MHU_NS_Open(mhu_ctrl_t * p_ctrl, mhu_cfg_t const * const p_cfg);
fsp_err_t R_MHU_NS_MsgSend(mhu_ctrl_t * const p_ctrl, uint32_t const msg);
fsp_err_t R_MHU_NS_Close(mhu_ctrl_t * const p_ctrl);
fsp_err_t R_MHU_NS_CallbackSet(mhu_ctrl_t * const p_api_ctrl,
void ( * p_callback ) (mhu_callback_args_t *),
void const * const p_context,
mhu_callback_args_t * const p_callback_memory);
void R_MHU_NS_IsrSub(uint32_t irq);
/** Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif /* R_MHU_NS_H */
/*******************************************************************************************************************//**
* @} (end defgroup MHU_NS)
**********************************************************************************************************************/

View File

@ -0,0 +1,242 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
#ifndef R_SCIF_UART_H
#define R_SCIF_UART_H
/*******************************************************************************************************************//**
* @addtogroup SCIF_UART
* @{
**********************************************************************************************************************/
/***********************************************************************************************************************
* Includes
**********************************************************************************************************************/
#include "bsp_api.h"
#include "r_uart_api.h"
#include "r_scif_uart_cfg.h"
/* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
FSP_HEADER
/***********************************************************************************************************************
* Macro definitions
**********************************************************************************************************************/
#define SCIF_UART_INVALID_16BIT_PARAM (0xFFFFU)
#define SCIF_UART_INVALID_8BIT_PARAM (0xFFU)
/**********************************************************************************************************************
* Typedef definitions
**********************************************************************************************************************/
/** Enumeration for SCIF clock source */
typedef enum e_scif_clk_src
{
SCIF_UART_CLOCK_INT, ///< Use internal clock for baud generation
SCIF_UART_CLOCK_INT_WITH_BAUDRATE_OUTPUT, ///< Use internal clock for baud generation and output on SCK
SCIF_UART_CLOCK_EXT8X, ///< Use external clock 8x baud rate
SCIF_UART_CLOCK_EXT16X ///< Use external clock 16x baud rate
} scif_clk_src_t;
/** UART communication mode definition */
typedef enum e_scif_uart_mode
{
SCIF_UART_MODE_RS232, ///< Enables RS232 communication mode
SCIF_UART_MODE_RS485_HD, ///< Enables RS485 half duplex communication mode
SCIF_UART_MODE_RS485_FD, ///< Enables RS485 full duplex communication mode
} scif_uart_mode_t;
/** UART automatic flow control definition */
typedef enum e_scif_uart_flow_control
{
SCIF_UART_FLOW_CONTROL_NONE, ///< Disables flow control
SCIF_UART_FLOW_CONTROL_AUTO, ///< Enables automatic RTS/CTS flow control
} scif_uart_flow_control_t;
/** Noise cancellation configuration. */
typedef enum e_scif_uart_noise_cancellation
{
SCIF_UART_NOISE_CANCELLATION_DISABLE, ///< Disable noise cancellation
SCIF_UART_NOISE_CANCELLATION_ENABLE, ///< Enable noise cancellation
} scif_uart_noise_cancellation_t;
/** RS-485 Enable/Disable. */
typedef enum e_sci_uart_rs485_enable
{
SCI_UART_RS485_DISABLE = 0, ///< RS-485 disabled.
SCI_UART_RS485_ENABLE = 1, ///< RS-485 enabled.
} sci_uart_rs485_enable_t;
/** The polarity of the RS-485 DE signal. */
typedef enum e_sci_uart_rs485_de_polarity
{
SCI_UART_RS485_DE_POLARITY_HIGH = 0, ///< The DE signal is high when a write transfer is in progress.
SCI_UART_RS485_DE_POLARITY_LOW = 1, ///< The DE signal is low when a write transfer is in progress.
} sci_uart_rs485_de_polarity_t;
/** Receive FIFO trigger configuration. */
typedef enum e_scif_uart_receive_trigger
{
SCIF_UART_RECEIVE_TRIGGER_ONE, ///< Interrupt at least one byte is in FIFO
SCIF_UART_RECEIVE_TRIGGER_QUARTER, ///< Interrupt at least quarter of FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_HALF, ///< Interrupt at least half of FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_MAX, ///< Interrupt at almost full in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_1, ///< Interrupt at least 1 byte is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_2, ///< Interrupt at least 2 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_3, ///< Interrupt at least 3 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_4, ///< Interrupt at least 4 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_5, ///< Interrupt at least 5 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_6, ///< Interrupt at least 6 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_7, ///< Interrupt at least 7 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_8, ///< Interrupt at least 8 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_9, ///< Interrupt at least 9 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_10, ///< Interrupt at least 10 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_11, ///< Interrupt at least 11 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_12, ///< Interrupt at least 12 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_13, ///< Interrupt at least 13 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_14, ///< Interrupt at least 14 bytes is in FIFO or 15ETU past from last receive
SCIF_UART_RECEIVE_TRIGGER_15, ///< Interrupt at least 15 bytes is in FIFO or 15ETU past from last receive
} scif_uart_receive_trigger_t;
/** RTS trigger level. */
typedef enum e_scif_uart_rts_trigger
{
SCIF_UART_RTS_TRIGGER_1, ///< RTS trigger level = 1
SCIF_UART_RTS_TRIGGER_4, ///< RTS trigger level = 4
SCIF_UART_RTS_TRIGGER_6, ///< RTS trigger level = 6
SCIF_UART_RTS_TRIGGER_8, ///< RTS trigger level = 8
SCIF_UART_RTS_TRIGGER_10, ///< RTS trigger level = 10
SCIF_UART_RTS_TRIGGER_12, ///< RTS trigger level = 12
SCIF_UART_RTS_TRIGGER_14, ///< RTS trigger level = 14
SCIF_UART_RTS_TRIGGER_15, ///< RTS trigger level = 15
} scif_uart_rts_trigger_t;
/** UART instance control block. */
typedef struct st_scif_uart_instance_ctrl
{
/* Parameters to control UART peripheral device */
uint32_t open; // Used to determine if the channel is configured
bsp_io_port_pin_t driver_enable_pin;
/* Source buffer pointer used to fill hardware FIFO from transmit ISR. */
uint8_t const * p_tx_src;
/* Size of source buffer pointer used to fill hardware FIFO from transmit ISR. */
uint32_t tx_src_bytes;
/* Destination buffer pointer used for receiving data. */
uint8_t * p_rx_dest;
/* Size of destination buffer pointer used for receiving data. */
uint32_t rx_dest_bytes;
/* Pointer to the configuration block. */
uart_cfg_t const * p_cfg;
/* Base register for this channel */
R_SCIFA0_Type * p_reg;
/* Backup SPTR value for writing */
uint16_t sptr;
void (* p_callback)(uart_callback_args_t * p_arg); // Pointer to callback
uart_callback_args_t * p_callback_memory; // Pointer to pre-allocated callback argument
/* Pointer to context to be passed into callback function */
void const * p_context;
} scif_uart_instance_ctrl_t;
/** Register settings to achieve a desired baud rate and modulation duty. */
typedef struct st_scif_baud_setting
{
struct
{
uint8_t abcs : 1; ///< Asynchronous Mode Base Clock Select
uint8_t brme : 1; ///< Bit Rate Modulation Enable
uint8_t bgdm : 1; ///< Baud Rate Generator Double-Speed Mode Select
uint8_t cks : 2; ///< CKS value to get divisor (CKS = N)
} semr_baudrate_bits_b;
uint8_t brr; ///< Bit Rate Register setting
uint8_t mddr; ///< Modulation Duty Register setting
} scif_baud_setting_t;
/** Configuration settings for controlling the DE signal for RS-485. */
typedef struct st_sci_uart_rs485_setting
{
sci_uart_rs485_enable_t enable; ///< Enable the DE signal.
sci_uart_rs485_de_polarity_t polarity; ///< DE signal polarity.
bsp_io_port_pin_t de_control_pin; ///< UART Driver Enable pin.
} sci_uart_rs485_setting_t;
/** UART on SCIF device Configuration */
typedef struct st_scif_uart_extended_cfg
{
uint8_t bri_ipl; ///< Break interrupt priority
IRQn_Type bri_irq; ///< Break interrupt IRQ number
scif_clk_src_t clock; ///< The source clock for the baud-rate generator.
scif_uart_noise_cancellation_t noise_cancel; ///< Noise cancellation setting
scif_baud_setting_t * p_baud_setting; ///< Register settings for a desired baud rate.
scif_uart_receive_trigger_t rx_fifo_trigger; ///< Receive FIFO trigger level.
scif_uart_rts_trigger_t rts_fifo_trigger; ///< RTS trigger level.
scif_uart_mode_t uart_mode; ///< UART communication mode selection
scif_uart_flow_control_t flow_control; ///< CTS/RTS function
sci_uart_rs485_setting_t rs485_setting; ///< RS-485 settings.
} scif_uart_extended_cfg_t;
/**********************************************************************************************************************
* Exported global variables
**********************************************************************************************************************/
/** @cond INC_HEADER_DEFS_SEC */
/** Filled in Interface API structure for this Instance. */
extern const uart_api_t g_uart_on_scif;
/** @endcond */
fsp_err_t R_SCIF_UART_Open(uart_ctrl_t * const p_api_ctrl, uart_cfg_t const * const p_cfg);
fsp_err_t R_SCIF_UART_Read(uart_ctrl_t * const p_api_ctrl, uint8_t * const p_dest, uint32_t const bytes);
fsp_err_t R_SCIF_UART_Write(uart_ctrl_t * const p_api_ctrl, uint8_t const * const p_src, uint32_t const bytes);
fsp_err_t R_SCIF_UART_BaudSet(uart_ctrl_t * const p_api_ctrl, void const * const p_baud_setting);
fsp_err_t R_SCIF_UART_InfoGet(uart_ctrl_t * const p_api_ctrl, uart_info_t * const p_info);
fsp_err_t R_SCIF_UART_Close(uart_ctrl_t * const p_api_ctrl);
fsp_err_t R_SCIF_UART_Abort(uart_ctrl_t * const p_api_ctrl, uart_dir_t communication_to_abort);
fsp_err_t R_SCIF_UART_BaudCalculate(uart_ctrl_t * const p_api_ctrl,
uint32_t baudrate,
bool bitrate_modulation,
uint32_t baud_rate_error_x_1000,
scif_baud_setting_t * const p_baud_setting);
fsp_err_t R_SCIF_UART_CallbackSet(uart_ctrl_t * const p_api_ctrl,
void ( * p_callback)(uart_callback_args_t * p_arg),
void const * const p_context,
uart_callback_args_t * const p_callback_memory);
fsp_err_t R_SCIF_UART_ReadStop(uart_ctrl_t * const p_api_ctrl, uint32_t * remaining_bytes);
/*******************************************************************************************************************//**
* @} (end addtogroup SCIF_UART)
**********************************************************************************************************************/
/* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
FSP_FOOTER
#endif /* R_SCIF_UART_H */

View File

@ -0,0 +1,157 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/*
* @file R9A07G043U.h
* @brief CMSIS HeaderFile
*/
/** @addtogroup Renesas
* @{
*/
/** @addtogroup R9A07G043U
* @{
*/
#ifndef R9A07G043U_H
#define R9A07G043U_H
#ifdef __cplusplus
extern "C" {
#endif
/** @addtogroup Configuration_of_CMSIS
* @{
*/
/* =========================================================================================================================== */
/* ================ Interrupt Number Definition ================ */
/* =========================================================================================================================== */
/* =========================================================================================================================== */
/* ================ Processor and Core Peripheral Section ================ */
/* =========================================================================================================================== */
/* ========================== Configuration of the ARM Cortex-M33 Processor and Core Peripherals =========================== */
#define __CM33_REV 0x0004U /*!< CM33 Core Revision */
#define __NVIC_PRIO_BITS 7 /*!< Number of Bits used for Priority Levels */
#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */
#define __VTOR_PRESENT 1 /*!< Set to 1 if CPU supports Vector Table Offset Register */
#define __MPU_PRESENT 1 /*!< MPU present */
#define __FPU_PRESENT 0 /*!< FPU present */
#define __FPU_DP 0 /*!< Double Precision FPU */
#define __DSP_PRESENT 0 /*!< DSP extension present */
#define __SAUREGION_PRESENT 0 /*!< SAU region present */
/** @} */ /* End of group Configuration_of_CMSIS */
#include "core_cm33.h" /*!< ARM Cortex-M33 processor and core peripherals */
#include "system.h" /*!< R9A07G043U System */
#ifndef __IM /*!< Fallback for older CMSIS versions */
#define __IM __I
#endif
#ifndef __OM /*!< Fallback for older CMSIS versions */
#define __OM __O
#endif
#ifndef __IOM /*!< Fallback for older CMSIS versions */
#define __IOM __IO
#endif
/* ======================================== Start of section using anonymous unions ======================================== */
#if defined(__CC_ARM)
#pragma push
#pragma anon_unions
#elif defined(__ICCARM__)
#pragma language=extended
#elif defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wc11-extensions"
#pragma clang diagnostic ignored "-Wreserved-id-macro"
#pragma clang diagnostic ignored "-Wgnu-anonymous-struct"
#pragma clang diagnostic ignored "-Wnested-anon-types"
#elif defined(__GNUC__)
/* anonymous unions are enabled by default */
#elif defined(__TMS470__)
/* anonymous unions are enabled by default */
#elif defined(__TASKING__)
#pragma warning 586
#elif defined(__CSMC__)
/* anonymous unions are enabled by default */
#else
#warning Not supported compiler type
#endif
/* =========================================================================================================================== */
/* ================ Device Specific Cluster Section ================ */
/* =========================================================================================================================== */
/** @addtogroup Device_Peripheral_clusters
* @{
*/
#include "R9A07G043U/iodefine.h"
/** @} */ /* End of group Device_Peripheral_clusters */
/* ========================================= End of section using anonymous unions =============================== */
#if defined(__CC_ARM)
#pragma pop
#elif defined(__ICCARM__)
/* leave anonymous unions enabled */
#elif defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
#pragma clang diagnostic pop
#elif defined(__GNUC__)
/* anonymous unions are enabled by default */
#elif defined(__TMS470__)
/* anonymous unions are enabled by default */
#elif defined(__TASKING__)
#pragma warning restore
#elif defined(__CSMC__)
/* anonymous unions are enabled by default */
#endif
/* =========================================================================================================================== */
/* ================ Pos/Mask Cluster Section ================ */
/* =========================================================================================================================== */
/** @addtogroup PosMask_clusters
* @{
*/
#include "R9A07G043U/iobitmask.h"
/** @} */ /* End of group PosMask_clusters */
#ifdef __cplusplus
}
#endif
#endif /* R9A07G043U_H */
/** @} */ /* End of group R9A07G043U */
/** @} */ /* End of group Renesas */

View File

@ -0,0 +1,54 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : iobitmask.h
* Version : 1.00
* Description : iobitmask header
*********************************************************************************************************************/
#ifndef __IOBITMASK_HEADER__
#define __IOBITMASK_HEADER__
#include "iobitmasks/adc_c_iobitmask.h"
#include "iobitmasks/cpg_iobitmask.h"
#include "iobitmasks/canfd_iobitmask.h"
#include "iobitmasks/dmac_b_iobitmask.h"
#include "iobitmasks/gpio_iobitmask.h"
#include "iobitmasks/gpt_iobitmask.h"
#include "iobitmasks/gtm_iobitmask.h"
#include "iobitmasks/intc_im33_iobitmask.h"
#include "iobitmasks/mhu_iobitmask.h"
#include "iobitmasks/poeg_iobitmask.h"
#include "iobitmasks/riic_iobitmask.h"
#include "iobitmasks/rspi_iobitmask.h"
#include "iobitmasks/scifa_iobitmask.h"
#include "iobitmasks/spibsc_iobitmask.h"
#include "iobitmasks/ssi_iobitmask.h"
#include "iobitmasks/sysc_iobitmask.h"
#include "iobitmasks/tsu_iobitmask.h"
#include "iobitmasks/wdt_iobitmask.h"
#include "iobitmasks/mtu_iobitmask.h"
#ifdef BSP_OVERRIDE_MASK_HEADER_IOPORT
#include BSP_OVERRIDE_MASK_HEADER_IOPORT
#endif
#endif /* __IOBITMASK_HEADER__ */

View File

@ -0,0 +1,271 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : adc_c_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for adc_c.
*********************************************************************************************************************/
#ifndef ADC_C_IOBITMASK_H
#define ADC_C_IOBITMASK_H
#define R_ADC_C_ADM0_ADCE_Msk (0x00000001UL)
#define R_ADC_C_ADM0_ADCE_Pos (0UL)
#define R_ADC_C_ADM0_ADBSY_Msk (0x00000002UL)
#define R_ADC_C_ADM0_ADBSY_Pos (1UL)
#define R_ADC_C_ADM0_PWDWNB_Msk (0x00000004UL)
#define R_ADC_C_ADM0_PWDWNB_Pos (2UL)
#define R_ADC_C_ADM0_SRESB_Msk (0x00008000UL)
#define R_ADC_C_ADM0_SRESB_Pos (15UL)
#define R_ADC_C_ADM1_TRG_Msk (0x00000001UL)
#define R_ADC_C_ADM1_TRG_Pos (0UL)
#define R_ADC_C_ADM1_TRGIN_Msk (0x00000002UL)
#define R_ADC_C_ADM1_TRGIN_Pos (1UL)
#define R_ADC_C_ADM1_MS_Msk (0x00000004UL)
#define R_ADC_C_ADM1_MS_Pos (2UL)
#define R_ADC_C_ADM1_RPS_Msk (0x00000008UL)
#define R_ADC_C_ADM1_RPS_Pos (3UL)
#define R_ADC_C_ADM1_BS_Msk (0x00000010UL)
#define R_ADC_C_ADM1_BS_Pos (4UL)
#define R_ADC_C_ADM1_EGA_Msk (0x00003000UL)
#define R_ADC_C_ADM1_EGA_Pos (12UL)
#define R_ADC_C_ADM1_TRGEN_Msk (0x003F0000UL)
#define R_ADC_C_ADM1_TRGEN_Pos (16UL)
#define R_ADC_C_ADM2_CHSEL_Msk (0x000001FFUL)
#define R_ADC_C_ADM2_CHSEL_Pos (0UL)
#define R_ADC_C_ADM3_ADSMP_Msk (0x000000FFUL)
#define R_ADC_C_ADM3_ADSMP_Pos (0UL)
#define R_ADC_C_ADM3_ADCMP_Msk (0x00FF0000UL)
#define R_ADC_C_ADM3_ADCMP_Pos (16UL)
#define R_ADC_C_ADM3_ADIL_Msk (0xFF000000UL)
#define R_ADC_C_ADM3_ADIL_Pos (24UL)
#define R_ADC_C_ADINT_INTEN_Msk (0x00000FFFUL)
#define R_ADC_C_ADINT_INTEN_Pos (0UL)
#define R_ADC_C_ADINT_CSEEN_Msk (0x00010000UL)
#define R_ADC_C_ADINT_CSEEN_Pos (16UL)
#define R_ADC_C_ADINT_INTS_Msk (0x80000000UL)
#define R_ADC_C_ADINT_INTS_Pos (31UL)
#define R_ADC_C_ADSTS_INTST_Msk (0x000001FFUL)
#define R_ADC_C_ADSTS_INTST_Pos (0UL)
#define R_ADC_C_ADSTS_CSEST_Msk (0x00010000UL)
#define R_ADC_C_ADSTS_CSEST_Pos (16UL)
#define R_ADC_C_ADSTS_TRGS_Msk (0x80000000UL)
#define R_ADC_C_ADSTS_TRGS_Pos (31UL)
#define R_ADC_C_ADIVC_DIVADC_Msk (0x000001FFUL)
#define R_ADC_C_ADIVC_DIVADC_Pos (0UL)
#define R_ADC_C_ADFIL_FILONOFF_Msk (0x00000001UL)
#define R_ADC_C_ADFIL_FILONOFF_Pos (0UL)
#define R_ADC_C_ADFIL_FILNUM_Msk (0x00000030UL)
#define R_ADC_C_ADFIL_FILNUM_Pos (4UL)
#define R_ADC_C_ADCR0_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR0_AD0_Pos (0UL)
#define R_ADC_C_ADCR0_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR0_AD1_Pos (1UL)
#define R_ADC_C_ADCR0_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR0_AD2_Pos (2UL)
#define R_ADC_C_ADCR0_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR0_AD3_Pos (3UL)
#define R_ADC_C_ADCR0_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR0_AD4_Pos (4UL)
#define R_ADC_C_ADCR0_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR0_AD5_Pos (5UL)
#define R_ADC_C_ADCR0_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR0_AD6_Pos (6UL)
#define R_ADC_C_ADCR0_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR0_AD7_Pos (7UL)
#define R_ADC_C_ADCR0_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR0_AD8_Pos (8UL)
#define R_ADC_C_ADCR0_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR0_AD9_Pos (9UL)
#define R_ADC_C_ADCR0_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR0_AD10_Pos (10UL)
#define R_ADC_C_ADCR0_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR0_AD11_Pos (11UL)
#define R_ADC_C_ADCR1_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR1_AD0_Pos (0UL)
#define R_ADC_C_ADCR1_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR1_AD1_Pos (1UL)
#define R_ADC_C_ADCR1_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR1_AD2_Pos (2UL)
#define R_ADC_C_ADCR1_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR1_AD3_Pos (3UL)
#define R_ADC_C_ADCR1_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR1_AD4_Pos (4UL)
#define R_ADC_C_ADCR1_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR1_AD5_Pos (5UL)
#define R_ADC_C_ADCR1_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR1_AD6_Pos (6UL)
#define R_ADC_C_ADCR1_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR1_AD7_Pos (7UL)
#define R_ADC_C_ADCR1_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR1_AD8_Pos (8UL)
#define R_ADC_C_ADCR1_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR1_AD9_Pos (9UL)
#define R_ADC_C_ADCR1_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR1_AD10_Pos (10UL)
#define R_ADC_C_ADCR1_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR1_AD11_Pos (11UL)
#define R_ADC_C_ADCR2_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR2_AD0_Pos (0UL)
#define R_ADC_C_ADCR2_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR2_AD1_Pos (1UL)
#define R_ADC_C_ADCR2_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR2_AD2_Pos (2UL)
#define R_ADC_C_ADCR2_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR2_AD3_Pos (3UL)
#define R_ADC_C_ADCR2_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR2_AD4_Pos (4UL)
#define R_ADC_C_ADCR2_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR2_AD5_Pos (5UL)
#define R_ADC_C_ADCR2_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR2_AD6_Pos (6UL)
#define R_ADC_C_ADCR2_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR2_AD7_Pos (7UL)
#define R_ADC_C_ADCR2_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR2_AD8_Pos (8UL)
#define R_ADC_C_ADCR2_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR2_AD9_Pos (9UL)
#define R_ADC_C_ADCR2_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR2_AD10_Pos (10UL)
#define R_ADC_C_ADCR2_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR2_AD11_Pos (11UL)
#define R_ADC_C_ADCR3_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR3_AD0_Pos (0UL)
#define R_ADC_C_ADCR3_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR3_AD1_Pos (1UL)
#define R_ADC_C_ADCR3_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR3_AD2_Pos (2UL)
#define R_ADC_C_ADCR3_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR3_AD3_Pos (3UL)
#define R_ADC_C_ADCR3_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR3_AD4_Pos (4UL)
#define R_ADC_C_ADCR3_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR3_AD5_Pos (5UL)
#define R_ADC_C_ADCR3_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR3_AD6_Pos (6UL)
#define R_ADC_C_ADCR3_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR3_AD7_Pos (7UL)
#define R_ADC_C_ADCR3_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR3_AD8_Pos (8UL)
#define R_ADC_C_ADCR3_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR3_AD9_Pos (9UL)
#define R_ADC_C_ADCR3_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR3_AD10_Pos (10UL)
#define R_ADC_C_ADCR3_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR3_AD11_Pos (11UL)
#define R_ADC_C_ADCR4_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR4_AD0_Pos (0UL)
#define R_ADC_C_ADCR4_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR4_AD1_Pos (1UL)
#define R_ADC_C_ADCR4_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR4_AD2_Pos (2UL)
#define R_ADC_C_ADCR4_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR4_AD3_Pos (3UL)
#define R_ADC_C_ADCR4_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR4_AD4_Pos (4UL)
#define R_ADC_C_ADCR4_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR4_AD5_Pos (5UL)
#define R_ADC_C_ADCR4_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR4_AD6_Pos (6UL)
#define R_ADC_C_ADCR4_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR4_AD7_Pos (7UL)
#define R_ADC_C_ADCR4_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR4_AD8_Pos (8UL)
#define R_ADC_C_ADCR4_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR4_AD9_Pos (9UL)
#define R_ADC_C_ADCR4_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR4_AD10_Pos (10UL)
#define R_ADC_C_ADCR4_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR4_AD11_Pos (11UL)
#define R_ADC_C_ADCR5_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR5_AD0_Pos (0UL)
#define R_ADC_C_ADCR5_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR5_AD1_Pos (1UL)
#define R_ADC_C_ADCR5_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR5_AD2_Pos (2UL)
#define R_ADC_C_ADCR5_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR5_AD3_Pos (3UL)
#define R_ADC_C_ADCR5_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR5_AD4_Pos (4UL)
#define R_ADC_C_ADCR5_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR5_AD5_Pos (5UL)
#define R_ADC_C_ADCR5_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR5_AD6_Pos (6UL)
#define R_ADC_C_ADCR5_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR5_AD7_Pos (7UL)
#define R_ADC_C_ADCR5_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR5_AD8_Pos (8UL)
#define R_ADC_C_ADCR5_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR5_AD9_Pos (9UL)
#define R_ADC_C_ADCR5_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR5_AD10_Pos (10UL)
#define R_ADC_C_ADCR5_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR5_AD11_Pos (11UL)
#define R_ADC_C_ADCR6_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR6_AD0_Pos (0UL)
#define R_ADC_C_ADCR6_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR6_AD1_Pos (1UL)
#define R_ADC_C_ADCR6_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR6_AD2_Pos (2UL)
#define R_ADC_C_ADCR6_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR6_AD3_Pos (3UL)
#define R_ADC_C_ADCR6_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR6_AD4_Pos (4UL)
#define R_ADC_C_ADCR6_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR6_AD5_Pos (5UL)
#define R_ADC_C_ADCR6_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR6_AD6_Pos (6UL)
#define R_ADC_C_ADCR6_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR6_AD7_Pos (7UL)
#define R_ADC_C_ADCR6_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR6_AD8_Pos (8UL)
#define R_ADC_C_ADCR6_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR6_AD9_Pos (9UL)
#define R_ADC_C_ADCR6_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR6_AD10_Pos (10UL)
#define R_ADC_C_ADCR6_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR6_AD11_Pos (11UL)
#define R_ADC_C_ADCR7_AD0_Msk (0x00000001UL)
#define R_ADC_C_ADCR7_AD0_Pos (0UL)
#define R_ADC_C_ADCR7_AD1_Msk (0x00000002UL)
#define R_ADC_C_ADCR7_AD1_Pos (1UL)
#define R_ADC_C_ADCR7_AD2_Msk (0x00000004UL)
#define R_ADC_C_ADCR7_AD2_Pos (2UL)
#define R_ADC_C_ADCR7_AD3_Msk (0x00000008UL)
#define R_ADC_C_ADCR7_AD3_Pos (3UL)
#define R_ADC_C_ADCR7_AD4_Msk (0x00000010UL)
#define R_ADC_C_ADCR7_AD4_Pos (4UL)
#define R_ADC_C_ADCR7_AD5_Msk (0x00000020UL)
#define R_ADC_C_ADCR7_AD5_Pos (5UL)
#define R_ADC_C_ADCR7_AD6_Msk (0x00000040UL)
#define R_ADC_C_ADCR7_AD6_Pos (6UL)
#define R_ADC_C_ADCR7_AD7_Msk (0x00000080UL)
#define R_ADC_C_ADCR7_AD7_Pos (7UL)
#define R_ADC_C_ADCR7_AD8_Msk (0x00000100UL)
#define R_ADC_C_ADCR7_AD8_Pos (8UL)
#define R_ADC_C_ADCR7_AD9_Msk (0x00000200UL)
#define R_ADC_C_ADCR7_AD9_Pos (9UL)
#define R_ADC_C_ADCR7_AD10_Msk (0x00000400UL)
#define R_ADC_C_ADCR7_AD10_Pos (10UL)
#define R_ADC_C_ADCR7_AD11_Msk (0x00000800UL)
#define R_ADC_C_ADCR7_AD11_Pos (11UL)
#endif

View File

@ -0,0 +1,697 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : canfd_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for canfd.
*********************************************************************************************************************/
#ifndef CANFD_IOBITMASK_H
#define CANFD_IOBITMASK_H
/* ========================================================= NCFG ========================================================== */
#define R_CANFD_CFDC_NCFG_NBRP_Pos (0UL) /*!< NBRP (Bit 0) */
#define R_CANFD_CFDC_NCFG_NBRP_Msk (0x3ffUL) /*!< NBRP (Bitfield-Mask: 0x3ff) */
#define R_CANFD_CFDC_NCFG_NSJW_Pos (11UL) /*!< NSJW (Bit 10) */
#define R_CANFD_CFDC_NCFG_NSJW_Msk (0x1fc00UL) /*!< NSJW (Bitfield-Mask: 0x7f) */
#define R_CANFD_CFDC_NCFG_NTSEG1_Pos (16UL) /*!< NTSEG1 (Bit 17) */
#define R_CANFD_CFDC_NCFG_NTSEG1_Msk (0x1fe0000UL) /*!< NTSEG1 (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDC_NCFG_NTSEG2_Pos (24UL) /*!< NTSEG2 (Bit 25) */
#define R_CANFD_CFDC_NCFG_NTSEG2_Msk (0xfe000000UL) /*!< NTSEG2 (Bitfield-Mask: 0x7f) */
/* ========================================================== CTR ========================================================== */
#define R_CANFD_CFDC_CTR_CHMDC_Pos (0UL) /*!< CHMDC (Bit 0) */
#define R_CANFD_CFDC_CTR_CHMDC_Msk (0x3UL) /*!< CHMDC (Bitfield-Mask: 0x03) */
#define R_CANFD_CFDC_CTR_CSLPR_Pos (2UL) /*!< CSLPR (Bit 2) */
#define R_CANFD_CFDC_CTR_CSLPR_Msk (0x4UL) /*!< CSLPR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_RTBO_Pos (3UL) /*!< RTBO (Bit 3) */
#define R_CANFD_CFDC_CTR_RTBO_Msk (0x8UL) /*!< RTBO (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_BEIE_Pos (8UL) /*!< BEIE (Bit 8) */
#define R_CANFD_CFDC_CTR_BEIE_Msk (0x100UL) /*!< BEIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_EWIE_Pos (9UL) /*!< EWIE (Bit 9) */
#define R_CANFD_CFDC_CTR_EWIE_Msk (0x200UL) /*!< EWIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_EPIE_Pos (10UL) /*!< EPIE (Bit 10) */
#define R_CANFD_CFDC_CTR_EPIE_Msk (0x400UL) /*!< EPIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_BOEIE_Pos (11UL) /*!< BOEIE (Bit 11) */
#define R_CANFD_CFDC_CTR_BOEIE_Msk (0x800UL) /*!< BOEIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_BORIE_Pos (12UL) /*!< BORIE (Bit 12) */
#define R_CANFD_CFDC_CTR_BORIE_Msk (0x1000UL) /*!< BORIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_OLIE_Pos (13UL) /*!< OLIE (Bit 13) */
#define R_CANFD_CFDC_CTR_OLIE_Msk (0x2000UL) /*!< OLIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_BLIE_Pos (14UL) /*!< BLIE (Bit 14) */
#define R_CANFD_CFDC_CTR_BLIE_Msk (0x4000UL) /*!< BLIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_ALIE_Pos (15UL) /*!< ALIE (Bit 15) */
#define R_CANFD_CFDC_CTR_ALIE_Msk (0x8000UL) /*!< ALIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_TAIE_Pos (16UL) /*!< TAIE (Bit 16) */
#define R_CANFD_CFDC_CTR_TAIE_Msk (0x10000UL) /*!< TAIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_EOCOIE_Pos (17UL) /*!< EOCOIE (Bit 17) */
#define R_CANFD_CFDC_CTR_EOCOIE_Msk (0x20000UL) /*!< EOCOIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_SOCOIE_Pos (18UL) /*!< SOCOIE (Bit 18) */
#define R_CANFD_CFDC_CTR_SOCOIE_Msk (0x40000UL) /*!< SOCOIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_TDCVFIE_Pos (19UL) /*!< TDCVFIE (Bit 19) */
#define R_CANFD_CFDC_CTR_TDCVFIE_Msk (0x80000UL) /*!< TDCVFIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_BOM_Pos (21UL) /*!< BOM (Bit 21) */
#define R_CANFD_CFDC_CTR_BOM_Msk (0x600000UL) /*!< BOM (Bitfield-Mask: 0x03) */
#define R_CANFD_CFDC_CTR_ERRD_Pos (23UL) /*!< ERRD (Bit 23) */
#define R_CANFD_CFDC_CTR_ERRD_Msk (0x800000UL) /*!< ERRD (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_CTME_Pos (24UL) /*!< CTME (Bit 24) */
#define R_CANFD_CFDC_CTR_CTME_Msk (0x1000000UL) /*!< CTME (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_CTMS_Pos (25UL) /*!< CTMS (Bit 25) */
#define R_CANFD_CFDC_CTR_CTMS_Msk (0x6000000UL) /*!< CTMS (Bitfield-Mask: 0x03) */
#define R_CANFD_CFDC_CTR_CRCT_Pos (30UL) /*!< CRCT (Bit 30) */
#define R_CANFD_CFDC_CTR_CRCT_Msk (0x40000000UL) /*!< CRCT (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_CTR_ROM_Pos (31UL) /*!< ROM (Bit 31) */
#define R_CANFD_CFDC_CTR_ROM_Msk (0x80000000UL) /*!< ROM (Bitfield-Mask: 0x01) */
/* ========================================================== STS ========================================================== */
#define R_CANFD_CFDC_STS_CRSTSTS_Pos (0UL) /*!< CRSTSTS (Bit 0) */
#define R_CANFD_CFDC_STS_CRSTSTS_Msk (0x1UL) /*!< CRSTSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_CHLTSTS_Pos (1UL) /*!< CHLTSTS (Bit 1) */
#define R_CANFD_CFDC_STS_CHLTSTS_Msk (0x2UL) /*!< CHLTSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_CSLPSTS_Pos (2UL) /*!< CSLPSTS (Bit 2) */
#define R_CANFD_CFDC_STS_CSLPSTS_Msk (0x4UL) /*!< CSLPSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_EPSTS_Pos (3UL) /*!< EPSTS (Bit 3) */
#define R_CANFD_CFDC_STS_EPSTS_Msk (0x8UL) /*!< EPSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_BOSTS_Pos (4UL) /*!< BOSTS (Bit 4) */
#define R_CANFD_CFDC_STS_BOSTS_Msk (0x10UL) /*!< BOSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_TRMSTS_Pos (5UL) /*!< TRMSTS (Bit 5) */
#define R_CANFD_CFDC_STS_TRMSTS_Msk (0x20UL) /*!< TRMSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_RECSTS_Pos (6UL) /*!< RECSTS (Bit 6) */
#define R_CANFD_CFDC_STS_RECSTS_Msk (0x40UL) /*!< RECSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_COMSTS_Pos (7UL) /*!< COMSTS (Bit 7) */
#define R_CANFD_CFDC_STS_COMSTS_Msk (0x80UL) /*!< COMSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_ESIF_Pos (8UL) /*!< ESIF (Bit 8) */
#define R_CANFD_CFDC_STS_ESIF_Msk (0x100UL) /*!< ESIF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_STS_REC_Pos (16UL) /*!< REC (Bit 16) */
#define R_CANFD_CFDC_STS_REC_Msk (0xff0000UL) /*!< REC (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDC_STS_TEC_Pos (24UL) /*!< TEC (Bit 24) */
#define R_CANFD_CFDC_STS_TEC_Msk (0xff000000UL) /*!< TEC (Bitfield-Mask: 0xff) */
/* ========================================================= ERFL ========================================================== */
#define R_CANFD_CFDC_ERFL_BEF_Pos (0UL) /*!< BEF (Bit 0) */
#define R_CANFD_CFDC_ERFL_BEF_Msk (0x1UL) /*!< BEF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_EWF_Pos (1UL) /*!< EWF (Bit 1) */
#define R_CANFD_CFDC_ERFL_EWF_Msk (0x2UL) /*!< EWF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_EPF_Pos (2UL) /*!< EPF (Bit 2) */
#define R_CANFD_CFDC_ERFL_EPF_Msk (0x4UL) /*!< EPF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_BOEF_Pos (3UL) /*!< BOEF (Bit 3) */
#define R_CANFD_CFDC_ERFL_BOEF_Msk (0x8UL) /*!< BOEF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_BORF_Pos (4UL) /*!< BORF (Bit 4) */
#define R_CANFD_CFDC_ERFL_BORF_Msk (0x10UL) /*!< BORF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_OVLF_Pos (5UL) /*!< OVLF (Bit 5) */
#define R_CANFD_CFDC_ERFL_OVLF_Msk (0x20UL) /*!< OVLF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_BLF_Pos (6UL) /*!< BLF (Bit 6) */
#define R_CANFD_CFDC_ERFL_BLF_Msk (0x40UL) /*!< BLF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_ALF_Pos (7UL) /*!< ALF (Bit 7) */
#define R_CANFD_CFDC_ERFL_ALF_Msk (0x80UL) /*!< ALF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_SERR_Pos (8UL) /*!< SERR (Bit 8) */
#define R_CANFD_CFDC_ERFL_SERR_Msk (0x100UL) /*!< SERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_FERR_Pos (9UL) /*!< FERR (Bit 9) */
#define R_CANFD_CFDC_ERFL_FERR_Msk (0x200UL) /*!< FERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_AERR_Pos (10UL) /*!< AERR (Bit 10) */
#define R_CANFD_CFDC_ERFL_AERR_Msk (0x400UL) /*!< AERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_CERR_Pos (11UL) /*!< CERR (Bit 11) */
#define R_CANFD_CFDC_ERFL_CERR_Msk (0x800UL) /*!< CERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_B1ERR_Pos (12UL) /*!< B1ERR (Bit 12) */
#define R_CANFD_CFDC_ERFL_B1ERR_Msk (0x1000UL) /*!< B1ERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_B0ERR_Pos (13UL) /*!< B0ERR (Bit 13) */
#define R_CANFD_CFDC_ERFL_B0ERR_Msk (0x2000UL) /*!< B0ERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_ADERR_Pos (14UL) /*!< ADERR (Bit 14) */
#define R_CANFD_CFDC_ERFL_ADERR_Msk (0x4000UL) /*!< ADERR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC_ERFL_CRCREG_Pos (16UL) /*!< CRCREG (Bit 16) */
#define R_CANFD_CFDC_ERFL_CRCREG_Msk (0x7fff0000UL) /*!< CRCREG (Bitfield-Mask: 0x7fff) */
/* =========================================================================================================================== */
/* ================ CFDC2 ================ */
/* =========================================================================================================================== */
/* ========================================================= DCFG ========================================================== */
#define R_CANFD_CFDC2_DCFG_DBRP_Pos (0UL) /*!< DBRP (Bit 0) */
#define R_CANFD_CFDC2_DCFG_DBRP_Msk (0xffUL) /*!< DBRP (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDC2_DCFG_DTSEG1_Pos (16UL) /*!< DTSEG1 (Bit 8) */
#define R_CANFD_CFDC2_DCFG_DTSEG1_Msk (0x1f00UL) /*!< DTSEG1 (Bitfield-Mask: 0x1f) */
#define R_CANFD_CFDC2_DCFG_DTSEG2_Pos (20UL) /*!< DTSEG2 (Bit 16) */
#define R_CANFD_CFDC2_DCFG_DTSEG2_Msk (0x70000UL) /*!< DTSEG2 (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDC2_DCFG_DSJW_Pos (24UL) /*!< DSJW (Bit 24) */
#define R_CANFD_CFDC2_DCFG_DSJW_Msk (0x7000000UL) /*!< DSJW (Bitfield-Mask: 0x07) */
/* ========================================================= FDCFG ========================================================= */
#define R_CANFD_CFDC2_FDCFG_EOCCFG_Pos (0UL) /*!< EOCCFG (Bit 0) */
#define R_CANFD_CFDC2_FDCFG_EOCCFG_Msk (0x7UL) /*!< EOCCFG (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDC2_FDCFG_TDCOC_Pos (8UL) /*!< TDCOC (Bit 8) */
#define R_CANFD_CFDC2_FDCFG_TDCOC_Msk (0x100UL) /*!< TDCOC (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_TDCE_Pos (9UL) /*!< TDCE (Bit 9) */
#define R_CANFD_CFDC2_FDCFG_TDCE_Msk (0x200UL) /*!< TDCE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_ESIC_Pos (10UL) /*!< ESIC (Bit 10) */
#define R_CANFD_CFDC2_FDCFG_ESIC_Msk (0x400UL) /*!< ESIC (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_TDCO_Pos (16UL) /*!< TDCO (Bit 16) */
#define R_CANFD_CFDC2_FDCFG_TDCO_Msk (0x7f0000UL) /*!< TDCO (Bitfield-Mask: 0x7f) */
#define R_CANFD_CFDC2_FDCFG_GWEN_Pos (24UL) /*!< GWEN (Bit 24) */
#define R_CANFD_CFDC2_FDCFG_GWEN_Msk (0x1000000UL) /*!< GWEN (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_GWFDF_Pos (25UL) /*!< GWFDF (Bit 25) */
#define R_CANFD_CFDC2_FDCFG_GWFDF_Msk (0x2000000UL) /*!< GWFDF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_GWBRS_Pos (26UL) /*!< GWBRS (Bit 26) */
#define R_CANFD_CFDC2_FDCFG_GWBRS_Msk (0x4000000UL) /*!< GWBRS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_TMME_Pos (27UL) /*!< TMME (Bit 27) */
#define R_CANFD_CFDC2_FDCFG_TMME_Msk (0x8000000UL) /*!< TMME (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_FDOE_Pos (28UL) /*!< FDOE (Bit 28) */
#define R_CANFD_CFDC2_FDCFG_FDOE_Msk (0x10000000UL) /*!< FDOE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCFG_REFE_Pos (29UL) /*!< REFE (Bit 29) */
#define R_CANFD_CFDC2_FDCFG_REFE_Msk (0x20000000UL) /*!< REFE (Bitfield-Mask: 0x01) */
/* ========================================================= FDCTR ========================================================= */
#define R_CANFD_CFDC2_FDCTR_EOCCLR_Pos (0UL) /*!< EOCCLR (Bit 0) */
#define R_CANFD_CFDC2_FDCTR_EOCCLR_Msk (0x1UL) /*!< EOCCLR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDCTR_SOCCLR_Pos (1UL) /*!< SOCCLR (Bit 1) */
#define R_CANFD_CFDC2_FDCTR_SOCCLR_Msk (0x2UL) /*!< SOCCLR (Bitfield-Mask: 0x01) */
/* ========================================================= FDSTS ========================================================= */
#define R_CANFD_CFDC2_FDSTS_TDCR_Pos (0UL) /*!< TDCR (Bit 0) */
#define R_CANFD_CFDC2_FDSTS_TDCR_Msk (0xffUL) /*!< TDCR (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDC2_FDSTS_TDCVF_Pos (7UL) /*!< TDCVF (Bit 7) */
#define R_CANFD_CFDC2_FDSTS_TDCVF_Msk (0x80UL) /*!< TDCVF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDSTS_EOCO_Pos (8UL) /*!< EOCO (Bit 8) */
#define R_CANFD_CFDC2_FDSTS_EOCO_Msk (0x100UL) /*!< EOCO (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDSTS_SOCO_Pos (9UL) /*!< SOCO (Bit 9) */
#define R_CANFD_CFDC2_FDSTS_SOCO_Msk (0x200UL) /*!< SOCO (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDC2_FDSTS_EOC_Pos (16UL) /*!< EOC (Bit 16) */
#define R_CANFD_CFDC2_FDSTS_EOC_Msk (0xff0000UL) /*!< EOC (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDC2_FDSTS_SOC_Pos (24UL) /*!< SOC (Bit 24) */
#define R_CANFD_CFDC2_FDSTS_SOC_Msk (0xff000000UL) /*!< SOC (Bitfield-Mask: 0xff) */
/* ========================================================= FDCRC ========================================================= */
#define R_CANFD_CFDC2_FDCRC_CRCREG_Pos (0UL) /*!< CRCREG (Bit 0) */
#define R_CANFD_CFDC2_FDCRC_CRCREG_Msk (0x1fffffUL) /*!< CRCREG (Bitfield-Mask: 0x1fffff) */
#define R_CANFD_CFDC2_FDCRC_SCNT_Pos (24UL) /*!< SCNT (Bit 24) */
#define R_CANFD_CFDC2_FDCRC_SCNT_Msk (0xf000000UL) /*!< SCNT (Bitfield-Mask: 0x0f) */
/* =========================================================================================================================== */
/* ================ CFDGAFL ================ */
/* =========================================================================================================================== */
/* ========================================================== ID =========================================================== */
#define R_CANFD_CFDGAFL_ID_GAFLID_Pos (0UL) /*!< GAFLID (Bit 0) */
#define R_CANFD_CFDGAFL_ID_GAFLID_Msk (0x1fffffffUL) /*!< GAFLID (Bitfield-Mask: 0x1fffffff) */
#define R_CANFD_CFDGAFL_ID_GAFLLB_Pos (29UL) /*!< GAFLLB (Bit 29) */
#define R_CANFD_CFDGAFL_ID_GAFLLB_Msk (0x20000000UL) /*!< GAFLLB (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGAFL_ID_GAFLRTR_Pos (30UL) /*!< GAFLRTR (Bit 30) */
#define R_CANFD_CFDGAFL_ID_GAFLRTR_Msk (0x40000000UL) /*!< GAFLRTR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGAFL_ID_GAFLIDE_Pos (31UL) /*!< GAFLIDE (Bit 31) */
#define R_CANFD_CFDGAFL_ID_GAFLIDE_Msk (0x80000000UL) /*!< GAFLIDE (Bitfield-Mask: 0x01) */
/* =========================================================== M =========================================================== */
#define R_CANFD_CFDGAFL_M_GAFLIDM_Pos (0UL) /*!< GAFLIDM (Bit 0) */
#define R_CANFD_CFDGAFL_M_GAFLIDM_Msk (0x1fffffffUL) /*!< GAFLIDM (Bitfield-Mask: 0x1fffffff) */
#define R_CANFD_CFDGAFL_M_GAFLRTRM_Pos (30UL) /*!< GAFLRTRM (Bit 30) */
#define R_CANFD_CFDGAFL_M_GAFLRTRM_Msk (0x40000000UL) /*!< GAFLRTRM (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGAFL_M_GAFLIDEM_Pos (31UL) /*!< GAFLIDEM (Bit 31) */
#define R_CANFD_CFDGAFL_M_GAFLIDEM_Msk (0x80000000UL) /*!< GAFLIDEM (Bitfield-Mask: 0x01) */
/* ========================================================== P0 =========================================================== */
#define R_CANFD_CFDGAFL_P0_GAFLRMDP_Pos (8UL) /*!< GAFLRMDP (Bit 8) */
#define R_CANFD_CFDGAFL_P0_GAFLRMDP_Msk (0x7f00UL) /*!< GAFLRMDP (Bitfield-Mask: 0x7f) */
#define R_CANFD_CFDGAFL_P0_GAFLRMV_Pos (15UL) /*!< GAFLRMV (Bit 15) */
#define R_CANFD_CFDGAFL_P0_GAFLRMV_Msk (0x8000UL) /*!< GAFLRMV (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGAFL_P0_GAFLPTR_Pos (16UL) /*!< GAFLPTR (Bit 16) */
#define R_CANFD_CFDGAFL_P0_GAFLPTR_Msk (0xfff0000UL) /*!< GAFLPTR (Bitfield-Mask: 0xfff) */
#define R_CANFD_CFDGAFL_P0_GAFLDLC_Pos (28UL) /*!< GAFLDLC (Bit 28) */
#define R_CANFD_CFDGAFL_P0_GAFLDLC_Msk (0xf0000000UL) /*!< GAFLDLC (Bitfield-Mask: 0x0f) */
/* ========================================================== P1 =========================================================== */
#define R_CANFD_CFDGAFL_P1_GAFLFDP_Pos (0UL) /*!< GAFLFDP (Bit 0) */
#define R_CANFD_CFDGAFL_P1_GAFLFDP_Msk (0x3fffUL) /*!< GAFLFDP (Bitfield-Mask: 0x3fff) */
/* =========================================================================================================================== */
/* ================ CFDTHL ================ */
/* =========================================================================================================================== */
/* ========================================================= ACC0 ========================================================== */
#define R_CANFD_CFDTHL_ACC0_BT_Pos (0UL) /*!< BT (Bit 0) */
#define R_CANFD_CFDTHL_ACC0_BT_Msk (0x7UL) /*!< BT (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDTHL_ACC0_BN_Pos (3UL) /*!< BN (Bit 3) */
#define R_CANFD_CFDTHL_ACC0_BN_Msk (0x78UL) /*!< BN (Bitfield-Mask: 0x0f) */
#define R_CANFD_CFDTHL_ACC0_TID_Pos (8UL) /*!< TID (Bit 8) */
#define R_CANFD_CFDTHL_ACC0_TID_Msk (0xff00UL) /*!< TID (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDTHL_ACC0_TMTS_Pos (16UL) /*!< TMTS (Bit 16) */
#define R_CANFD_CFDTHL_ACC0_TMTS_Msk (0xffff0000UL) /*!< TMTS (Bitfield-Mask: 0xffff) */
/* =========================================================================================================================== */
/* ================ CFDRM ================ */
/* =========================================================================================================================== */
/* ========================================================== ID =========================================================== */
#define R_CANFD_CFDRM_ID_RMID_Pos (0UL) /*!< RMID (Bit 0) */
#define R_CANFD_CFDRM_ID_RMID_Msk (0x1fffffffUL) /*!< RMID (Bitfield-Mask: 0x1fffffff) */
#define R_CANFD_CFDRM_ID_RMRTR_Pos (30UL) /*!< RMRTR (Bit 30) */
#define R_CANFD_CFDRM_ID_RMRTR_Msk (0x40000000UL) /*!< RMRTR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRM_ID_RMIDE_Pos (31UL) /*!< RMIDE (Bit 31) */
#define R_CANFD_CFDRM_ID_RMIDE_Msk (0x80000000UL) /*!< RMIDE (Bitfield-Mask: 0x01) */
/* ========================================================== PTR ========================================================== */
#define R_CANFD_CFDRM_PTR_RMTS_Pos (0UL) /*!< RMTS (Bit 0) */
#define R_CANFD_CFDRM_PTR_RMTS_Msk (0xffffUL) /*!< RMTS (Bitfield-Mask: 0xffff) */
#define R_CANFD_CFDRM_PTR_RMPTR_Pos (16UL) /*!< RMPTR (Bit 16) */
#define R_CANFD_CFDRM_PTR_RMPTR_Msk (0xfff0000UL) /*!< RMPTR (Bitfield-Mask: 0xfff) */
#define R_CANFD_CFDRM_PTR_RMDLC_Pos (28UL) /*!< RMDLC (Bit 28) */
#define R_CANFD_CFDRM_PTR_RMDLC_Msk (0xf0000000UL) /*!< RMDLC (Bitfield-Mask: 0x0f) */
/* ========================================================= FDSTS ========================================================= */
#define R_CANFD_CFDRM_FDSTS_RMESI_Pos (0UL) /*!< RMESI (Bit 0) */
#define R_CANFD_CFDRM_FDSTS_RMESI_Msk (0x1UL) /*!< RMESI (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRM_FDSTS_RMBRS_Pos (1UL) /*!< RMBRS (Bit 1) */
#define R_CANFD_CFDRM_FDSTS_RMBRS_Msk (0x2UL) /*!< RMBRS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRM_FDSTS_RMFDF_Pos (2UL) /*!< RMFDF (Bit 2) */
#define R_CANFD_CFDRM_FDSTS_RMFDF_Msk (0x4UL) /*!< RMFDF (Bitfield-Mask: 0x01) */
/* ========================================================== DF =========================================================== */
#define R_CANFD_CFDRM_DF_RMDB_Pos (0UL) /*!< RMDB (Bit 0) */
#define R_CANFD_CFDRM_DF_RMDB_Msk (0xffUL) /*!< RMDB (Bitfield-Mask: 0xff) */
/* =========================================================================================================================== */
/* ================ CFDRF ================ */
/* =========================================================================================================================== */
/* ========================================================== ID =========================================================== */
#define R_CANFD_CFDRF_ID_RFID_Pos (0UL) /*!< RFID (Bit 0) */
#define R_CANFD_CFDRF_ID_RFID_Msk (0x1fffffffUL) /*!< RFID (Bitfield-Mask: 0x1fffffff) */
#define R_CANFD_CFDRF_ID_RFRTR_Pos (30UL) /*!< RFRTR (Bit 30) */
#define R_CANFD_CFDRF_ID_RFRTR_Msk (0x40000000UL) /*!< RFRTR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRF_ID_RFIDE_Pos (31UL) /*!< RFIDE (Bit 31) */
#define R_CANFD_CFDRF_ID_RFIDE_Msk (0x80000000UL) /*!< RFIDE (Bitfield-Mask: 0x01) */
/* ========================================================== PTR ========================================================== */
#define R_CANFD_CFDRF_PTR_RFTS_Pos (0UL) /*!< RFTS (Bit 0) */
#define R_CANFD_CFDRF_PTR_RFTS_Msk (0xffffUL) /*!< RFTS (Bitfield-Mask: 0xffff) */
#define R_CANFD_CFDRF_PTR_RFPTR_Pos (16UL) /*!< RFPTR (Bit 16) */
#define R_CANFD_CFDRF_PTR_RFPTR_Msk (0xfff0000UL) /*!< RFPTR (Bitfield-Mask: 0xfff) */
#define R_CANFD_CFDRF_PTR_RFDLC_Pos (28UL) /*!< RFDLC (Bit 28) */
#define R_CANFD_CFDRF_PTR_RFDLC_Msk (0xf0000000UL) /*!< RFDLC (Bitfield-Mask: 0x0f) */
/* ========================================================= FDSTS ========================================================= */
#define R_CANFD_CFDRF_FDSTS_RFESI_Pos (0UL) /*!< RFESI (Bit 0) */
#define R_CANFD_CFDRF_FDSTS_RFESI_Msk (0x1UL) /*!< RFESI (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRF_FDSTS_RFBRS_Pos (1UL) /*!< RFBRS (Bit 1) */
#define R_CANFD_CFDRF_FDSTS_RFBRS_Msk (0x2UL) /*!< RFBRS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRF_FDSTS_RFFDF_Pos (2UL) /*!< RFFDF (Bit 2) */
#define R_CANFD_CFDRF_FDSTS_RFFDF_Msk (0x4UL) /*!< RFFDF (Bitfield-Mask: 0x01) */
/* ========================================================== DF =========================================================== */
#define R_CANFD_CFDRF_DF_RFDB_Pos (0UL) /*!< RFDB (Bit 0) */
#define R_CANFD_CFDRF_DF_RFDB_Msk (0xffUL) /*!< RFDB (Bitfield-Mask: 0xff) */
/* =========================================================================================================================== */
/* ================ CFDCF ================ */
/* =========================================================================================================================== */
/* ========================================================== ID =========================================================== */
#define R_CANFD_CFDCF_ID_CFID_Pos (0UL) /*!< CFID (Bit 0) */
#define R_CANFD_CFDCF_ID_CFID_Msk (0x1fffffffUL) /*!< CFID (Bitfield-Mask: 0x1fffffff) */
#define R_CANFD_CFDCF_ID_THLEN_Pos (29UL) /*!< THLEN (Bit 29) */
#define R_CANFD_CFDCF_ID_THLEN_Msk (0x20000000UL) /*!< THLEN (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCF_ID_CFRTR_Pos (30UL) /*!< CFRTR (Bit 30) */
#define R_CANFD_CFDCF_ID_CFRTR_Msk (0x40000000UL) /*!< CFRTR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCF_ID_CFIDE_Pos (31UL) /*!< CFIDE (Bit 31) */
#define R_CANFD_CFDCF_ID_CFIDE_Msk (0x80000000UL) /*!< CFIDE (Bitfield-Mask: 0x01) */
/* ========================================================== PTR ========================================================== */
#define R_CANFD_CFDCF_PTR_CFTS_Pos (0UL) /*!< CFTS (Bit 0) */
#define R_CANFD_CFDCF_PTR_CFTS_Msk (0xffffUL) /*!< CFTS (Bitfield-Mask: 0xffff) */
#define R_CANFD_CFDCF_PTR_CFPTR_Pos (16UL) /*!< CFPTR (Bit 16) */
#define R_CANFD_CFDCF_PTR_CFPTR_Msk (0xfff0000UL) /*!< CFPTR (Bitfield-Mask: 0xfff) */
#define R_CANFD_CFDCF_PTR_CFDLC_Pos (28UL) /*!< CFDLC (Bit 28) */
#define R_CANFD_CFDCF_PTR_CFDLC_Msk (0xf0000000UL) /*!< CFDLC (Bitfield-Mask: 0x0f) */
/* ========================================================= FDSTS ========================================================= */
#define R_CANFD_CFDCF_FDSTS_CFESI_Pos (0UL) /*!< CFESI (Bit 0) */
#define R_CANFD_CFDCF_FDSTS_CFESI_Msk (0x1UL) /*!< CFESI (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCF_FDSTS_CFBRS_Pos (1UL) /*!< CFBRS (Bit 1) */
#define R_CANFD_CFDCF_FDSTS_CFBRS_Msk (0x2UL) /*!< CFBRS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCF_FDSTS_CFFDF_Pos (2UL) /*!< CFFDF (Bit 2) */
#define R_CANFD_CFDCF_FDSTS_CFFDF_Msk (0x4UL) /*!< CFFDF (Bitfield-Mask: 0x01) */
/* ========================================================== DF =========================================================== */
#define R_CANFD_CFDCF_DF_CFDB_Pos (0UL) /*!< CFDB (Bit 0) */
#define R_CANFD_CFDCF_DF_CFDB_Msk (0xffUL) /*!< CFDB (Bitfield-Mask: 0xff) */
/* =========================================================================================================================== */
/* ================ CFDTM ================ */
/* =========================================================================================================================== */
/* ========================================================== ID =========================================================== */
#define R_CANFD_CFDTM_ID_TMID_Pos (0UL) /*!< TMID (Bit 0) */
#define R_CANFD_CFDTM_ID_TMID_Msk (0x1fffffffUL) /*!< TMID (Bitfield-Mask: 0x1fffffff) */
#define R_CANFD_CFDCF_ID_THLEN_Pos (29UL) /*!< THLEN (Bit 29) */
#define R_CANFD_CFDCF_ID_THLEN_Msk (0x20000000UL) /*!< THLEN (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTM_ID_TMRTR_Pos (30UL) /*!< TMRTR (Bit 30) */
#define R_CANFD_CFDTM_ID_TMRTR_Msk (0x40000000UL) /*!< TMRTR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTM_ID_TMIDE_Pos (31UL) /*!< TMIDE (Bit 31) */
#define R_CANFD_CFDTM_ID_TMIDE_Msk (0x80000000UL) /*!< TMIDE (Bitfield-Mask: 0x01) */
/* ========================================================== PTR ========================================================== */
#define R_CANFD_CFDTM_PTR_TMPTR_Pos (16UL) /*!< TMPTR (Bit 16) */
#define R_CANFD_CFDTM_PTR_TMPTR_Msk (0xff0000UL) /*!< TMPTR (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDTM_PTR_TMDLC_Pos (28UL) /*!< TMDLC (Bit 28) */
#define R_CANFD_CFDTM_PTR_TMDLC_Msk (0xf0000000UL) /*!< TMDLC (Bitfield-Mask: 0x0f) */
/* ========================================================= FDCTR ========================================================= */
#define R_CANFD_CFDTM_FDCTR_TMESI_Pos (0UL) /*!< TMESI (Bit 0) */
#define R_CANFD_CFDTM_FDCTR_TMESI_Msk (0x1UL) /*!< TMESI (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTM_FDCTR_TMBRS_Pos (1UL) /*!< TMBRS (Bit 1) */
#define R_CANFD_CFDTM_FDCTR_TMBRS_Msk (0x2UL) /*!< TMBRS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTM_FDCTR_TMFDF_Pos (2UL) /*!< TMFDF (Bit 2) */
#define R_CANFD_CFDTM_FDCTR_TMFDF_Msk (0x4UL) /*!< TMFDF (Bitfield-Mask: 0x01) */
/* ========================================================== DF =========================================================== */
#define R_CANFD_CFDTM_DF_TMDB_Pos (0UL) /*!< TMDB (Bit 0) */
#define R_CANFD_CFDTM_DF_TMDB_Msk (0xffUL) /*!< TMDB (Bitfield-Mask: 0xff) */
/* =========================================================================================================================== */
/* ================ R_CANFD ================ */
/* =========================================================================================================================== */
/* ======================================================== CFDGCFG ======================================================== */
#define R_CANFD_CFDGCFG_TPRI_Pos (0UL) /*!< TPRI (Bit 0) */
#define R_CANFD_CFDGCFG_TPRI_Msk (0x1UL) /*!< TPRI (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_DCE_Pos (1UL) /*!< DCE (Bit 1) */
#define R_CANFD_CFDGCFG_DCE_Msk (0x2UL) /*!< DCE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_DRE_Pos (2UL) /*!< DRE (Bit 2) */
#define R_CANFD_CFDGCFG_DRE_Msk (0x4UL) /*!< DRE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_MME_Pos (3UL) /*!< MME (Bit 3) */
#define R_CANFD_CFDGCFG_MME_Msk (0x8UL) /*!< MME (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_DCS_Pos (4UL) /*!< DCS (Bit 4) */
#define R_CANFD_CFDGCFG_DCS_Msk (0x10UL) /*!< DCS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_CMPOC_Pos (5UL) /*!< CMPOC (Bit 5) */
#define R_CANFD_CFDGCFG_CMPOC_Msk (0x20UL) /*!< CMPOC (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_TSP_Pos (8UL) /*!< TSP (Bit 8) */
#define R_CANFD_CFDGCFG_TSP_Msk (0xf00UL) /*!< TSP (Bitfield-Mask: 0x0f) */
#define R_CANFD_CFDGCFG_TSSS_Pos (12UL) /*!< TSSS (Bit 12) */
#define R_CANFD_CFDGCFG_TSSS_Msk (0x1000UL) /*!< TSSS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCFG_TSBTCS_Pos (13UL) /*!< TSBTCS (Bit 13) */
#define R_CANFD_CFDGCFG_TSBTCS_Msk (0xe000UL) /*!< TSBTCS (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDGCFG_ITRCP_Pos (16UL) /*!< ITRCP (Bit 16) */
#define R_CANFD_CFDGCFG_ITRCP_Msk (0xffff0000UL) /*!< ITRCP (Bitfield-Mask: 0xffff) */
/* ======================================================== CFDGCTR ======================================================== */
#define R_CANFD_CFDGCTR_GMDC_Pos (0UL) /*!< GMDC (Bit 0) */
#define R_CANFD_CFDGCTR_GMDC_Msk (0x3UL) /*!< GMDC (Bitfield-Mask: 0x03) */
#define R_CANFD_CFDGCTR_GSLPR_Pos (2UL) /*!< GSLPR (Bit 2) */
#define R_CANFD_CFDGCTR_GSLPR_Msk (0x4UL) /*!< GSLPR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCTR_DEIE_Pos (8UL) /*!< DEIE (Bit 8) */
#define R_CANFD_CFDGCTR_DEIE_Msk (0x100UL) /*!< DEIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCTR_MEIE_Pos (9UL) /*!< MEIE (Bit 9) */
#define R_CANFD_CFDGCTR_MEIE_Msk (0x200UL) /*!< MEIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCTR_THLEIE_Pos (10UL) /*!< THLEIE (Bit 10) */
#define R_CANFD_CFDGCTR_THLEIE_Msk (0x400UL) /*!< THLEIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCTR_CMPOFIE_Pos (11UL) /*!< CMPOFIE (Bit 11) */
#define R_CANFD_CFDGCTR_CMPOFIE_Msk (0x800UL) /*!< CMPOFIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGCTR_TSRST_Pos (16UL) /*!< TSRST (Bit 16) */
#define R_CANFD_CFDGCTR_TSRST_Msk (0x10000UL) /*!< TSRST (Bitfield-Mask: 0x01) */
/* ======================================================== CFDGSTS ======================================================== */
#define R_CANFD_CFDGSTS_GRSTSTS_Pos (0UL) /*!< GRSTSTS (Bit 0) */
#define R_CANFD_CFDGSTS_GRSTSTS_Msk (0x1UL) /*!< GRSTSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGSTS_GHLTSTS_Pos (1UL) /*!< GHLTSTS (Bit 1) */
#define R_CANFD_CFDGSTS_GHLTSTS_Msk (0x2UL) /*!< GHLTSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGSTS_GSLPSTS_Pos (2UL) /*!< GSLPSTS (Bit 2) */
#define R_CANFD_CFDGSTS_GSLPSTS_Msk (0x4UL) /*!< GSLPSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGSTS_GRAMINIT_Pos (3UL) /*!< GRAMINIT (Bit 3) */
#define R_CANFD_CFDGSTS_GRAMINIT_Msk (0x8UL) /*!< GRAMINIT (Bitfield-Mask: 0x01) */
/* ======================================================= CFDGERFL ======================================================== */
#define R_CANFD_CFDGERFL_DEF_Pos (0UL) /*!< DEF (Bit 0) */
#define R_CANFD_CFDGERFL_DEF_Msk (0x1UL) /*!< DEF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGERFL_MES_Pos (1UL) /*!< MES (Bit 1) */
#define R_CANFD_CFDGERFL_MES_Msk (0x2UL) /*!< MES (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGERFL_THLES_Pos (2UL) /*!< THLES (Bit 2) */
#define R_CANFD_CFDGERFL_THLES_Msk (0x4UL) /*!< THLES (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGERFL_CMPOF_Pos (3UL) /*!< CMPOF (Bit 3) */
#define R_CANFD_CFDGERFL_CMPOF_Msk (0x8UL) /*!< CMPOF (Bitfield-Mask: 0x01) */
/* ======================================================== CFDGTSC ======================================================== */
#define R_CANFD_CFDGTSC_TS_Pos (0UL) /*!< TS (Bit 0) */
#define R_CANFD_CFDGTSC_TS_Msk (0xffffUL) /*!< TS (Bitfield-Mask: 0xffff) */
/* ====================================================== CFDGAFLECTR ====================================================== */
#define R_CANFD_CFDGAFLECTR_AFLPN_Pos (0UL) /*!< AFLPN (Bit 0) */
#define R_CANFD_CFDGAFLECTR_AFLPN_Msk (0x1fUL) /*!< AFLPN (Bitfield-Mask: 0x1f) */
#define R_CANFD_CFDGAFLECTR_AFLDAE_Pos (8UL) /*!< AFLDAE (Bit 8) */
#define R_CANFD_CFDGAFLECTR_AFLDAE_Msk (0x100UL) /*!< AFLDAE (Bitfield-Mask: 0x01) */
/* ====================================================== CFDGAFLCFG0 ====================================================== */
#define R_CANFD_CFDGAFLCFG0_RNC1_Pos (16UL) /*!< RNC1 (Bit 16) */
#define R_CANFD_CFDGAFLCFG0_RNC1_Msk (0xff0000UL) /*!< RNC1 (Bitfield-Mask: 0x1ff) */
#define R_CANFD_CFDGAFLCFG0_RNC0_Pos (24UL) /*!< RNC0 (Bit 24) */
#define R_CANFD_CFDGAFLCFG0_RNC0_Msk (0xff000000UL) /*!< RNC0 (Bitfield-Mask: 0x1ff) */
/* ======================================================== CFDRMNB ======================================================== */
#define R_CANFD_CFDRMNB_NRXMB_Pos (0UL) /*!< NRXMB (Bit 0) */
#define R_CANFD_CFDRMNB_NRXMB_Msk (0xffUL) /*!< NRXMB (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDRMNB_RMPLS_Pos (8UL) /*!< RMPLS (Bit 8) */
#define R_CANFD_CFDRMNB_RMPLS_Msk (0x700UL) /*!< RMPLS (Bitfield-Mask: 0x07) */
/* ======================================================= CFDRMND0 ======================================================== */
#define R_CANFD_CFDRMND0_RMNS_Pos (0UL) /*!< RMNS (Bit 0) */
#define R_CANFD_CFDRMND0_RMNS_Msk (0xffffffffUL) /*!< RMNS (Bitfield-Mask: 0xffffffff) */
/* ======================================================== CFDRFCC ======================================================== */
#define R_CANFD_CFDRFCC_RFE_Pos (0UL) /*!< RFE (Bit 0) */
#define R_CANFD_CFDRFCC_RFE_Msk (0x1UL) /*!< RFE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFCC_RFIE_Pos (1UL) /*!< RFIE (Bit 1) */
#define R_CANFD_CFDRFCC_RFIE_Msk (0x2UL) /*!< RFIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFCC_RFPLS_Pos (4UL) /*!< RFPLS (Bit 4) */
#define R_CANFD_CFDRFCC_RFPLS_Msk (0x70UL) /*!< RFPLS (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDRFCC_RFDC_Pos (8UL) /*!< RFDC (Bit 8) */
#define R_CANFD_CFDRFCC_RFDC_Msk (0x700UL) /*!< RFDC (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDRFCC_RFIM_Pos (12UL) /*!< RFIM (Bit 12) */
#define R_CANFD_CFDRFCC_RFIM_Msk (0x1000UL) /*!< RFIM (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFCC_RFIGCV_Pos (13UL) /*!< RFIGCV (Bit 13) */
#define R_CANFD_CFDRFCC_RFIGCV_Msk (0xe000UL) /*!< RFIGCV (Bitfield-Mask: 0x07) */
/* ======================================================= CFDRFSTS ======================================================== */
#define R_CANFD_CFDRFSTS_RFEMP_Pos (0UL) /*!< RFEMP (Bit 0) */
#define R_CANFD_CFDRFSTS_RFEMP_Msk (0x1UL) /*!< RFEMP (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFSTS_RFFLL_Pos (1UL) /*!< RFFLL (Bit 1) */
#define R_CANFD_CFDRFSTS_RFFLL_Msk (0x2UL) /*!< RFFLL (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFSTS_RFMLT_Pos (2UL) /*!< RFMLT (Bit 2) */
#define R_CANFD_CFDRFSTS_RFMLT_Msk (0x4UL) /*!< RFMLT (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFSTS_RFIF_Pos (3UL) /*!< RFIF (Bit 3) */
#define R_CANFD_CFDRFSTS_RFIF_Msk (0x8UL) /*!< RFIF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDRFSTS_RFMC_Pos (8UL) /*!< RFMC (Bit 8) */
#define R_CANFD_CFDRFSTS_RFMC_Msk (0xff00UL) /*!< RFMC (Bitfield-Mask: 0xff) */
/* ======================================================= CFDRFPCTR ======================================================= */
#define R_CANFD_CFDRFPCTR_RFPC_Pos (0UL) /*!< RFPC (Bit 0) */
#define R_CANFD_CFDRFPCTR_RFPC_Msk (0xffUL) /*!< RFPC (Bitfield-Mask: 0xff) */
/* ======================================================== CFDCFCC ======================================================== */
#define R_CANFD_CFDCFCC_CFE_Pos (0UL) /*!< CFE (Bit 0) */
#define R_CANFD_CFDCFCC_CFE_Msk (0x1UL) /*!< CFE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFCC_CFRXIE_Pos (1UL) /*!< CFRXIE (Bit 1) */
#define R_CANFD_CFDCFCC_CFRXIE_Msk (0x2UL) /*!< CFRXIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFCC_CFTXIE_Pos (2UL) /*!< CFTXIE (Bit 2) */
#define R_CANFD_CFDCFCC_CFTXIE_Msk (0x4UL) /*!< CFTXIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFCC_CFPLS_Pos (4UL) /*!< CFPLS (Bit 4) */
#define R_CANFD_CFDCFCC_CFPLS_Msk (0x70UL) /*!< CFPLS (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDCFCC_CFDC_Pos (8UL) /*!< CFDC (Bit 8) */
#define R_CANFD_CFDCFCC_CFDC_Msk (0x700UL) /*!< CFDC (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDCFCC_CFIM_Pos (12UL) /*!< CFIM (Bit 12) */
#define R_CANFD_CFDCFCC_CFIM_Msk (0x1000UL) /*!< CFIM (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFCC_CFIGCV_Pos (13UL) /*!< CFIGCV (Bit 13) */
#define R_CANFD_CFDCFCC_CFIGCV_Msk (0xe000UL) /*!< CFIGCV (Bitfield-Mask: 0x07) */
#define R_CANFD_CFDCFCC_CFM_Pos (16UL) /*!< CFM (Bit 16) */
#define R_CANFD_CFDCFCC_CFM_Msk (0x30000UL) /*!< CFM (Bitfield-Mask: 0x03) */
#define R_CANFD_CFDCFCC_CFITSS_Pos (18UL) /*!< CFITSS (Bit 18) */
#define R_CANFD_CFDCFCC_CFITSS_Msk (0x40000UL) /*!< CFITSS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFCC_CFITR_Pos (19UL) /*!< CFITR (Bit 19) */
#define R_CANFD_CFDCFCC_CFITR_Msk (0x80000UL) /*!< CFITR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFCC_CFTML_Pos (20UL) /*!< CFTML (Bit 16) */
#define R_CANFD_CFDCFCC_CFTML_Msk (0xf00000UL) /*!< CFTML (Bitfield-Mask: 0x0f) */
#define R_CANFD_CFDCFCC_CFITT_Pos (24UL) /*!< CFITT (Bit 24) */
#define R_CANFD_CFDCFCC_CFITT_Msk (0xff000000UL) /*!< CFITT (Bitfield-Mask: 0xff) */
/* ======================================================= CFDCFSTS ======================================================== */
#define R_CANFD_CFDCFSTS_CFEMP_Pos (0UL) /*!< CFEMP (Bit 0) */
#define R_CANFD_CFDCFSTS_CFEMP_Msk (0x1UL) /*!< CFEMP (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFSTS_CFFLL_Pos (1UL) /*!< CFFLL (Bit 1) */
#define R_CANFD_CFDCFSTS_CFFLL_Msk (0x2UL) /*!< CFFLL (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFSTS_CFMLT_Pos (2UL) /*!< CFMLT (Bit 2) */
#define R_CANFD_CFDCFSTS_CFMLT_Msk (0x4UL) /*!< CFMLT (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFSTS_CFRXIF_Pos (3UL) /*!< CFRXIF (Bit 3) */
#define R_CANFD_CFDCFSTS_CFRXIF_Msk (0x8UL) /*!< CFRXIF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFSTS_CFTXIF_Pos (4UL) /*!< CFTXIF (Bit 4) */
#define R_CANFD_CFDCFSTS_CFTXIF_Msk (0x10UL) /*!< CFTXIF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCFSTS_CFMC_Pos (8UL) /*!< CFMC (Bit 8) */
#define R_CANFD_CFDCFSTS_CFMC_Msk (0xff00UL) /*!< CFMC (Bitfield-Mask: 0xff) */
/* ======================================================= CFDCFPCTR ======================================================= */
#define R_CANFD_CFDCFPCTR_CFPC_Pos (0UL) /*!< CFPC (Bit 0) */
#define R_CANFD_CFDCFPCTR_CFPC_Msk (0xffUL) /*!< CFPC (Bitfield-Mask: 0xff) */
/* ======================================================= CFDFESTS ======================================================== */
#define R_CANFD_CFDFESTS_RFXEMP_Pos (0UL) /*!< RFXEMP (Bit 0) */
#define R_CANFD_CFDFESTS_RFXEMP_Msk (0xffUL) /*!< RFXEMP (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDFESTS_CFXEMP_Pos (8UL) /*!< CFXEMP (Bit 8) */
#define R_CANFD_CFDFESTS_CFXEMP_Msk (0x3f00UL) /*!< CFXEMP (Bitfield-Mask: 0x3f) */
/* ======================================================= CFDFFSTS ======================================================== */
#define R_CANFD_CFDFFSTS_RFXFLL_Pos (0UL) /*!< RFXFLL (Bit 0) */
#define R_CANFD_CFDFFSTS_RFXFLL_Msk (0xffUL) /*!< RFXFLL (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDFFSTS_CFXFLL_Pos (8UL) /*!< CFXFLL (Bit 8) */
#define R_CANFD_CFDFFSTS_CFXFLL_Msk (0x3f00UL) /*!< CFXFLL (Bitfield-Mask: 0x3f) */
/* ======================================================= CFDFMSTS ======================================================== */
#define R_CANFD_CFDFMSTS_RFXMLT_Pos (0UL) /*!< RFXMLT (Bit 0) */
#define R_CANFD_CFDFMSTS_RFXMLT_Msk (0xffUL) /*!< RFXMLT (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDFMSTS_CFXMLT_Pos (8UL) /*!< CFXMLT (Bit 8) */
#define R_CANFD_CFDFMSTS_CFXMLT_Msk (0x3f00UL) /*!< CFXMLT (Bitfield-Mask: 0x3f) */
/* ======================================================= CFDRFISTS ======================================================= */
#define R_CANFD_CFDRFISTS_RFXIF_Pos (0UL) /*!< RFXIF (Bit 0) */
#define R_CANFD_CFDRFISTS_RFXIF_Msk (0xffUL) /*!< RFXIF (Bitfield-Mask: 0xff) */
#define R_CANFD_CFDRFISTS_RFXFFLL_Pos (16UL) /*!< RFXFFLL (Bit 16) */
#define R_CANFD_CFDRFISTS_RFXFFLL_Msk (0xff0000UL) /*!< RFXFFLL (Bitfield-Mask: 0xff) */
/* ====================================================== CFDCFRISTS ======================================================= */
#define R_CANFD_CFDCFRISTS_CFXRXIF_Pos (0UL) /*!< CFXRXIF (Bit 0) */
#define R_CANFD_CFDCFRISTS_CFXRXIF_Msk (0x3fUL) /*!< CFXRXIF (Bitfield-Mask: 0x3f) */
/* ====================================================== CFDCFTISTS ======================================================= */
#define R_CANFD_CFDCFTISTS_CFXTXIF_Pos (0UL) /*!< CFXTXIF (Bit 0) */
#define R_CANFD_CFDCFTISTS_CFXTXIF_Msk (0x3fUL) /*!< CFXTXIF (Bitfield-Mask: 0x3f) */
/* ======================================================== CFDTMC ========================================================= */
#define R_CANFD_CFDTMC_TMTR_Pos (0UL) /*!< TMTR (Bit 0) */
#define R_CANFD_CFDTMC_TMTR_Msk (0x1UL) /*!< TMTR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTMC_TMTAR_Pos (1UL) /*!< TMTAR (Bit 1) */
#define R_CANFD_CFDTMC_TMTAR_Msk (0x2UL) /*!< TMTAR (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTMC_TMOM_Pos (2UL) /*!< TMOM (Bit 2) */
#define R_CANFD_CFDTMC_TMOM_Msk (0x4UL) /*!< TMOM (Bitfield-Mask: 0x01) */
/* ======================================================= CFDTMSTS ======================================================== */
#define R_CANFD_CFDTMSTS_TMTSTS_Pos (0UL) /*!< TMTSTS (Bit 0) */
#define R_CANFD_CFDTMSTS_TMTSTS_Msk (0x1UL) /*!< TMTSTS (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTMSTS_TMTRF_Pos (1UL) /*!< TMTRF (Bit 1) */
#define R_CANFD_CFDTMSTS_TMTRF_Msk (0x6UL) /*!< TMTRF (Bitfield-Mask: 0x03) */
#define R_CANFD_CFDTMSTS_TMTRM_Pos (3UL) /*!< TMTRM (Bit 3) */
#define R_CANFD_CFDTMSTS_TMTRM_Msk (0x8UL) /*!< TMTRM (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTMSTS_TMTARM_Pos (4UL) /*!< TMTARM (Bit 4) */
#define R_CANFD_CFDTMSTS_TMTARM_Msk (0x10UL) /*!< TMTARM (Bitfield-Mask: 0x01) */
/* ====================================================== CFDTMTRSTS ======================================================= */
#define R_CANFD_CFDTMTRSTS_TMTRSTS_Pos (0UL) /*!< TMTRSTS (Bit 0) */
#define R_CANFD_CFDTMTRSTS_TMTRSTS_Msk (0xffffffffUL) /*!< TMTRSTS (Bitfield-Mask: 0xffffffff) */
/* ====================================================== CFDTMTARSTS ====================================================== */
#define R_CANFD_CFDTMTARSTS_TMTARSTS_Pos (0UL) /*!< TMTARSTS (Bit 0) */
#define R_CANFD_CFDTMTARSTS_TMTARSTS_Msk (0xffffffffUL) /*!< TMTARSTS (Bitfield-Mask: 0xffffffff) */
/* ====================================================== CFDTMTCSTS ======================================================= */
#define R_CANFD_CFDTMTCSTS_TMTCSTS_Pos (0UL) /*!< TMTCSTS (Bit 0) */
#define R_CANFD_CFDTMTCSTS_TMTCSTS_Msk (0xffffffffUL) /*!< TMTCSTS (Bitfield-Mask: 0xffffffff) */
/* ====================================================== CFDTMTASTS ======================================================= */
#define R_CANFD_CFDTMTASTS_TMTASTS_Pos (0UL) /*!< TMTASTS (Bit 0) */
#define R_CANFD_CFDTMTASTS_TMTASTS_Msk (0xffffffffUL) /*!< TMTASTS (Bitfield-Mask: 0xffffffff) */
/* ======================================================= CFDTMIEC ======================================================== */
#define R_CANFD_CFDTMIEC_TMIE_Pos (0UL) /*!< TMIE (Bit 0) */
#define R_CANFD_CFDTMIEC_TMIE_Msk (0xffffffffUL) /*!< TMIE (Bitfield-Mask: 0xffffffff) */
/* ======================================================= CFDTXQCC0 ======================================================= */
#define R_CANFD_CFDTXQCC0_TXQE_Pos (0UL) /*!< TXQE (Bit 0) */
#define R_CANFD_CFDTXQCC0_TXQE_Msk (0x1UL) /*!< TXQE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTXQCC0_TXQDC_Pos (8UL) /*!< TXQDC (Bit 8) */
#define R_CANFD_CFDTXQCC0_TXQDC_Msk (0xf00UL) /*!< TXQDC (Bitfield-Mask: 0x1f) */
#define R_CANFD_CFDTXQCC0_TXQIE_Pos (12UL) /*!< TXQIE (Bit 12) */
#define R_CANFD_CFDTXQCC0_TXQIE_Msk (0x20UL) /*!< TXQIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTXQCC0_TXQIM_Pos (13UL) /*!< TXQIM (Bit 13) */
#define R_CANFD_CFDTXQCC0_TXQIM_Msk (0x80UL) /*!< TXQIM (Bitfield-Mask: 0x01) */
/* ====================================================== CFDTXQSTS0 ======================================================= */
#define R_CANFD_CFDTXQSTS0_TXQEMP_Pos (0UL) /*!< TXQEMP (Bit 0) */
#define R_CANFD_CFDTXQSTS0_TXQEMP_Msk (0x1UL) /*!< TXQEMP (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTXQSTS0_TXQFLL_Pos (1UL) /*!< TXQFLL (Bit 1) */
#define R_CANFD_CFDTXQSTS0_TXQFLL_Msk (0x2UL) /*!< TXQFLL (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTXQSTS0_TXQIF_Pos (2UL) /*!< TXQIF (Bit 2) */
#define R_CANFD_CFDTXQSTS0_TXQIF_Msk (0x4UL) /*!< TXQIF (Bitfield-Mask: 0x01) */
/* ====================================================== CFDTXQPCTR0 ====================================================== */
#define R_CANFD_CFDTXQPCTR0_TXQPC_Pos (0UL) /*!< TXQPC (Bit 0) */
#define R_CANFD_CFDTXQPCTR0_TXQPC_Msk (0xffUL) /*!< TXQPC (Bitfield-Mask: 0xff) */
/* ======================================================= CFDTHLCC ======================================================== */
#define R_CANFD_CFDTHLCC_THLE_Pos (0UL) /*!< THLE (Bit 0) */
#define R_CANFD_CFDTHLCC_THLE_Msk (0x1UL) /*!< THLE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLCC_THLIE_Pos (8UL) /*!< THLIE (Bit 8) */
#define R_CANFD_CFDTHLCC_THLIE_Msk (0x100UL) /*!< THLIE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLCC_THLIM_Pos (9UL) /*!< THLIM (Bit 9) */
#define R_CANFD_CFDTHLCC_THLIM_Msk (0x200UL) /*!< THLIM (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLCC_THLDTE_Pos (10UL) /*!< THLDTE (Bit 10) */
#define R_CANFD_CFDTHLCC_THLDTE_Msk (0x400UL) /*!< THLDTE (Bitfield-Mask: 0x01) */
/* ======================================================= CFDTHLSTS ======================================================= */
#define R_CANFD_CFDTHLSTS_THLEMP_Pos (0UL) /*!< THLEMP (Bit 0) */
#define R_CANFD_CFDTHLSTS_THLEMP_Msk (0x1UL) /*!< THLEMP (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLSTS_THLFLL_Pos (1UL) /*!< THLFLL (Bit 1) */
#define R_CANFD_CFDTHLSTS_THLFLL_Msk (0x2UL) /*!< THLFLL (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLSTS_THLELT_Pos (2UL) /*!< THLELT (Bit 2) */
#define R_CANFD_CFDTHLSTS_THLELT_Msk (0x4UL) /*!< THLELT (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLSTS_THLIF_Pos (3UL) /*!< THLIF (Bit 3) */
#define R_CANFD_CFDTHLSTS_THLIF_Msk (0x8UL) /*!< THLIF (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDTHLSTS_THLMC_Pos (8UL) /*!< THLMC (Bit 8) */
#define R_CANFD_CFDTHLSTS_THLMC_Msk (0x1f00UL) /*!< THLMC (Bitfield-Mask: 0x1f) */
/* ====================================================== CFDTHLPCTR ======================================================= */
#define R_CANFD_CFDTHLPCTR_THLPC_Pos (0UL) /*!< THLPC (Bit 0) */
#define R_CANFD_CFDTHLPCTR_THLPC_Msk (0xffUL) /*!< THLPC (Bitfield-Mask: 0xff) */
/* ===================================================== CFDGTINTSTS0 ====================================================== */
#define R_CANFD_CFDGTINTSTS0_TSIF0_Pos (0UL) /*!< TSIF0 (Bit 0) */
#define R_CANFD_CFDGTINTSTS0_TSIF0_Msk (0x1UL) /*!< TSIF0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_TAIF0_Pos (1UL) /*!< TAIF0 (Bit 1) */
#define R_CANFD_CFDGTINTSTS0_TAIF0_Msk (0x2UL) /*!< TAIF0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_TQIF0_Pos (2UL) /*!< TQIF0 (Bit 2) */
#define R_CANFD_CFDGTINTSTS0_TQIF0_Msk (0x4UL) /*!< TQIF0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_CFTIF0_Pos (3UL) /*!< CFTIF0 (Bit 3) */
#define R_CANFD_CFDGTINTSTS0_CFTIF0_Msk (0x8UL) /*!< CFTIF0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_THIF0_Pos (4UL) /*!< THIF0 (Bit 4) */
#define R_CANFD_CFDGTINTSTS0_THIF0_Msk (0x10UL) /*!< THIF0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_TSIF1_Pos (8UL) /*!< TSIF1 (Bit 8) */
#define R_CANFD_CFDGTINTSTS0_TSIF1_Msk (0x100UL) /*!< TSIF1 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_TAIF1_Pos (9UL) /*!< TAIF1 (Bit 9) */
#define R_CANFD_CFDGTINTSTS0_TAIF1_Msk (0x200UL) /*!< TAIF1 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_TQIF1_Pos (10UL) /*!< TQIF1 (Bit 10) */
#define R_CANFD_CFDGTINTSTS0_TQIF1_Msk (0x400UL) /*!< TQIF1 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_CFTIF1_Pos (11UL) /*!< CFTIF1 (Bit 11) */
#define R_CANFD_CFDGTINTSTS0_CFTIF1_Msk (0x800UL) /*!< CFTIF1 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTINTSTS0_THIF1_Pos (12UL) /*!< THIF1 (Bit 12) */
#define R_CANFD_CFDGTINTSTS0_THIF1_Msk (0x1000UL) /*!< THIF1 (Bitfield-Mask: 0x01) */
/* ====================================================== CFDGTSTCFG ======================================================= */
#define R_CANFD_CFDGTSTCFG_C0ICBCE_Pos (0UL) /*!< C0ICBCE (Bit 0) */
#define R_CANFD_CFDGTSTCFG_C0ICBCE_Msk (0x1UL) /*!< C0ICBCE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTSTCFG_C1ICBCE_Pos (1UL) /*!< C1ICBCE (Bit 1) */
#define R_CANFD_CFDGTSTCFG_C1ICBCE_Msk (0x2UL) /*!< C1ICBCE (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTSTCFG_RTMPS_Pos (16UL) /*!< RTMPS (Bit 16) */
#define R_CANFD_CFDGTSTCFG_RTMPS_Msk (0x3ff0000UL) /*!< RTMPS (Bitfield-Mask: 0x3f) */
/* ====================================================== CFDGTSTCTR ======================================================= */
#define R_CANFD_CFDGTSTCTR_ICBCTME_Pos (0UL) /*!< ICBCTME (Bit 0) */
#define R_CANFD_CFDGTSTCTR_ICBCTME_Msk (0x1UL) /*!< ICBCTME (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGTSTCTR_RTME_Pos (2UL) /*!< RTME (Bit 2) */
#define R_CANFD_CFDGTSTCTR_RTME_Msk (0x4UL) /*!< RTME (Bitfield-Mask: 0x01) */
/* ======================================================= CFDGFDCFG ======================================================= */
#define R_CANFD_CFDGFDCFG_RPED_Pos (0UL) /*!< RPED (Bit 0) */
#define R_CANFD_CFDGFDCFG_RPED_Msk (0x1UL) /*!< RPED (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDGFDCFG_TSCCFG_Pos (8UL) /*!< TSCCFG (Bit 8) */
#define R_CANFD_CFDGFDCFG_TSCCFG_Msk (0x300UL) /*!< TSCCFG (Bitfield-Mask: 0x03) */
/* ======================================================= CFDGLOCKK ======================================================= */
#define R_CANFD_CFDGLOCKK_LOCK_Pos (0UL) /*!< LOCK (Bit 0) */
#define R_CANFD_CFDGLOCKK_LOCK_Msk (0xffffUL) /*!< LOCK (Bitfield-Mask: 0xffff) */
/* ======================================================= CFDCDTCT ======================================================== */
#define R_CANFD_CFDCDTCT_RFDMAE0_Pos (0UL) /*!< RFDMAE0 (Bit 0) */
#define R_CANFD_CFDCDTCT_RFDMAE0_Msk (0x1UL) /*!< RFDMAE0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE1_Pos (1UL) /*!< RFDMAE1 (Bit 1) */
#define R_CANFD_CFDCDTCT_RFDMAE1_Msk (0x2UL) /*!< RFDMAE1 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE2_Pos (2UL) /*!< RFDMAE2 (Bit 2) */
#define R_CANFD_CFDCDTCT_RFDMAE2_Msk (0x4UL) /*!< RFDMAE2 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE3_Pos (3UL) /*!< RFDMAE3 (Bit 3) */
#define R_CANFD_CFDCDTCT_RFDMAE3_Msk (0x8UL) /*!< RFDMAE3 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE4_Pos (4UL) /*!< RFDMAE4 (Bit 4) */
#define R_CANFD_CFDCDTCT_RFDMAE4_Msk (0x10UL) /*!< RFDMAE4 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE5_Pos (5UL) /*!< RFDMAE5 (Bit 5) */
#define R_CANFD_CFDCDTCT_RFDMAE5_Msk (0x20UL) /*!< RFDMAE5 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE6_Pos (6UL) /*!< RFDMAE6 (Bit 6) */
#define R_CANFD_CFDCDTCT_RFDMAE6_Msk (0x40UL) /*!< RFDMAE6 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_RFDMAE7_Pos (7UL) /*!< RFDMAE7 (Bit 7) */
#define R_CANFD_CFDCDTCT_RFDMAE7_Msk (0x80UL) /*!< RFDMAE7 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_CFDMAE0_Pos (8UL) /*!< CFDMAE0 (Bit 8) */
#define R_CANFD_CFDCDTCT_CFDMAE0_Msk (0x100UL) /*!< CFDMAE0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTCT_CFDMAE1_Pos (9UL) /*!< CFDMAE1 (Bit 9) */
#define R_CANFD_CFDCDTCT_CFDMAE1_Msk (0x200UL) /*!< CFDMAE1 (Bitfield-Mask: 0x01) */
/* ======================================================= CFDCDTSTS ======================================================= */
#define R_CANFD_CFDCDTSTS_RFDMASTS0_Pos (0UL) /*!< RFDMASTS0 (Bit 0) */
#define R_CANFD_CFDCDTSTS_RFDMASTS0_Msk (0x1UL) /*!< RFDMASTS0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS1_Pos (1UL) /*!< RFDMASTS1 (Bit 1) */
#define R_CANFD_CFDCDTSTS_RFDMASTS1_Msk (0x2UL) /*!< RFDMASTS1 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS2_Pos (2UL) /*!< RFDMASTS2 (Bit 2) */
#define R_CANFD_CFDCDTSTS_RFDMASTS2_Msk (0x4UL) /*!< RFDMASTS2 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS3_Pos (3UL) /*!< RFDMASTS3 (Bit 3) */
#define R_CANFD_CFDCDTSTS_RFDMASTS3_Msk (0x8UL) /*!< RFDMASTS3 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS4_Pos (4UL) /*!< RFDMASTS4 (Bit 4) */
#define R_CANFD_CFDCDTSTS_RFDMASTS4_Msk (0x10UL) /*!< RFDMASTS4 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS5_Pos (5UL) /*!< RFDMASTS5 (Bit 5) */
#define R_CANFD_CFDCDTSTS_RFDMASTS5_Msk (0x20UL) /*!< RFDMASTS5 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS6_Pos (6UL) /*!< RFDMASTS6 (Bit 6) */
#define R_CANFD_CFDCDTSTS_RFDMASTS6_Msk (0x40UL) /*!< RFDMASTS6 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_RFDMASTS7_Pos (7UL) /*!< RFDMASTS7 (Bit 7) */
#define R_CANFD_CFDCDTSTS_RFDMASTS7_Msk (0x80UL) /*!< RFDMASTS7 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_CFDMASTS0_Pos (8UL) /*!< CFDMASTS0 (Bit 8) */
#define R_CANFD_CFDCDTSTS_CFDMASTS0_Msk (0x100UL) /*!< CFDMASTS0 (Bitfield-Mask: 0x01) */
#define R_CANFD_CFDCDTSTS_CFDMASTS1_Pos (9UL) /*!< CFDMASTS1 (Bit 9) */
#define R_CANFD_CFDCDTSTS_CFDMASTS1_Msk (0x200UL) /*!< CFDMASTS1 (Bitfield-Mask: 0x01) */
/* ======================================================= CFDRPGACC ======================================================= */
#define R_CANFD_CFDRPGACC_RDTA_Pos (0UL) /*!< RDTA (Bit 0) */
#define R_CANFD_CFDRPGACC_RDTA_Msk (0xffffffffUL) /*!< RDTA (Bitfield-Mask: 0xffffffff) */
#endif

View File

@ -0,0 +1,217 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : dmac_b_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for dmac.
*********************************************************************************************************************/
#ifndef DMAC_B_IOBITMASK_H
#define DMAC_B_IOBITMASK_H
#define R_DMAC_B0_GRP_CH_CHSTAT_EN_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_EN_Pos (0UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_RQST_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_RQST_Pos (1UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_TACT_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_TACT_Pos (2UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_SUS_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_SUS_Pos (3UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_ER_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_ER_Pos (4UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_END_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_END_Pos (5UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_TC_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_TC_Pos (6UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_SR_Msk (0x00000080UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_SR_Pos (7UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_DL_Msk (0x00000100UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_DL_Pos (8UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_DW_Msk (0x00000200UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_DW_Pos (9UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_DER_Msk (0x00000400UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_DER_Pos (10UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_MODE_Msk (0x00000800UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_MODE_Pos (11UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_INTMSK_Msk (0x00010000UL)
#define R_DMAC_B0_GRP_CH_CHSTAT_INTMSK_Pos (16UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SETEN_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SETEN_Pos (0UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLREN_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLREN_Pos (1UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_STG_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_STG_Pos (2UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SWRST_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SWRST_Pos (3UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRRQ_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRRQ_Pos (4UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLREND_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLREND_Pos (5UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRTC_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRTC_Pos (6UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SETSUS_Msk (0x00000100UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SETSUS_Pos (8UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRSUS_Msk (0x00000200UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRSUS_Pos (9UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SETINTMSK_Msk (0x00010000UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_SETINTMSK_Pos (16UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRINTMSK_Msk (0x00020000UL)
#define R_DMAC_B0_GRP_CH_CHCTRL_CLRINTMSK_Pos (17UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SEL_Msk (0x00000007UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SEL_Pos (0UL)
#define R_DMAC_B0_GRP_CH_CHCFG_REQD_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_CH_CHCFG_REQD_Pos (3UL)
#define R_DMAC_B0_GRP_CH_CHCFG_LOEN_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_CH_CHCFG_LOEN_Pos (4UL)
#define R_DMAC_B0_GRP_CH_CHCFG_HIEN_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_CH_CHCFG_HIEN_Pos (5UL)
#define R_DMAC_B0_GRP_CH_CHCFG_LVL_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_CH_CHCFG_LVL_Pos (6UL)
#define R_DMAC_B0_GRP_CH_CHCFG_AM_Msk (0x00000700UL)
#define R_DMAC_B0_GRP_CH_CHCFG_AM_Pos (8UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SDS_Msk (0x0000F000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SDS_Pos (12UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DDS_Msk (0x000F0000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DDS_Pos (16UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SAD_Msk (0x00100000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SAD_Pos (20UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DAD_Msk (0x00200000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DAD_Pos (21UL)
#define R_DMAC_B0_GRP_CH_CHCFG_TM_Msk (0x00400000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_TM_Pos (22UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DEM_Msk (0x01000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DEM_Pos (24UL)
#define R_DMAC_B0_GRP_CH_CHCFG_TCM_Msk (0x02000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_TCM_Pos (25UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SBE_Msk (0x08000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_SBE_Pos (27UL)
#define R_DMAC_B0_GRP_CH_CHCFG_RSEL_Msk (0x10000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_RSEL_Pos (28UL)
#define R_DMAC_B0_GRP_CH_CHCFG_RSW_Msk (0x20000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_RSW_Pos (29UL)
#define R_DMAC_B0_GRP_CH_CHCFG_REN_Msk (0x40000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_REN_Pos (30UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DMS_Msk (0x80000000UL)
#define R_DMAC_B0_GRP_CH_CHCFG_DMS_Pos (31UL)
#define R_DMAC_B0_GRP_CH_CHITVL_ITVL_Msk (0x0000FFFFUL)
#define R_DMAC_B0_GRP_CH_CHITVL_ITVL_Pos (0UL)
#define R_DMAC_B0_GRP_CH_CHEXT_SPR_Msk (0x00000007UL)
#define R_DMAC_B0_GRP_CH_CHEXT_SPR_Pos (0UL)
#define R_DMAC_B0_GRP_CH_CHEXT_SCA_Msk (0x000000F0UL)
#define R_DMAC_B0_GRP_CH_CHEXT_SCA_Pos (4UL)
#define R_DMAC_B0_GRP_CH_CHEXT_DPR_Msk (0x00000700UL)
#define R_DMAC_B0_GRP_CH_CHEXT_DPR_Pos (8UL)
#define R_DMAC_B0_GRP_CH_CHEXT_DCA_Msk (0x0000F000UL)
#define R_DMAC_B0_GRP_CH_CHEXT_DCA_Pos (12UL)
#define R_DMAC_B0_GRP_DCTRL_PR_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_DCTRL_PR_Pos (0UL)
#define R_DMAC_B0_GRP_DCTRL_LVINT_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_DCTRL_LVINT_Pos (1UL)
#define R_DMAC_B0_GRP_DCTRL_LDPR_Msk (0x00070000UL)
#define R_DMAC_B0_GRP_DCTRL_LDPR_Pos (16UL)
#define R_DMAC_B0_GRP_DCTRL_LDCA_Msk (0x00F00000UL)
#define R_DMAC_B0_GRP_DCTRL_LDCA_Pos (20UL)
#define R_DMAC_B0_GRP_DCTRL_LWPR_Msk (0x07000000UL)
#define R_DMAC_B0_GRP_DCTRL_LWPR_Pos (24UL)
#define R_DMAC_B0_GRP_DCTRL_LWCA_Msk (0xF0000000UL)
#define R_DMAC_B0_GRP_DCTRL_LWCA_Pos (28UL)
#define R_DMAC_B0_GRP_DST_EN_EN0_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_DST_EN_EN0_Pos (0UL)
#define R_DMAC_B0_GRP_DST_EN_EN1_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_DST_EN_EN1_Pos (1UL)
#define R_DMAC_B0_GRP_DST_EN_EN2_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_DST_EN_EN2_Pos (2UL)
#define R_DMAC_B0_GRP_DST_EN_EN3_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_DST_EN_EN3_Pos (3UL)
#define R_DMAC_B0_GRP_DST_EN_EN4_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_DST_EN_EN4_Pos (4UL)
#define R_DMAC_B0_GRP_DST_EN_EN5_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_DST_EN_EN5_Pos (5UL)
#define R_DMAC_B0_GRP_DST_EN_EN6_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_DST_EN_EN6_Pos (6UL)
#define R_DMAC_B0_GRP_DST_EN_EN7_Msk (0x00000080UL)
#define R_DMAC_B0_GRP_DST_EN_EN7_Pos (7UL)
#define R_DMAC_B0_GRP_DST_ER_ER0_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_DST_ER_ER0_Pos (0UL)
#define R_DMAC_B0_GRP_DST_ER_ER1_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_DST_ER_ER1_Pos (1UL)
#define R_DMAC_B0_GRP_DST_ER_ER2_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_DST_ER_ER2_Pos (2UL)
#define R_DMAC_B0_GRP_DST_ER_ER3_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_DST_ER_ER3_Pos (3UL)
#define R_DMAC_B0_GRP_DST_ER_ER4_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_DST_ER_ER4_Pos (4UL)
#define R_DMAC_B0_GRP_DST_ER_ER5_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_DST_ER_ER5_Pos (5UL)
#define R_DMAC_B0_GRP_DST_ER_ER6_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_DST_ER_ER6_Pos (6UL)
#define R_DMAC_B0_GRP_DST_ER_ER7_Msk (0x00000080UL)
#define R_DMAC_B0_GRP_DST_ER_ER7_Pos (7UL)
#define R_DMAC_B0_GRP_DST_END_END0_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_DST_END_END0_Pos (0UL)
#define R_DMAC_B0_GRP_DST_END_END1_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_DST_END_END1_Pos (1UL)
#define R_DMAC_B0_GRP_DST_END_END2_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_DST_END_END2_Pos (2UL)
#define R_DMAC_B0_GRP_DST_END_END3_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_DST_END_END3_Pos (3UL)
#define R_DMAC_B0_GRP_DST_END_END4_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_DST_END_END4_Pos (4UL)
#define R_DMAC_B0_GRP_DST_END_END5_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_DST_END_END5_Pos (5UL)
#define R_DMAC_B0_GRP_DST_END_END6_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_DST_END_END6_Pos (6UL)
#define R_DMAC_B0_GRP_DST_END_END7_Msk (0x00000080UL)
#define R_DMAC_B0_GRP_DST_END_END7_Pos (7UL)
#define R_DMAC_B0_GRP_DST_TC_TC0_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_DST_TC_TC0_Pos (0UL)
#define R_DMAC_B0_GRP_DST_TC_TC1_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_DST_TC_TC1_Pos (1UL)
#define R_DMAC_B0_GRP_DST_TC_TC2_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_DST_TC_TC2_Pos (2UL)
#define R_DMAC_B0_GRP_DST_TC_TC3_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_DST_TC_TC3_Pos (3UL)
#define R_DMAC_B0_GRP_DST_TC_TC4_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_DST_TC_TC4_Pos (4UL)
#define R_DMAC_B0_GRP_DST_TC_TC5_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_DST_TC_TC5_Pos (5UL)
#define R_DMAC_B0_GRP_DST_TC_TC6_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_DST_TC_TC6_Pos (6UL)
#define R_DMAC_B0_GRP_DST_TC_TC7_Msk (0x00000080UL)
#define R_DMAC_B0_GRP_DST_TC_TC7_Pos (7UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS0_Msk (0x00000001UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS0_Pos (0UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS1_Msk (0x00000002UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS1_Pos (1UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS2_Msk (0x00000004UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS2_Pos (2UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS3_Msk (0x00000008UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS3_Pos (3UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS4_Msk (0x00000010UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS4_Pos (4UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS5_Msk (0x00000020UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS5_Pos (5UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS6_Msk (0x00000040UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS6_Pos (6UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS7_Msk (0x00000080UL)
#define R_DMAC_B0_GRP_DST_SUS_SUS7_Pos (7UL)
#endif

View File

@ -0,0 +1,519 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : gpt_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for gpt.
*********************************************************************************************************************/
#ifndef GPT_IOBITMASK_H
#define GPT_IOBITMASK_H
#define R_GPT0_GTWP_WP_Msk (0x00000001UL)
#define R_GPT0_GTWP_WP_Pos (0UL)
#define R_GPT0_GTWP_PRKEY_Msk (0x0000FF00UL)
#define R_GPT0_GTWP_PRKEY_Pos (8UL)
#define R_GPT0_GTSTR_CSTRT0_Msk (0x00000001UL)
#define R_GPT0_GTSTR_CSTRT0_Pos (0UL)
#define R_GPT0_GTSTR_CSTRT1_Msk (0x00000002UL)
#define R_GPT0_GTSTR_CSTRT1_Pos (1UL)
#define R_GPT0_GTSTR_CSTRT2_Msk (0x00000004UL)
#define R_GPT0_GTSTR_CSTRT2_Pos (2UL)
#define R_GPT0_GTSTR_CSTRT3_Msk (0x00000008UL)
#define R_GPT0_GTSTR_CSTRT3_Pos (3UL)
#define R_GPT0_GTSTR_CSTRT4_Msk (0x00000010UL)
#define R_GPT0_GTSTR_CSTRT4_Pos (4UL)
#define R_GPT0_GTSTR_CSTRT5_Msk (0x00000020UL)
#define R_GPT0_GTSTR_CSTRT5_Pos (5UL)
#define R_GPT0_GTSTR_CSTRT6_Msk (0x00000040UL)
#define R_GPT0_GTSTR_CSTRT6_Pos (6UL)
#define R_GPT0_GTSTR_CSTRT7_Msk (0x00000080UL)
#define R_GPT0_GTSTR_CSTRT7_Pos (7UL)
#define R_GPT0_GTSTP_CSTOP0_Msk (0x00000001UL)
#define R_GPT0_GTSTP_CSTOP0_Pos (0UL)
#define R_GPT0_GTSTP_CSTOP1_Msk (0x00000002UL)
#define R_GPT0_GTSTP_CSTOP1_Pos (1UL)
#define R_GPT0_GTSTP_CSTOP2_Msk (0x00000004UL)
#define R_GPT0_GTSTP_CSTOP2_Pos (2UL)
#define R_GPT0_GTSTP_CSTOP3_Msk (0x00000008UL)
#define R_GPT0_GTSTP_CSTOP3_Pos (3UL)
#define R_GPT0_GTSTP_CSTOP4_Msk (0x00000010UL)
#define R_GPT0_GTSTP_CSTOP4_Pos (4UL)
#define R_GPT0_GTSTP_CSTOP5_Msk (0x00000020UL)
#define R_GPT0_GTSTP_CSTOP5_Pos (5UL)
#define R_GPT0_GTSTP_CSTOP6_Msk (0x00000040UL)
#define R_GPT0_GTSTP_CSTOP6_Pos (6UL)
#define R_GPT0_GTSTP_CSTOP7_Msk (0x00000080UL)
#define R_GPT0_GTSTP_CSTOP7_Pos (7UL)
#define R_GPT0_GTCLR_CCLR0_Msk (0x00000001UL)
#define R_GPT0_GTCLR_CCLR0_Pos (0UL)
#define R_GPT0_GTCLR_CCLR1_Msk (0x00000002UL)
#define R_GPT0_GTCLR_CCLR1_Pos (1UL)
#define R_GPT0_GTCLR_CCLR2_Msk (0x00000004UL)
#define R_GPT0_GTCLR_CCLR2_Pos (2UL)
#define R_GPT0_GTCLR_CCLR3_Msk (0x00000008UL)
#define R_GPT0_GTCLR_CCLR3_Pos (3UL)
#define R_GPT0_GTCLR_CCLR4_Msk (0x00000010UL)
#define R_GPT0_GTCLR_CCLR4_Pos (4UL)
#define R_GPT0_GTCLR_CCLR5_Msk (0x00000020UL)
#define R_GPT0_GTCLR_CCLR5_Pos (5UL)
#define R_GPT0_GTCLR_CCLR6_Msk (0x00000040UL)
#define R_GPT0_GTCLR_CCLR6_Pos (6UL)
#define R_GPT0_GTCLR_CCLR7_Msk (0x00000080UL)
#define R_GPT0_GTCLR_CCLR7_Pos (7UL)
#define R_GPT0_GTSSR_SSGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTSSR_SSGTRGAR_Pos (0UL)
#define R_GPT0_GTSSR_SSGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTSSR_SSGTRGAF_Pos (1UL)
#define R_GPT0_GTSSR_SSGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTSSR_SSGTRGBR_Pos (2UL)
#define R_GPT0_GTSSR_SSGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTSSR_SSGTRGBF_Pos (3UL)
#define R_GPT0_GTSSR_SSGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTSSR_SSGTRGCR_Pos (4UL)
#define R_GPT0_GTSSR_SSGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTSSR_SSGTRGCF_Pos (5UL)
#define R_GPT0_GTSSR_SSGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTSSR_SSGTRGDR_Pos (6UL)
#define R_GPT0_GTSSR_SSGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTSSR_SSGTRGDF_Pos (7UL)
#define R_GPT0_GTSSR_SSCARBL_Msk (0x00000100UL)
#define R_GPT0_GTSSR_SSCARBL_Pos (8UL)
#define R_GPT0_GTSSR_SSCARBH_Msk (0x00000200UL)
#define R_GPT0_GTSSR_SSCARBH_Pos (9UL)
#define R_GPT0_GTSSR_SSCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTSSR_SSCAFBL_Pos (10UL)
#define R_GPT0_GTSSR_SSCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTSSR_SSCAFBH_Pos (11UL)
#define R_GPT0_GTSSR_SSCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTSSR_SSCBRAL_Pos (12UL)
#define R_GPT0_GTSSR_SSCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTSSR_SSCBRAH_Pos (13UL)
#define R_GPT0_GTSSR_SSCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTSSR_SSCBFAL_Pos (14UL)
#define R_GPT0_GTSSR_SSCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTSSR_SSCBFAH_Pos (15UL)
#define R_GPT0_GTSSR_CSTRT_Msk (0x80000000UL)
#define R_GPT0_GTSSR_CSTRT_Pos (31UL)
#define R_GPT0_GTPSR_PSGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTPSR_PSGTRGAR_Pos (0UL)
#define R_GPT0_GTPSR_PSGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTPSR_PSGTRGAF_Pos (1UL)
#define R_GPT0_GTPSR_PSGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTPSR_PSGTRGBR_Pos (2UL)
#define R_GPT0_GTPSR_PSGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTPSR_PSGTRGBF_Pos (3UL)
#define R_GPT0_GTPSR_PSGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTPSR_PSGTRGCR_Pos (4UL)
#define R_GPT0_GTPSR_PSGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTPSR_PSGTRGCF_Pos (5UL)
#define R_GPT0_GTPSR_PSGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTPSR_PSGTRGDR_Pos (6UL)
#define R_GPT0_GTPSR_PSGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTPSR_PSGTRGDF_Pos (7UL)
#define R_GPT0_GTPSR_PSCARBL_Msk (0x00000100UL)
#define R_GPT0_GTPSR_PSCARBL_Pos (8UL)
#define R_GPT0_GTPSR_PSCARBH_Msk (0x00000200UL)
#define R_GPT0_GTPSR_PSCARBH_Pos (9UL)
#define R_GPT0_GTPSR_PSCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTPSR_PSCAFBL_Pos (10UL)
#define R_GPT0_GTPSR_PSCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTPSR_PSCAFBH_Pos (11UL)
#define R_GPT0_GTPSR_PSCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTPSR_PSCBRAL_Pos (12UL)
#define R_GPT0_GTPSR_PSCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTPSR_PSCBRAH_Pos (13UL)
#define R_GPT0_GTPSR_PSCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTPSR_PSCBFAL_Pos (14UL)
#define R_GPT0_GTPSR_PSCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTPSR_PSCBFAH_Pos (15UL)
#define R_GPT0_GTPSR_CSTOP_Msk (0x80000000UL)
#define R_GPT0_GTPSR_CSTOP_Pos (31UL)
#define R_GPT0_GTCSR_CSGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTCSR_CSGTRGAR_Pos (0UL)
#define R_GPT0_GTCSR_CSGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTCSR_CSGTRGAF_Pos (1UL)
#define R_GPT0_GTCSR_CSGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTCSR_CSGTRGBR_Pos (2UL)
#define R_GPT0_GTCSR_CSGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTCSR_CSGTRGBF_Pos (3UL)
#define R_GPT0_GTCSR_CSGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTCSR_CSGTRGCR_Pos (4UL)
#define R_GPT0_GTCSR_CSGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTCSR_CSGTRGCF_Pos (5UL)
#define R_GPT0_GTCSR_CSGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTCSR_CSGTRGDR_Pos (6UL)
#define R_GPT0_GTCSR_CSGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTCSR_CSGTRGDF_Pos (7UL)
#define R_GPT0_GTCSR_CSCARBL_Msk (0x00000100UL)
#define R_GPT0_GTCSR_CSCARBL_Pos (8UL)
#define R_GPT0_GTCSR_CSCARBH_Msk (0x00000200UL)
#define R_GPT0_GTCSR_CSCARBH_Pos (9UL)
#define R_GPT0_GTCSR_CSCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTCSR_CSCAFBL_Pos (10UL)
#define R_GPT0_GTCSR_CSCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTCSR_CSCAFBH_Pos (11UL)
#define R_GPT0_GTCSR_CSCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTCSR_CSCBRAL_Pos (12UL)
#define R_GPT0_GTCSR_CSCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTCSR_CSCBRAH_Pos (13UL)
#define R_GPT0_GTCSR_CSCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTCSR_CSCBFAL_Pos (14UL)
#define R_GPT0_GTCSR_CSCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTCSR_CSCBFAH_Pos (15UL)
#define R_GPT0_GTCSR_CCLR_Msk (0x80000000UL)
#define R_GPT0_GTCSR_CCLR_Pos (31UL)
#define R_GPT0_GTUPSR_USGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTUPSR_USGTRGAR_Pos (0UL)
#define R_GPT0_GTUPSR_USGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTUPSR_USGTRGAF_Pos (1UL)
#define R_GPT0_GTUPSR_USGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTUPSR_USGTRGBR_Pos (2UL)
#define R_GPT0_GTUPSR_USGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTUPSR_USGTRGBF_Pos (3UL)
#define R_GPT0_GTUPSR_USGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTUPSR_USGTRGCR_Pos (4UL)
#define R_GPT0_GTUPSR_USGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTUPSR_USGTRGCF_Pos (5UL)
#define R_GPT0_GTUPSR_USGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTUPSR_USGTRGDR_Pos (6UL)
#define R_GPT0_GTUPSR_USGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTUPSR_USGTRGDF_Pos (7UL)
#define R_GPT0_GTUPSR_USCARBL_Msk (0x00000100UL)
#define R_GPT0_GTUPSR_USCARBL_Pos (8UL)
#define R_GPT0_GTUPSR_USCARBH_Msk (0x00000200UL)
#define R_GPT0_GTUPSR_USCARBH_Pos (9UL)
#define R_GPT0_GTUPSR_USCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTUPSR_USCAFBL_Pos (10UL)
#define R_GPT0_GTUPSR_USCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTUPSR_USCAFBH_Pos (11UL)
#define R_GPT0_GTUPSR_USCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTUPSR_USCBRAL_Pos (12UL)
#define R_GPT0_GTUPSR_USCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTUPSR_USCBRAH_Pos (13UL)
#define R_GPT0_GTUPSR_USCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTUPSR_USCBFAL_Pos (14UL)
#define R_GPT0_GTUPSR_USCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTUPSR_USCBFAH_Pos (15UL)
#define R_GPT0_GTDNSR_DSGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTDNSR_DSGTRGAR_Pos (0UL)
#define R_GPT0_GTDNSR_DSGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTDNSR_DSGTRGAF_Pos (1UL)
#define R_GPT0_GTDNSR_DSGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTDNSR_DSGTRGBR_Pos (2UL)
#define R_GPT0_GTDNSR_DSGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTDNSR_DSGTRGBF_Pos (3UL)
#define R_GPT0_GTDNSR_DSGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTDNSR_DSGTRGCR_Pos (4UL)
#define R_GPT0_GTDNSR_DSGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTDNSR_DSGTRGCF_Pos (5UL)
#define R_GPT0_GTDNSR_DSGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTDNSR_DSGTRGDR_Pos (6UL)
#define R_GPT0_GTDNSR_DSGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTDNSR_DSGTRGDF_Pos (7UL)
#define R_GPT0_GTDNSR_DSCARBL_Msk (0x00000100UL)
#define R_GPT0_GTDNSR_DSCARBL_Pos (8UL)
#define R_GPT0_GTDNSR_DSCARBH_Msk (0x00000200UL)
#define R_GPT0_GTDNSR_DSCARBH_Pos (9UL)
#define R_GPT0_GTDNSR_DSCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTDNSR_DSCAFBL_Pos (10UL)
#define R_GPT0_GTDNSR_DSCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTDNSR_DSCAFBH_Pos (11UL)
#define R_GPT0_GTDNSR_DSCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTDNSR_DSCBRAL_Pos (12UL)
#define R_GPT0_GTDNSR_DSCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTDNSR_DSCBRAH_Pos (13UL)
#define R_GPT0_GTDNSR_DSCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTDNSR_DSCBFAL_Pos (14UL)
#define R_GPT0_GTDNSR_DSCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTDNSR_DSCBFAH_Pos (15UL)
#define R_GPT0_GTICASR_ASGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTICASR_ASGTRGAR_Pos (0UL)
#define R_GPT0_GTICASR_ASGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTICASR_ASGTRGAF_Pos (1UL)
#define R_GPT0_GTICASR_ASGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTICASR_ASGTRGBR_Pos (2UL)
#define R_GPT0_GTICASR_ASGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTICASR_ASGTRGBF_Pos (3UL)
#define R_GPT0_GTICASR_ASGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTICASR_ASGTRGCR_Pos (4UL)
#define R_GPT0_GTICASR_ASGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTICASR_ASGTRGCF_Pos (5UL)
#define R_GPT0_GTICASR_ASGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTICASR_ASGTRGDR_Pos (6UL)
#define R_GPT0_GTICASR_ASGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTICASR_ASGTRGDF_Pos (7UL)
#define R_GPT0_GTICASR_ASCARBL_Msk (0x00000100UL)
#define R_GPT0_GTICASR_ASCARBL_Pos (8UL)
#define R_GPT0_GTICASR_ASCARBH_Msk (0x00000200UL)
#define R_GPT0_GTICASR_ASCARBH_Pos (9UL)
#define R_GPT0_GTICASR_ASCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTICASR_ASCAFBL_Pos (10UL)
#define R_GPT0_GTICASR_ASCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTICASR_ASCAFBH_Pos (11UL)
#define R_GPT0_GTICASR_ASCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTICASR_ASCBRAL_Pos (12UL)
#define R_GPT0_GTICASR_ASCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTICASR_ASCBRAH_Pos (13UL)
#define R_GPT0_GTICASR_ASCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTICASR_ASCBFAL_Pos (14UL)
#define R_GPT0_GTICASR_ASCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTICASR_ASCBFAH_Pos (15UL)
#define R_GPT0_GTICBSR_BSGTRGAR_Msk (0x00000001UL)
#define R_GPT0_GTICBSR_BSGTRGAR_Pos (0UL)
#define R_GPT0_GTICBSR_BSGTRGAF_Msk (0x00000002UL)
#define R_GPT0_GTICBSR_BSGTRGAF_Pos (1UL)
#define R_GPT0_GTICBSR_BSGTRGBR_Msk (0x00000004UL)
#define R_GPT0_GTICBSR_BSGTRGBR_Pos (2UL)
#define R_GPT0_GTICBSR_BSGTRGBF_Msk (0x00000008UL)
#define R_GPT0_GTICBSR_BSGTRGBF_Pos (3UL)
#define R_GPT0_GTICBSR_BSGTRGCR_Msk (0x00000010UL)
#define R_GPT0_GTICBSR_BSGTRGCR_Pos (4UL)
#define R_GPT0_GTICBSR_BSGTRGCF_Msk (0x00000020UL)
#define R_GPT0_GTICBSR_BSGTRGCF_Pos (5UL)
#define R_GPT0_GTICBSR_BSGTRGDR_Msk (0x00000040UL)
#define R_GPT0_GTICBSR_BSGTRGDR_Pos (6UL)
#define R_GPT0_GTICBSR_BSGTRGDF_Msk (0x00000080UL)
#define R_GPT0_GTICBSR_BSGTRGDF_Pos (7UL)
#define R_GPT0_GTICBSR_BSCARBL_Msk (0x00000100UL)
#define R_GPT0_GTICBSR_BSCARBL_Pos (8UL)
#define R_GPT0_GTICBSR_BSCARBH_Msk (0x00000200UL)
#define R_GPT0_GTICBSR_BSCARBH_Pos (9UL)
#define R_GPT0_GTICBSR_BSCAFBL_Msk (0x00000400UL)
#define R_GPT0_GTICBSR_BSCAFBL_Pos (10UL)
#define R_GPT0_GTICBSR_BSCAFBH_Msk (0x00000800UL)
#define R_GPT0_GTICBSR_BSCAFBH_Pos (11UL)
#define R_GPT0_GTICBSR_BSCBRAL_Msk (0x00001000UL)
#define R_GPT0_GTICBSR_BSCBRAL_Pos (12UL)
#define R_GPT0_GTICBSR_BSCBRAH_Msk (0x00002000UL)
#define R_GPT0_GTICBSR_BSCBRAH_Pos (13UL)
#define R_GPT0_GTICBSR_BSCBFAL_Msk (0x00004000UL)
#define R_GPT0_GTICBSR_BSCBFAL_Pos (14UL)
#define R_GPT0_GTICBSR_BSCBFAH_Msk (0x00008000UL)
#define R_GPT0_GTICBSR_BSCBFAH_Pos (15UL)
#define R_GPT0_GTCR_CST_Msk (0x00000001UL)
#define R_GPT0_GTCR_CST_Pos (0UL)
#define R_GPT0_GTCR_MD_Msk (0x00070000UL)
#define R_GPT0_GTCR_MD_Pos (16UL)
#define R_GPT0_GTCR_TPCS_Msk (0x07000000UL)
#define R_GPT0_GTCR_TPCS_Pos (24UL)
#define R_GPT0_GTUDDTYC_UD_Msk (0x00000001UL)
#define R_GPT0_GTUDDTYC_UD_Pos (0UL)
#define R_GPT0_GTUDDTYC_UDF_Msk (0x00000002UL)
#define R_GPT0_GTUDDTYC_UDF_Pos (1UL)
#define R_GPT0_GTUDDTYC_OADTY_Msk (0x00030000UL)
#define R_GPT0_GTUDDTYC_OADTY_Pos (16UL)
#define R_GPT0_GTUDDTYC_OADTYF_Msk (0x00040000UL)
#define R_GPT0_GTUDDTYC_OADTYF_Pos (18UL)
#define R_GPT0_GTUDDTYC_OADTYR_Msk (0x00080000UL)
#define R_GPT0_GTUDDTYC_OADTYR_Pos (19UL)
#define R_GPT0_GTUDDTYC_OBDTY_Msk (0x03000000UL)
#define R_GPT0_GTUDDTYC_OBDTY_Pos (24UL)
#define R_GPT0_GTUDDTYC_OBDTYF_Msk (0x04000000UL)
#define R_GPT0_GTUDDTYC_OBDTYF_Pos (26UL)
#define R_GPT0_GTUDDTYC_OBDTYR_Msk (0x08000000UL)
#define R_GPT0_GTUDDTYC_OBDTYR_Pos (27UL)
#define R_GPT0_GTIOR_GTIOA_Msk (0x0000001FUL)
#define R_GPT0_GTIOR_GTIOA_Pos (0UL)
#define R_GPT0_GTIOR_OADFLT_Msk (0x00000040UL)
#define R_GPT0_GTIOR_OADFLT_Pos (6UL)
#define R_GPT0_GTIOR_OAHLD_Msk (0x00000080UL)
#define R_GPT0_GTIOR_OAHLD_Pos (7UL)
#define R_GPT0_GTIOR_OAE_Msk (0x00000100UL)
#define R_GPT0_GTIOR_OAE_Pos (8UL)
#define R_GPT0_GTIOR_OADF_Msk (0x00000600UL)
#define R_GPT0_GTIOR_OADF_Pos (9UL)
#define R_GPT0_GTIOR_NFAEN_Msk (0x00002000UL)
#define R_GPT0_GTIOR_NFAEN_Pos (13UL)
#define R_GPT0_GTIOR_NFCSA_Msk (0x0000C000UL)
#define R_GPT0_GTIOR_NFCSA_Pos (14UL)
#define R_GPT0_GTIOR_GTIOB_Msk (0x001F0000UL)
#define R_GPT0_GTIOR_GTIOB_Pos (16UL)
#define R_GPT0_GTIOR_OBDFLT_Msk (0x00400000UL)
#define R_GPT0_GTIOR_OBDFLT_Pos (22UL)
#define R_GPT0_GTIOR_OBHLD_Msk (0x00800000UL)
#define R_GPT0_GTIOR_OBHLD_Pos (23UL)
#define R_GPT0_GTIOR_OBE_Msk (0x01000000UL)
#define R_GPT0_GTIOR_OBE_Pos (24UL)
#define R_GPT0_GTIOR_OBDF_Msk (0x06000000UL)
#define R_GPT0_GTIOR_OBDF_Pos (25UL)
#define R_GPT0_GTIOR_NFBEN_Msk (0x20000000UL)
#define R_GPT0_GTIOR_NFBEN_Pos (29UL)
#define R_GPT0_GTIOR_NFCSB_Msk (0xC0000000UL)
#define R_GPT0_GTIOR_NFCSB_Pos (30UL)
#define R_GPT0_GTINTAD_GTINTA_Msk (0x00000001UL)
#define R_GPT0_GTINTAD_GTINTA_Pos (0UL)
#define R_GPT0_GTINTAD_GTINTB_Msk (0x00000002UL)
#define R_GPT0_GTINTAD_GTINTB_Pos (1UL)
#define R_GPT0_GTINTAD_GTINTC_Msk (0x00000004UL)
#define R_GPT0_GTINTAD_GTINTC_Pos (2UL)
#define R_GPT0_GTINTAD_GTINTD_Msk (0x00000008UL)
#define R_GPT0_GTINTAD_GTINTD_Pos (3UL)
#define R_GPT0_GTINTAD_GTINTE_Msk (0x00000010UL)
#define R_GPT0_GTINTAD_GTINTE_Pos (4UL)
#define R_GPT0_GTINTAD_GTINTF_Msk (0x00000020UL)
#define R_GPT0_GTINTAD_GTINTF_Pos (5UL)
#define R_GPT0_GTINTAD_GTINTPR_Msk (0x000000C0UL)
#define R_GPT0_GTINTAD_GTINTPR_Pos (6UL)
#define R_GPT0_GTINTAD_ADTRAUEN_Msk (0x00010000UL)
#define R_GPT0_GTINTAD_ADTRAUEN_Pos (16UL)
#define R_GPT0_GTINTAD_ADTRADEN_Msk (0x00020000UL)
#define R_GPT0_GTINTAD_ADTRADEN_Pos (17UL)
#define R_GPT0_GTINTAD_ADTRBUEN_Msk (0x00040000UL)
#define R_GPT0_GTINTAD_ADTRBUEN_Pos (18UL)
#define R_GPT0_GTINTAD_ADTRBDEN_Msk (0x00080000UL)
#define R_GPT0_GTINTAD_ADTRBDEN_Pos (19UL)
#define R_GPT0_GTINTAD_GRP_Msk (0x03000000UL)
#define R_GPT0_GTINTAD_GRP_Pos (24UL)
#define R_GPT0_GTINTAD_GRPDTE_Msk (0x10000000UL)
#define R_GPT0_GTINTAD_GRPDTE_Pos (28UL)
#define R_GPT0_GTINTAD_GRPABH_Msk (0x20000000UL)
#define R_GPT0_GTINTAD_GRPABH_Pos (29UL)
#define R_GPT0_GTINTAD_GRPABL_Msk (0x40000000UL)
#define R_GPT0_GTINTAD_GRPABL_Pos (30UL)
#define R_GPT0_GTST_TCFA_Msk (0x00000001UL)
#define R_GPT0_GTST_TCFA_Pos (0UL)
#define R_GPT0_GTST_TCFB_Msk (0x00000002UL)
#define R_GPT0_GTST_TCFB_Pos (1UL)
#define R_GPT0_GTST_TCFC_Msk (0x00000004UL)
#define R_GPT0_GTST_TCFC_Pos (2UL)
#define R_GPT0_GTST_TCFD_Msk (0x00000008UL)
#define R_GPT0_GTST_TCFD_Pos (3UL)
#define R_GPT0_GTST_TCFE_Msk (0x00000010UL)
#define R_GPT0_GTST_TCFE_Pos (4UL)
#define R_GPT0_GTST_TCFF_Msk (0x00000020UL)
#define R_GPT0_GTST_TCFF_Pos (5UL)
#define R_GPT0_GTST_TCFPO_Msk (0x00000040UL)
#define R_GPT0_GTST_TCFPO_Pos (6UL)
#define R_GPT0_GTST_TCFPU_Msk (0x00000080UL)
#define R_GPT0_GTST_TCFPU_Pos (7UL)
#define R_GPT0_GTST_ITCNT_Msk (0x00000700UL)
#define R_GPT0_GTST_ITCNT_Pos (8UL)
#define R_GPT0_GTST_TUCF_Msk (0x00008000UL)
#define R_GPT0_GTST_TUCF_Pos (15UL)
#define R_GPT0_GTST_ADTRAUF_Msk (0x00010000UL)
#define R_GPT0_GTST_ADTRAUF_Pos (16UL)
#define R_GPT0_GTST_ADTRADF_Msk (0x00020000UL)
#define R_GPT0_GTST_ADTRADF_Pos (17UL)
#define R_GPT0_GTST_ADTRBUF_Msk (0x00040000UL)
#define R_GPT0_GTST_ADTRBUF_Pos (18UL)
#define R_GPT0_GTST_ADTRBDF_Msk (0x00080000UL)
#define R_GPT0_GTST_ADTRBDF_Pos (19UL)
#define R_GPT0_GTST_ODF_Msk (0x01000000UL)
#define R_GPT0_GTST_ODF_Pos (24UL)
#define R_GPT0_GTST_DTEF_Msk (0x10000000UL)
#define R_GPT0_GTST_DTEF_Pos (28UL)
#define R_GPT0_GTST_OABHF_Msk (0x20000000UL)
#define R_GPT0_GTST_OABHF_Pos (29UL)
#define R_GPT0_GTST_OABLF_Msk (0x40000000UL)
#define R_GPT0_GTST_OABLF_Pos (30UL)
#define R_GPT0_GTBER_BD_Msk (0x0000000FUL)
#define R_GPT0_GTBER_BD_Pos (0UL)
#define R_GPT0_GTBER_CCRA_Msk (0x00030000UL)
#define R_GPT0_GTBER_CCRA_Pos (16UL)
#define R_GPT0_GTBER_CCRB_Msk (0x000C0000UL)
#define R_GPT0_GTBER_CCRB_Pos (18UL)
#define R_GPT0_GTBER_PR_Msk (0x00300000UL)
#define R_GPT0_GTBER_PR_Pos (20UL)
#define R_GPT0_GTBER_CCRSWT_Msk (0x00400000UL)
#define R_GPT0_GTBER_CCRSWT_Pos (22UL)
#define R_GPT0_GTBER_ADTTA_Msk (0x03000000UL)
#define R_GPT0_GTBER_ADTTA_Pos (24UL)
#define R_GPT0_GTBER_ADTDA_Msk (0x04000000UL)
#define R_GPT0_GTBER_ADTDA_Pos (26UL)
#define R_GPT0_GTBER_ADTTB_Msk (0x30000000UL)
#define R_GPT0_GTBER_ADTTB_Pos (28UL)
#define R_GPT0_GTBER_ADTDB_Msk (0x40000000UL)
#define R_GPT0_GTBER_ADTDB_Pos (30UL)
#define R_GPT0_GTITC_ITLA_Msk (0x00000001UL)
#define R_GPT0_GTITC_ITLA_Pos (0UL)
#define R_GPT0_GTITC_ITLB_Msk (0x00000002UL)
#define R_GPT0_GTITC_ITLB_Pos (1UL)
#define R_GPT0_GTITC_ITLC_Msk (0x00000004UL)
#define R_GPT0_GTITC_ITLC_Pos (2UL)
#define R_GPT0_GTITC_ITLD_Msk (0x00000008UL)
#define R_GPT0_GTITC_ITLD_Pos (3UL)
#define R_GPT0_GTITC_ITLE_Msk (0x00000010UL)
#define R_GPT0_GTITC_ITLE_Pos (4UL)
#define R_GPT0_GTITC_ITLF_Msk (0x00000020UL)
#define R_GPT0_GTITC_ITLF_Pos (5UL)
#define R_GPT0_GTITC_IVTC_Msk (0x000000C0UL)
#define R_GPT0_GTITC_IVTC_Pos (6UL)
#define R_GPT0_GTITC_IVTT_Msk (0x00000700UL)
#define R_GPT0_GTITC_IVTT_Pos (8UL)
#define R_GPT0_GTITC_ADTAL_Msk (0x00001000UL)
#define R_GPT0_GTITC_ADTAL_Pos (12UL)
#define R_GPT0_GTITC_ADTBL_Msk (0x00004000UL)
#define R_GPT0_GTITC_ADTBL_Pos (14UL)
#define R_GPT0_GTCNT_GTCNT_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCNT_GTCNT_Pos (0UL)
#define R_GPT0_GTCCRA_GTCCRA_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCCRA_GTCCRA_Pos (0UL)
#define R_GPT0_GTCCRB_GTCCRB_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCCRB_GTCCRB_Pos (0UL)
#define R_GPT0_GTCCRC_GTCCRC_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCCRC_GTCCRC_Pos (0UL)
#define R_GPT0_GTCCRE_GTCCRE_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCCRE_GTCCRE_Pos (0UL)
#define R_GPT0_GTCCRD_GTCCRD_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCCRD_GTCCRD_Pos (0UL)
#define R_GPT0_GTCCRF_GTCCRF_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTCCRF_GTCCRF_Pos (0UL)
#define R_GPT0_GTPR_GTPR_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTPR_GTPR_Pos (0UL)
#define R_GPT0_GTPBR_GTPBR_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTPBR_GTPBR_Pos (0UL)
#define R_GPT0_GTPDBR_GTPDBR_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTPDBR_GTPDBR_Pos (0UL)
#define R_GPT0_GTADTRA_GTADTRA_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTADTRA_GTADTRA_Pos (0UL)
#define R_GPT0_GTADTBRA_GTADTBRA_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTADTBRA_GTADTBRA_Pos (0UL)
#define R_GPT0_GTADTDBRA_GTADTDBRA_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTADTDBRA_GTADTDBRA_Pos (0UL)
#define R_GPT0_GTADTRB_GTADTRB_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTADTRB_GTADTRB_Pos (0UL)
#define R_GPT0_GTADTBRB_GTADTBRB_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTADTBRB_GTADTBRB_Pos (0UL)
#define R_GPT0_GTADTDBRB_GTADTDBRB_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTADTDBRB_GTADTDBRB_Pos (0UL)
#define R_GPT0_GTDTCR_TDE_Msk (0x00000001UL)
#define R_GPT0_GTDTCR_TDE_Pos (0UL)
#define R_GPT0_GTDTCR_TDBUE_Msk (0x00000010UL)
#define R_GPT0_GTDTCR_TDBUE_Pos (4UL)
#define R_GPT0_GTDTCR_TDBDE_Msk (0x00000020UL)
#define R_GPT0_GTDTCR_TDBDE_Pos (5UL)
#define R_GPT0_GTDTCR_TDFER_Msk (0x00000100UL)
#define R_GPT0_GTDTCR_TDFER_Pos (8UL)
#define R_GPT0_GTDVU_GTDVU_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTDVU_GTDVU_Pos (0UL)
#define R_GPT0_GTDVD_GTDVD_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTDVD_GTDVD_Pos (0UL)
#define R_GPT0_GTDBU_GTDBU_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTDBU_GTDBU_Pos (0UL)
#define R_GPT0_GTDBD_GTDBD_Msk (0xFFFFFFFFUL)
#define R_GPT0_GTDBD_GTDBD_Pos (0UL)
#define R_GPT0_GTSOS_SOS_Msk (0x00000003UL)
#define R_GPT0_GTSOS_SOS_Pos (0UL)
#define R_GPT0_GTSOTR_SOTR_Msk (0x00000001UL)
#define R_GPT0_GTSOTR_SOTR_Pos (0UL)
#endif /* GPT_IOBITMASK_H */

View File

@ -0,0 +1,45 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : gtm_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for gtm.
*********************************************************************************************************************/
#ifndef GTM_IOBITMASK_H
#define GTM_IOBITMASK_H
#define R_GTM0_OSTMnCMP_OSTMnCMP_Msk (0xFFFFFFFFUL)
#define R_GTM0_OSTMnCMP_OSTMnCMP_Pos (0UL)
#define R_GTM0_OSTMnCNT_OSTMnCNT_Msk (0xFFFFFFFFUL)
#define R_GTM0_OSTMnCNT_OSTMnCNT_Pos (0UL)
#define R_GTM0_OSTMnTE_OSTMnTE_Msk (0x01UL)
#define R_GTM0_OSTMnTE_OSTMnTE_Pos (0UL)
#define R_GTM0_OSTMnTS_OSTMnTS_Msk (0x01UL)
#define R_GTM0_OSTMnTS_OSTMnTS_Pos (0UL)
#define R_GTM0_OSTMnTT_OSTMnTT_Msk (0x01UL)
#define R_GTM0_OSTMnTT_OSTMnTT_Pos (0UL)
#define R_GTM0_OSTMnCTL_OSTMnMD0_Msk (0x01UL)
#define R_GTM0_OSTMnCTL_OSTMnMD0_Pos (0UL)
#define R_GTM0_OSTMnCTL_OSTMnMD1_Msk (0x02UL)
#define R_GTM0_OSTMnCTL_OSTMnMD1_Pos (1UL)
#endif /* GTM_IOBITMASK_H */

View File

@ -0,0 +1,511 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : intc_im33_iobitmask.h.h
* Version : 1.00
* Description : IO bit mask file for intc_im33.
*********************************************************************************************************************/
#ifndef INTC_IM33_IOBITMASK_H
#define INTC_IM33_IOBITMASK_H
#define R_INTC_IM33_NSCR_NSTAT_Msk (0x00000001UL)
#define R_INTC_IM33_NSCR_NSTAT_Pos (0UL)
#define R_INTC_IM33_NSCR_NSMON_Msk (0x00010000UL)
#define R_INTC_IM33_NSCR_NSMON_Pos (16UL)
#define R_INTC_IM33_NITSR_NTSEL_Msk (0x00000001UL)
#define R_INTC_IM33_NITSR_NTSEL_Pos (0UL)
#define R_INTC_IM33_ISCR_ISTAT0_Msk (0x00000001UL)
#define R_INTC_IM33_ISCR_ISTAT0_Pos (0UL)
#define R_INTC_IM33_ISCR_ISTAT1_Msk (0x00000002UL)
#define R_INTC_IM33_ISCR_ISTAT1_Pos (1UL)
#define R_INTC_IM33_ISCR_ISTAT2_Msk (0x00000004UL)
#define R_INTC_IM33_ISCR_ISTAT2_Pos (2UL)
#define R_INTC_IM33_ISCR_ISTAT3_Msk (0x00000008UL)
#define R_INTC_IM33_ISCR_ISTAT3_Pos (3UL)
#define R_INTC_IM33_ISCR_ISTAT4_Msk (0x00000010UL)
#define R_INTC_IM33_ISCR_ISTAT4_Pos (4UL)
#define R_INTC_IM33_ISCR_ISTAT5_Msk (0x00000020UL)
#define R_INTC_IM33_ISCR_ISTAT5_Pos (5UL)
#define R_INTC_IM33_ISCR_ISTAT6_Msk (0x00000040UL)
#define R_INTC_IM33_ISCR_ISTAT6_Pos (6UL)
#define R_INTC_IM33_ISCR_ISTAT7_Msk (0x00000080UL)
#define R_INTC_IM33_ISCR_ISTAT7_Pos (7UL)
#define R_INTC_IM33_IITSR_IITSEL0_Msk (0x00000003UL)
#define R_INTC_IM33_IITSR_IITSEL0_Pos (0UL)
#define R_INTC_IM33_IITSR_IITSEL1_Msk (0x0000000CUL)
#define R_INTC_IM33_IITSR_IITSEL1_Pos (2UL)
#define R_INTC_IM33_IITSR_IITSEL2_Msk (0x00000030UL)
#define R_INTC_IM33_IITSR_IITSEL2_Pos (4UL)
#define R_INTC_IM33_IITSR_IITSEL3_Msk (0x000000C0UL)
#define R_INTC_IM33_IITSR_IITSEL3_Pos (6UL)
#define R_INTC_IM33_IITSR_IITSEL4_Msk (0x00000300UL)
#define R_INTC_IM33_IITSR_IITSEL4_Pos (8UL)
#define R_INTC_IM33_IITSR_IITSEL5_Msk (0x00000C00UL)
#define R_INTC_IM33_IITSR_IITSEL5_Pos (10UL)
#define R_INTC_IM33_IITSR_IITSEL6_Msk (0x00003000UL)
#define R_INTC_IM33_IITSR_IITSEL6_Pos (12UL)
#define R_INTC_IM33_IITSR_IITSEL7_Msk (0x0000C000UL)
#define R_INTC_IM33_IITSR_IITSEL7_Pos (14UL)
#define R_INTC_IM33_TSCR_TSTAT0_Msk (0x00000001UL)
#define R_INTC_IM33_TSCR_TSTAT0_Pos (0UL)
#define R_INTC_IM33_TSCR_TSTAT1_Msk (0x00000002UL)
#define R_INTC_IM33_TSCR_TSTAT1_Pos (1UL)
#define R_INTC_IM33_TSCR_TSTAT2_Msk (0x00000004UL)
#define R_INTC_IM33_TSCR_TSTAT2_Pos (2UL)
#define R_INTC_IM33_TSCR_TSTAT3_Msk (0x00000008UL)
#define R_INTC_IM33_TSCR_TSTAT3_Pos (3UL)
#define R_INTC_IM33_TSCR_TSTAT4_Msk (0x00000010UL)
#define R_INTC_IM33_TSCR_TSTAT4_Pos (4UL)
#define R_INTC_IM33_TSCR_TSTAT5_Msk (0x00000020UL)
#define R_INTC_IM33_TSCR_TSTAT5_Pos (5UL)
#define R_INTC_IM33_TSCR_TSTAT6_Msk (0x00000040UL)
#define R_INTC_IM33_TSCR_TSTAT6_Pos (6UL)
#define R_INTC_IM33_TSCR_TSTAT7_Msk (0x00000080UL)
#define R_INTC_IM33_TSCR_TSTAT7_Pos (7UL)
#define R_INTC_IM33_TSCR_TSTAT8_Msk (0x00000100UL)
#define R_INTC_IM33_TSCR_TSTAT8_Pos (8UL)
#define R_INTC_IM33_TSCR_TSTAT9_Msk (0x00000200UL)
#define R_INTC_IM33_TSCR_TSTAT9_Pos (9UL)
#define R_INTC_IM33_TSCR_TSTAT10_Msk (0x00000400UL)
#define R_INTC_IM33_TSCR_TSTAT10_Pos (10UL)
#define R_INTC_IM33_TSCR_TSTAT11_Msk (0x00000800UL)
#define R_INTC_IM33_TSCR_TSTAT11_Pos (11UL)
#define R_INTC_IM33_TSCR_TSTAT12_Msk (0x00001000UL)
#define R_INTC_IM33_TSCR_TSTAT12_Pos (12UL)
#define R_INTC_IM33_TSCR_TSTAT13_Msk (0x00002000UL)
#define R_INTC_IM33_TSCR_TSTAT13_Pos (13UL)
#define R_INTC_IM33_TSCR_TSTAT14_Msk (0x00004000UL)
#define R_INTC_IM33_TSCR_TSTAT14_Pos (14UL)
#define R_INTC_IM33_TSCR_TSTAT15_Msk (0x00008000UL)
#define R_INTC_IM33_TSCR_TSTAT15_Pos (15UL)
#define R_INTC_IM33_TSCR_TSTAT16_Msk (0x00010000UL)
#define R_INTC_IM33_TSCR_TSTAT16_Pos (16UL)
#define R_INTC_IM33_TSCR_TSTAT17_Msk (0x00020000UL)
#define R_INTC_IM33_TSCR_TSTAT17_Pos (17UL)
#define R_INTC_IM33_TSCR_TSTAT18_Msk (0x00040000UL)
#define R_INTC_IM33_TSCR_TSTAT18_Pos (18UL)
#define R_INTC_IM33_TSCR_TSTAT19_Msk (0x00080000UL)
#define R_INTC_IM33_TSCR_TSTAT19_Pos (19UL)
#define R_INTC_IM33_TSCR_TSTAT20_Msk (0x00100000UL)
#define R_INTC_IM33_TSCR_TSTAT20_Pos (20UL)
#define R_INTC_IM33_TSCR_TSTAT21_Msk (0x00200000UL)
#define R_INTC_IM33_TSCR_TSTAT21_Pos (21UL)
#define R_INTC_IM33_TSCR_TSTAT22_Msk (0x00400000UL)
#define R_INTC_IM33_TSCR_TSTAT22_Pos (22UL)
#define R_INTC_IM33_TSCR_TSTAT23_Msk (0x00800000UL)
#define R_INTC_IM33_TSCR_TSTAT23_Pos (23UL)
#define R_INTC_IM33_TSCR_TSTAT24_Msk (0x01000000UL)
#define R_INTC_IM33_TSCR_TSTAT24_Pos (24UL)
#define R_INTC_IM33_TSCR_TSTAT25_Msk (0x02000000UL)
#define R_INTC_IM33_TSCR_TSTAT25_Pos (25UL)
#define R_INTC_IM33_TSCR_TSTAT26_Msk (0x04000000UL)
#define R_INTC_IM33_TSCR_TSTAT26_Pos (26UL)
#define R_INTC_IM33_TSCR_TSTAT27_Msk (0x08000000UL)
#define R_INTC_IM33_TSCR_TSTAT27_Pos (27UL)
#define R_INTC_IM33_TSCR_TSTAT28_Msk (0x10000000UL)
#define R_INTC_IM33_TSCR_TSTAT28_Pos (28UL)
#define R_INTC_IM33_TSCR_TSTAT29_Msk (0x20000000UL)
#define R_INTC_IM33_TSCR_TSTAT29_Pos (29UL)
#define R_INTC_IM33_TSCR_TSTAT30_Msk (0x40000000UL)
#define R_INTC_IM33_TSCR_TSTAT30_Pos (30UL)
#define R_INTC_IM33_TSCR_TSTAT31_Msk (0x80000000UL)
#define R_INTC_IM33_TSCR_TSTAT31_Pos (31UL)
#define R_INTC_IM33_TITSR0_TITSEL0_Msk (0x00000003UL)
#define R_INTC_IM33_TITSR0_TITSEL0_Pos (0UL)
#define R_INTC_IM33_TITSR0_TITSEL1_Msk (0x0000000CUL)
#define R_INTC_IM33_TITSR0_TITSEL1_Pos (2UL)
#define R_INTC_IM33_TITSR0_TITSEL2_Msk (0x00000030UL)
#define R_INTC_IM33_TITSR0_TITSEL2_Pos (4UL)
#define R_INTC_IM33_TITSR0_TITSEL3_Msk (0x000000C0UL)
#define R_INTC_IM33_TITSR0_TITSEL3_Pos (6UL)
#define R_INTC_IM33_TITSR0_TITSEL4_Msk (0x00000300UL)
#define R_INTC_IM33_TITSR0_TITSEL4_Pos (8UL)
#define R_INTC_IM33_TITSR0_TITSEL5_Msk (0x00000C00UL)
#define R_INTC_IM33_TITSR0_TITSEL5_Pos (10UL)
#define R_INTC_IM33_TITSR0_TITSEL6_Msk (0x00003000UL)
#define R_INTC_IM33_TITSR0_TITSEL6_Pos (12UL)
#define R_INTC_IM33_TITSR0_TITSEL7_Msk (0x0000C000UL)
#define R_INTC_IM33_TITSR0_TITSEL7_Pos (14UL)
#define R_INTC_IM33_TITSR0_TITSEL8_Msk (0x00030000UL)
#define R_INTC_IM33_TITSR0_TITSEL8_Pos (16UL)
#define R_INTC_IM33_TITSR0_TITSEL9_Msk (0x000C0000UL)
#define R_INTC_IM33_TITSR0_TITSEL9_Pos (18UL)
#define R_INTC_IM33_TITSR0_TITSEL10_Msk (0x00300000UL)
#define R_INTC_IM33_TITSR0_TITSEL10_Pos (20UL)
#define R_INTC_IM33_TITSR0_TITSEL11_Msk (0x00C00000UL)
#define R_INTC_IM33_TITSR0_TITSEL11_Pos (22UL)
#define R_INTC_IM33_TITSR0_TITSEL12_Msk (0x03000000UL)
#define R_INTC_IM33_TITSR0_TITSEL12_Pos (24UL)
#define R_INTC_IM33_TITSR0_TITSEL13_Msk (0x0C000000UL)
#define R_INTC_IM33_TITSR0_TITSEL13_Pos (26UL)
#define R_INTC_IM33_TITSR0_TITSEL14_Msk (0x30000000UL)
#define R_INTC_IM33_TITSR0_TITSEL14_Pos (28UL)
#define R_INTC_IM33_TITSR0_TITSEL15_Msk (0xC0000000UL)
#define R_INTC_IM33_TITSR0_TITSEL15_Pos (30UL)
#define R_INTC_IM33_TITSR1_TITSEL16_Msk (0x00000003UL)
#define R_INTC_IM33_TITSR1_TITSEL16_Pos (0UL)
#define R_INTC_IM33_TITSR1_TITSEL17_Msk (0x0000000CUL)
#define R_INTC_IM33_TITSR1_TITSEL17_Pos (2UL)
#define R_INTC_IM33_TITSR1_TITSEL18_Msk (0x00000030UL)
#define R_INTC_IM33_TITSR1_TITSEL18_Pos (4UL)
#define R_INTC_IM33_TITSR1_TITSEL19_Msk (0x000000C0UL)
#define R_INTC_IM33_TITSR1_TITSEL19_Pos (6UL)
#define R_INTC_IM33_TITSR1_TITSEL20_Msk (0x00000300UL)
#define R_INTC_IM33_TITSR1_TITSEL20_Pos (8UL)
#define R_INTC_IM33_TITSR1_TITSEL21_Msk (0x00000C00UL)
#define R_INTC_IM33_TITSR1_TITSEL21_Pos (10UL)
#define R_INTC_IM33_TITSR1_TITSEL22_Msk (0x00003000UL)
#define R_INTC_IM33_TITSR1_TITSEL22_Pos (12UL)
#define R_INTC_IM33_TITSR1_TITSEL23_Msk (0x0000C000UL)
#define R_INTC_IM33_TITSR1_TITSEL23_Pos (14UL)
#define R_INTC_IM33_TITSR1_TITSEL24_Msk (0x00030000UL)
#define R_INTC_IM33_TITSR1_TITSEL24_Pos (16UL)
#define R_INTC_IM33_TITSR1_TITSEL25_Msk (0x000C0000UL)
#define R_INTC_IM33_TITSR1_TITSEL25_Pos (18UL)
#define R_INTC_IM33_TITSR1_TITSEL26_Msk (0x00300000UL)
#define R_INTC_IM33_TITSR1_TITSEL26_Pos (20UL)
#define R_INTC_IM33_TITSR1_TITSEL27_Msk (0x00C00000UL)
#define R_INTC_IM33_TITSR1_TITSEL27_Pos (22UL)
#define R_INTC_IM33_TITSR1_TITSEL28_Msk (0x03000000UL)
#define R_INTC_IM33_TITSR1_TITSEL28_Pos (24UL)
#define R_INTC_IM33_TITSR1_TITSEL29_Msk (0x0C000000UL)
#define R_INTC_IM33_TITSR1_TITSEL29_Pos (26UL)
#define R_INTC_IM33_TITSR1_TITSEL30_Msk (0x30000000UL)
#define R_INTC_IM33_TITSR1_TITSEL30_Pos (28UL)
#define R_INTC_IM33_TITSR1_TITSEL31_Msk (0xC0000000UL)
#define R_INTC_IM33_TITSR1_TITSEL31_Pos (30UL)
#define R_INTC_IM33_TSSR0_TSSEL0_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR0_TSSEL0_Pos (0UL)
#define R_INTC_IM33_TSSR0_TIEN0_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR0_TIEN0_Pos (7UL)
#define R_INTC_IM33_TSSR0_TSSEL1_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR0_TSSEL1_Pos (8UL)
#define R_INTC_IM33_TSSR0_TIEN1_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR0_TIEN1_Pos (15UL)
#define R_INTC_IM33_TSSR0_TSSEL2_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR0_TSSEL2_Pos (16UL)
#define R_INTC_IM33_TSSR0_TIEN2_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR0_TIEN2_Pos (23UL)
#define R_INTC_IM33_TSSR0_TSSEL3_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR0_TSSEL3_Pos (24UL)
#define R_INTC_IM33_TSSR0_TIEN3_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR0_TIEN3_Pos (31UL)
#define R_INTC_IM33_TSSR1_TSSEL4_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR1_TSSEL4_Pos (0UL)
#define R_INTC_IM33_TSSR1_TIEN4_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR1_TIEN4_Pos (7UL)
#define R_INTC_IM33_TSSR1_TSSEL5_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR1_TSSEL5_Pos (8UL)
#define R_INTC_IM33_TSSR1_TIEN5_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR1_TIEN5_Pos (15UL)
#define R_INTC_IM33_TSSR1_TSSEL6_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR1_TSSEL6_Pos (16UL)
#define R_INTC_IM33_TSSR1_TIEN6_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR1_TIEN6_Pos (23UL)
#define R_INTC_IM33_TSSR1_TSSEL7_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR1_TSSEL7_Pos (24UL)
#define R_INTC_IM33_TSSR1_TIEN7_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR1_TIEN7_Pos (31UL)
#define R_INTC_IM33_TSSR2_TSSEL8_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR2_TSSEL8_Pos (0UL)
#define R_INTC_IM33_TSSR2_TIEN8_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR2_TIEN8_Pos (7UL)
#define R_INTC_IM33_TSSR2_TSSEL9_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR2_TSSEL9_Pos (8UL)
#define R_INTC_IM33_TSSR2_TIEN9_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR2_TIEN9_Pos (15UL)
#define R_INTC_IM33_TSSR2_TSSEL10_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR2_TSSEL10_Pos (16UL)
#define R_INTC_IM33_TSSR2_TIEN10_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR2_TIEN10_Pos (23UL)
#define R_INTC_IM33_TSSR2_TSSEL11_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR2_TSSEL11_Pos (24UL)
#define R_INTC_IM33_TSSR2_TIEN11_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR2_TIEN11_Pos (31UL)
#define R_INTC_IM33_TSSR3_TSSEL12_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR3_TSSEL12_Pos (0UL)
#define R_INTC_IM33_TSSR3_TIEN12_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR3_TIEN12_Pos (7UL)
#define R_INTC_IM33_TSSR3_TSSEL13_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR3_TSSEL13_Pos (8UL)
#define R_INTC_IM33_TSSR3_TIEN13_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR3_TIEN13_Pos (15UL)
#define R_INTC_IM33_TSSR3_TSSEL14_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR3_TSSEL14_Pos (16UL)
#define R_INTC_IM33_TSSR3_TIEN14_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR3_TIEN14_Pos (23UL)
#define R_INTC_IM33_TSSR3_TSSEL15_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR3_TSSEL15_Pos (24UL)
#define R_INTC_IM33_TSSR3_TIEN15_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR3_TIEN15_Pos (31UL)
#define R_INTC_IM33_TSSR4_TSSEL16_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR4_TSSEL16_Pos (0UL)
#define R_INTC_IM33_TSSR4_TIEN16_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR4_TIEN16_Pos (7UL)
#define R_INTC_IM33_TSSR4_TSSEL17_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR4_TSSEL17_Pos (8UL)
#define R_INTC_IM33_TSSR4_TIEN17_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR4_TIEN17_Pos (15UL)
#define R_INTC_IM33_TSSR4_TSSEL18_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR4_TSSEL18_Pos (16UL)
#define R_INTC_IM33_TSSR4_TIEN18_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR4_TIEN18_Pos (23UL)
#define R_INTC_IM33_TSSR4_TSSEL19_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR4_TSSEL19_Pos (24UL)
#define R_INTC_IM33_TSSR4_TIEN19_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR4_TIEN19_Pos (31UL)
#define R_INTC_IM33_TSSR5_TSSEL20_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR5_TSSEL20_Pos (0UL)
#define R_INTC_IM33_TSSR5_TIEN20_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR5_TIEN20_Pos (7UL)
#define R_INTC_IM33_TSSR5_TSSEL21_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR5_TSSEL21_Pos (8UL)
#define R_INTC_IM33_TSSR5_TIEN21_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR5_TIEN21_Pos (15UL)
#define R_INTC_IM33_TSSR5_TSSEL22_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR5_TSSEL22_Pos (16UL)
#define R_INTC_IM33_TSSR5_TIEN22_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR5_TIEN22_Pos (23UL)
#define R_INTC_IM33_TSSR5_TSSEL23_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR5_TSSEL23_Pos (24UL)
#define R_INTC_IM33_TSSR5_TIEN23_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR5_TIEN23_Pos (31UL)
#define R_INTC_IM33_TSSR6_TSSEL24_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR6_TSSEL24_Pos (0UL)
#define R_INTC_IM33_TSSR6_TIEN24_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR6_TIEN24_Pos (7UL)
#define R_INTC_IM33_TSSR6_TSSEL25_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR6_TSSEL25_Pos (8UL)
#define R_INTC_IM33_TSSR6_TIEN25_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR6_TIEN25_Pos (15UL)
#define R_INTC_IM33_TSSR6_TSSEL26_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR6_TSSEL26_Pos (16UL)
#define R_INTC_IM33_TSSR6_TIEN26_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR6_TIEN26_Pos (23UL)
#define R_INTC_IM33_TSSR6_TSSEL27_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR6_TSSEL27_Pos (24UL)
#define R_INTC_IM33_TSSR6_TIEN27_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR6_TIEN27_Pos (31UL)
#define R_INTC_IM33_TSSR7_TSSEL28_Msk (0x0000007FUL)
#define R_INTC_IM33_TSSR7_TSSEL28_Pos (0UL)
#define R_INTC_IM33_TSSR7_TIEN28_Msk (0x00000080UL)
#define R_INTC_IM33_TSSR7_TIEN28_Pos (7UL)
#define R_INTC_IM33_TSSR7_TSSEL29_Msk (0x00007F00UL)
#define R_INTC_IM33_TSSR7_TSSEL29_Pos (8UL)
#define R_INTC_IM33_TSSR7_TIEN29_Msk (0x00008000UL)
#define R_INTC_IM33_TSSR7_TIEN29_Pos (15UL)
#define R_INTC_IM33_TSSR7_TSSEL30_Msk (0x007F0000UL)
#define R_INTC_IM33_TSSR7_TSSEL30_Pos (16UL)
#define R_INTC_IM33_TSSR7_TIEN30_Msk (0x00800000UL)
#define R_INTC_IM33_TSSR7_TIEN30_Pos (23UL)
#define R_INTC_IM33_TSSR7_TSSEL31_Msk (0x7F000000UL)
#define R_INTC_IM33_TSSR7_TSSEL31_Pos (24UL)
#define R_INTC_IM33_TSSR7_TIEN31_Msk (0x80000000UL)
#define R_INTC_IM33_TSSR7_TIEN31_Pos (31UL)
#define R_INTC_IM33_BEISR0_BESTAT0_Msk (0x00000001UL)
#define R_INTC_IM33_BEISR0_BESTAT0_Pos (0UL)
#define R_INTC_IM33_BEISR0_BESTAT1_Msk (0x00000002UL)
#define R_INTC_IM33_BEISR0_BESTAT1_Pos (1UL)
#define R_INTC_IM33_BEISR0_BESTAT2_Msk (0x00000004UL)
#define R_INTC_IM33_BEISR0_BESTAT2_Pos (2UL)
#define R_INTC_IM33_BEISR0_BESTAT3_Msk (0x00000008UL)
#define R_INTC_IM33_BEISR0_BESTAT3_Pos (3UL)
#define R_INTC_IM33_BEISR0_BESTAT4_Msk (0x00000010UL)
#define R_INTC_IM33_BEISR0_BESTAT4_Pos (4UL)
#define R_INTC_IM33_BEISR0_BESTAT5_Msk (0x00000020UL)
#define R_INTC_IM33_BEISR0_BESTAT5_Pos (5UL)
#define R_INTC_IM33_BEISR0_BESTAT6_Msk (0x00000040UL)
#define R_INTC_IM33_BEISR0_BESTAT6_Pos (6UL)
#define R_INTC_IM33_BEISR0_BESTAT7_Msk (0x00000080UL)
#define R_INTC_IM33_BEISR0_BESTAT7_Pos (7UL)
#define R_INTC_IM33_BEISR0_BESTAT8_Msk (0x00000100UL)
#define R_INTC_IM33_BEISR0_BESTAT8_Pos (8UL)
#define R_INTC_IM33_BEISR0_BESTAT9_Msk (0x00000200UL)
#define R_INTC_IM33_BEISR0_BESTAT9_Pos (9UL)
#define R_INTC_IM33_BEISR0_BESTAT10_Msk (0x00000400UL)
#define R_INTC_IM33_BEISR0_BESTAT10_Pos (10UL)
#define R_INTC_IM33_BEISR0_BESTAT11_Msk (0x00000800UL)
#define R_INTC_IM33_BEISR0_BESTAT11_Pos (11UL)
#define R_INTC_IM33_BEISR0_BESTAT12_Msk (0x00001000UL)
#define R_INTC_IM33_BEISR0_BESTAT12_Pos (12UL)
#define R_INTC_IM33_BEISR0_BESTAT13_Msk (0x00002000UL)
#define R_INTC_IM33_BEISR0_BESTAT13_Pos (13UL)
#define R_INTC_IM33_BEISR0_BESTAT14_Msk (0x00004000UL)
#define R_INTC_IM33_BEISR0_BESTAT14_Pos (14UL)
#define R_INTC_IM33_BEISR0_BESTAT15_Msk (0x00008000UL)
#define R_INTC_IM33_BEISR0_BESTAT15_Pos (15UL)
#define R_INTC_IM33_BEISR0_BESTAT16_Msk (0x00010000UL)
#define R_INTC_IM33_BEISR0_BESTAT16_Pos (16UL)
#define R_INTC_IM33_BEISR0_BESTAT17_Msk (0x00020000UL)
#define R_INTC_IM33_BEISR0_BESTAT17_Pos (17UL)
#define R_INTC_IM33_BEISR0_BESTAT18_Msk (0x00040000UL)
#define R_INTC_IM33_BEISR0_BESTAT18_Pos (18UL)
#define R_INTC_IM33_BEISR0_BESTAT19_Msk (0x00080000UL)
#define R_INTC_IM33_BEISR0_BESTAT19_Pos (19UL)
#define R_INTC_IM33_BEISR0_BESTAT20_Msk (0x00100000UL)
#define R_INTC_IM33_BEISR0_BESTAT20_Pos (20UL)
#define R_INTC_IM33_BEISR0_BESTAT21_Msk (0x00200000UL)
#define R_INTC_IM33_BEISR0_BESTAT21_Pos (21UL)
#define R_INTC_IM33_BEISR0_BESTAT22_Msk (0x00400000UL)
#define R_INTC_IM33_BEISR0_BESTAT22_Pos (22UL)
#define R_INTC_IM33_BEISR0_BESTAT23_Msk (0x00800000UL)
#define R_INTC_IM33_BEISR0_BESTAT23_Pos (23UL)
#define R_INTC_IM33_BEISR0_BESTAT24_Msk (0x01000000UL)
#define R_INTC_IM33_BEISR0_BESTAT24_Pos (24UL)
#define R_INTC_IM33_BEISR0_BESTAT25_Msk (0x02000000UL)
#define R_INTC_IM33_BEISR0_BESTAT25_Pos (25UL)
#define R_INTC_IM33_BEISR0_BESTAT26_Msk (0x04000000UL)
#define R_INTC_IM33_BEISR0_BESTAT26_Pos (26UL)
#define R_INTC_IM33_BEISR0_BESTAT27_Msk (0x08000000UL)
#define R_INTC_IM33_BEISR0_BESTAT27_Pos (27UL)
#define R_INTC_IM33_BEISR0_BESTAT28_Msk (0x10000000UL)
#define R_INTC_IM33_BEISR0_BESTAT28_Pos (28UL)
#define R_INTC_IM33_BEISR0_BESTAT29_Msk (0x20000000UL)
#define R_INTC_IM33_BEISR0_BESTAT29_Pos (29UL)
#define R_INTC_IM33_BEISR0_BESTAT30_Msk (0x40000000UL)
#define R_INTC_IM33_BEISR0_BESTAT30_Pos (30UL)
#define R_INTC_IM33_BEISR0_BESTAT31_Msk (0x80000000UL)
#define R_INTC_IM33_BEISR0_BESTAT31_Pos (31UL)
#define R_INTC_IM33_BEISR1_BESTAT32_Msk (0x00000001UL)
#define R_INTC_IM33_BEISR1_BESTAT32_Pos (0UL)
#define R_INTC_IM33_BEISR1_BESTAT33_Msk (0x00000002UL)
#define R_INTC_IM33_BEISR1_BESTAT33_Pos (1UL)
#define R_INTC_IM33_BEISR1_BESTAT34_Msk (0x00000004UL)
#define R_INTC_IM33_BEISR1_BESTAT34_Pos (2UL)
#define R_INTC_IM33_BEISR1_BESTAT35_Msk (0x00000008UL)
#define R_INTC_IM33_BEISR1_BESTAT35_Pos (3UL)
#define R_INTC_IM33_BEISR1_BESTAT36_Msk (0x00000010UL)
#define R_INTC_IM33_BEISR1_BESTAT36_Pos (4UL)
#define R_INTC_IM33_BEISR1_BESTAT37_Msk (0x00000020UL)
#define R_INTC_IM33_BEISR1_BESTAT37_Pos (5UL)
#define R_INTC_IM33_BEISR1_BESTAT38_Msk (0x00000040UL)
#define R_INTC_IM33_BEISR1_BESTAT38_Pos (6UL)
#define R_INTC_IM33_BEISR1_BESTAT39_Msk (0x00000080UL)
#define R_INTC_IM33_BEISR1_BESTAT39_Pos (7UL)
#define R_INTC_IM33_BEISR1_BESTAT40_Msk (0x00000100UL)
#define R_INTC_IM33_BEISR1_BESTAT40_Pos (8UL)
#define R_INTC_IM33_BEISR1_BESTAT41_Msk (0x00000200UL)
#define R_INTC_IM33_BEISR1_BESTAT41_Pos (9UL)
#define R_INTC_IM33_BEISR1_BESTAT42_Msk (0x00000400UL)
#define R_INTC_IM33_BEISR1_BESTAT42_Pos (10UL)
#define R_INTC_IM33_BEISR1_BESTAT43_Msk (0x00000800UL)
#define R_INTC_IM33_BEISR1_BESTAT43_Pos (11UL)
#define R_INTC_IM33_BEISR1_BESTAT44_Msk (0x00001000UL)
#define R_INTC_IM33_BEISR1_BESTAT44_Pos (12UL)
#define R_INTC_IM33_EREISR0_E1STAT0_Msk (0x00000001UL)
#define R_INTC_IM33_EREISR0_E1STAT0_Pos (0UL)
#define R_INTC_IM33_EREISR0_E1STAT1_Msk (0x00000002UL)
#define R_INTC_IM33_EREISR0_E1STAT1_Pos (1UL)
#define R_INTC_IM33_EREISR0_E1STAT2_Msk (0x00000004UL)
#define R_INTC_IM33_EREISR0_E1STAT2_Pos (2UL)
#define R_INTC_IM33_EREISR0_E1STAT3_Msk (0x00000008UL)
#define R_INTC_IM33_EREISR0_E1STAT3_Pos (3UL)
#define R_INTC_IM33_EREISR0_E1STAT4_Msk (0x00000010UL)
#define R_INTC_IM33_EREISR0_E1STAT4_Pos (4UL)
#define R_INTC_IM33_EREISR0_E1STAT5_Msk (0x00000020UL)
#define R_INTC_IM33_EREISR0_E1STAT5_Pos (5UL)
#define R_INTC_IM33_EREISR0_E1STAT6_Msk (0x00000040UL)
#define R_INTC_IM33_EREISR0_E1STAT6_Pos (6UL)
#define R_INTC_IM33_EREISR0_E1STAT7_Msk (0x00000080UL)
#define R_INTC_IM33_EREISR0_E1STAT7_Pos (7UL)
#define R_INTC_IM33_EREISR0_E2STAT0_Msk (0x00000100UL)
#define R_INTC_IM33_EREISR0_E2STAT0_Pos (8UL)
#define R_INTC_IM33_EREISR0_E2STAT1_Msk (0x00000200UL)
#define R_INTC_IM33_EREISR0_E2STAT1_Pos (9UL)
#define R_INTC_IM33_EREISR0_E2STAT2_Msk (0x00000400UL)
#define R_INTC_IM33_EREISR0_E2STAT2_Pos (10UL)
#define R_INTC_IM33_EREISR0_E2STAT3_Msk (0x00000800UL)
#define R_INTC_IM33_EREISR0_E2STAT3_Pos (11UL)
#define R_INTC_IM33_EREISR0_E2STAT4_Msk (0x00001000UL)
#define R_INTC_IM33_EREISR0_E2STAT4_Pos (12UL)
#define R_INTC_IM33_EREISR0_E2STAT5_Msk (0x00002000UL)
#define R_INTC_IM33_EREISR0_E2STAT5_Pos (13UL)
#define R_INTC_IM33_EREISR0_E2STAT6_Msk (0x00004000UL)
#define R_INTC_IM33_EREISR0_E2STAT6_Pos (14UL)
#define R_INTC_IM33_EREISR0_E2STAT7_Msk (0x00008000UL)
#define R_INTC_IM33_EREISR0_E2STAT7_Pos (15UL)
#define R_INTC_IM33_EREISR0_OFSTAT0_Msk (0x00010000UL)
#define R_INTC_IM33_EREISR0_OFSTAT0_Pos (16UL)
#define R_INTC_IM33_EREISR0_OFSTAT1_Msk (0x00020000UL)
#define R_INTC_IM33_EREISR0_OFSTAT1_Pos (17UL)
#define R_INTC_IM33_EREISR0_OFSTAT2_Msk (0x00040000UL)
#define R_INTC_IM33_EREISR0_OFSTAT2_Pos (18UL)
#define R_INTC_IM33_EREISR0_OFSTAT3_Msk (0x00080000UL)
#define R_INTC_IM33_EREISR0_OFSTAT3_Pos (19UL)
#define R_INTC_IM33_EREISR0_OFSTAT4_Msk (0x00100000UL)
#define R_INTC_IM33_EREISR0_OFSTAT4_Pos (20UL)
#define R_INTC_IM33_EREISR0_OFSTAT5_Msk (0x00200000UL)
#define R_INTC_IM33_EREISR0_OFSTAT5_Pos (21UL)
#define R_INTC_IM33_EREISR0_OFSTAT6_Msk (0x00400000UL)
#define R_INTC_IM33_EREISR0_OFSTAT6_Pos (22UL)
#define R_INTC_IM33_EREISR0_OFSTAT7_Msk (0x00800000UL)
#define R_INTC_IM33_EREISR0_OFSTAT7_Pos (23UL)
#define R_INTC_IM33_EREISR1_E1STAT0_Msk (0x00000001UL)
#define R_INTC_IM33_EREISR1_E1STAT0_Pos (0UL)
#define R_INTC_IM33_EREISR1_E1STAT1_Msk (0x00000002UL)
#define R_INTC_IM33_EREISR1_E1STAT1_Pos (1UL)
#define R_INTC_IM33_EREISR1_E1STAT2_Msk (0x00000004UL)
#define R_INTC_IM33_EREISR1_E1STAT2_Pos (2UL)
#define R_INTC_IM33_EREISR1_E1STAT3_Msk (0x00000008UL)
#define R_INTC_IM33_EREISR1_E1STAT3_Pos (3UL)
#define R_INTC_IM33_EREISR1_E1STAT4_Msk (0x00000010UL)
#define R_INTC_IM33_EREISR1_E1STAT4_Pos (4UL)
#define R_INTC_IM33_EREISR1_E1STAT5_Msk (0x00000020UL)
#define R_INTC_IM33_EREISR1_E1STAT5_Pos (5UL)
#define R_INTC_IM33_EREISR1_E1STAT6_Msk (0x00000040UL)
#define R_INTC_IM33_EREISR1_E1STAT6_Pos (6UL)
#define R_INTC_IM33_EREISR1_E1STAT7_Msk (0x00000080UL)
#define R_INTC_IM33_EREISR1_E1STAT7_Pos (7UL)
#define R_INTC_IM33_EREISR1_E2STAT0_Msk (0x00000100UL)
#define R_INTC_IM33_EREISR1_E2STAT0_Pos (8UL)
#define R_INTC_IM33_EREISR1_E2STAT1_Msk (0x00000200UL)
#define R_INTC_IM33_EREISR1_E2STAT1_Pos (9UL)
#define R_INTC_IM33_EREISR1_E2STAT2_Msk (0x00000400UL)
#define R_INTC_IM33_EREISR1_E2STAT2_Pos (10UL)
#define R_INTC_IM33_EREISR1_E2STAT3_Msk (0x00000800UL)
#define R_INTC_IM33_EREISR1_E2STAT3_Pos (11UL)
#define R_INTC_IM33_EREISR1_E2STAT4_Msk (0x00001000UL)
#define R_INTC_IM33_EREISR1_E2STAT4_Pos (12UL)
#define R_INTC_IM33_EREISR1_E2STAT5_Msk (0x00002000UL)
#define R_INTC_IM33_EREISR1_E2STAT5_Pos (13UL)
#define R_INTC_IM33_EREISR1_E2STAT6_Msk (0x00004000UL)
#define R_INTC_IM33_EREISR1_E2STAT6_Pos (14UL)
#define R_INTC_IM33_EREISR1_E2STAT7_Msk (0x00008000UL)
#define R_INTC_IM33_EREISR1_E2STAT7_Pos (15UL)
#define R_INTC_IM33_EREISR1_OFSTAT0_Msk (0x00010000UL)
#define R_INTC_IM33_EREISR1_OFSTAT0_Pos (16UL)
#define R_INTC_IM33_EREISR1_OFSTAT1_Msk (0x00020000UL)
#define R_INTC_IM33_EREISR1_OFSTAT1_Pos (17UL)
#define R_INTC_IM33_EREISR1_OFSTAT2_Msk (0x00040000UL)
#define R_INTC_IM33_EREISR1_OFSTAT2_Pos (18UL)
#define R_INTC_IM33_EREISR1_OFSTAT3_Msk (0x00080000UL)
#define R_INTC_IM33_EREISR1_OFSTAT3_Pos (19UL)
#define R_INTC_IM33_EREISR1_OFSTAT4_Msk (0x00100000UL)
#define R_INTC_IM33_EREISR1_OFSTAT4_Pos (20UL)
#define R_INTC_IM33_EREISR1_OFSTAT5_Msk (0x00200000UL)
#define R_INTC_IM33_EREISR1_OFSTAT5_Pos (21UL)
#define R_INTC_IM33_EREISR1_OFSTAT6_Msk (0x00400000UL)
#define R_INTC_IM33_EREISR1_OFSTAT6_Pos (22UL)
#define R_INTC_IM33_EREISR1_OFSTAT7_Msk (0x00800000UL)
#define R_INTC_IM33_EREISR1_OFSTAT7_Pos (23UL)
#endif /* INTC_IM33_IOBITMASK_H */

View File

@ -0,0 +1,49 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : mhu_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for mhu.
*********************************************************************************************************************/
#ifndef MHU_IOBITMASK_H
#define MHU_IOBITMASK_H
#define R_MHU0_MSG_INT_STSn_STAT_Msk (0x00000001UL)
#define R_MHU0_MSG_INT_STSn_STAT_Pos (0UL)
#define R_MHU0_MSG_INT_SETn_SET_Msk (0x00000001UL)
#define R_MHU0_MSG_INT_SETn_SET_Pos (0UL)
#define R_MHU0_MSG_INT_CLRn_CLEAR_Msk (0x00000001UL)
#define R_MHU0_MSG_INT_CLRn_CLEAR_Pos (0UL)
#define R_MHU0_RSP_INT_STSn_STAT_Msk (0x00000001UL)
#define R_MHU0_RSP_INT_STSn_STAT_Pos (0UL)
#define R_MHU0_RSP_INT_SETn_SET_Msk (0x00000001UL)
#define R_MHU0_RSP_INT_SETn_SET_Pos (0UL)
#define R_MHU0_RSP_INT_CLRn_CLEAR_Msk (0x00000001UL)
#define R_MHU0_RSP_INT_CLRn_CLEAR_Pos (0UL)
#define R_MHU0_SW_INT_STSn_STAT_Msk (0x00000001UL)
#define R_MHU0_SW_INT_STSn_STAT_Pos (0UL)
#define R_MHU0_SW_INT_SETn_SET_Msk (0x00000001UL)
#define R_MHU0_SW_INT_SETn_SET_Pos (0UL)
#define R_MHU0_SW_INT_CLRn_CLEAR_Msk (0x00000001UL)
#define R_MHU0_SW_INT_CLRn_CLEAR_Pos (0UL)
#endif /* MHU_IOBITMASK_H */

View File

@ -0,0 +1,567 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : mtu_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for mtu.
*********************************************************************************************************************/
#ifndef MTU_IOBITMASK_H
#define MTU_IOBITMASK_H
#define R_MTU_TOERA_OE3B_Msk (0x01UL)
#define R_MTU_TOERA_OE3B_Pos (0UL)
#define R_MTU_TOERA_OE4A_Msk (0x02UL)
#define R_MTU_TOERA_OE4A_Pos (1UL)
#define R_MTU_TOERA_OE4B_Msk (0x04UL)
#define R_MTU_TOERA_OE4B_Pos (2UL)
#define R_MTU_TOERA_OE3D_Msk (0x08UL)
#define R_MTU_TOERA_OE3D_Pos (3UL)
#define R_MTU_TOERA_OE4C_Msk (0x10UL)
#define R_MTU_TOERA_OE4C_Pos (4UL)
#define R_MTU_TOERA_OE4D_Msk (0x20UL)
#define R_MTU_TOERA_OE4D_Pos (5UL)
#define R_MTU_TGCRA_UF_Msk (0x01UL)
#define R_MTU_TGCRA_UF_Pos (0UL)
#define R_MTU_TGCRA_VF_Msk (0x02UL)
#define R_MTU_TGCRA_VF_Pos (1UL)
#define R_MTU_TGCRA_WF_Msk (0x04UL)
#define R_MTU_TGCRA_WF_Pos (2UL)
#define R_MTU_TGCRA_FB_Msk (0x08UL)
#define R_MTU_TGCRA_FB_Pos (3UL)
#define R_MTU_TGCRA_P_Msk (0x10UL)
#define R_MTU_TGCRA_P_Pos (4UL)
#define R_MTU_TGCRA_N_Msk (0x20UL)
#define R_MTU_TGCRA_N_Pos (5UL)
#define R_MTU_TGCRA_BDC_Msk (0x40UL)
#define R_MTU_TGCRA_BDC_Pos (6UL)
#define R_MTU_TOCR1A_OLSP_Msk (0x01UL)
#define R_MTU_TOCR1A_OLSP_Pos (0UL)
#define R_MTU_TOCR1A_OLSN_Msk (0x02UL)
#define R_MTU_TOCR1A_OLSN_Pos (1UL)
#define R_MTU_TOCR1A_TOCS_Msk (0x04UL)
#define R_MTU_TOCR1A_TOCS_Pos (2UL)
#define R_MTU_TOCR1A_TOCL_Msk (0x08UL)
#define R_MTU_TOCR1A_TOCL_Pos (3UL)
#define R_MTU_TOCR1A_PSYE_Msk (0x40UL)
#define R_MTU_TOCR1A_PSYE_Pos (6UL)
#define R_MTU_TOCR2A_OLS1P_Msk (0x01UL)
#define R_MTU_TOCR2A_OLS1P_Pos (0UL)
#define R_MTU_TOCR2A_OLS1N_Msk (0x02UL)
#define R_MTU_TOCR2A_OLS1N_Pos (1UL)
#define R_MTU_TOCR2A_OLS2P_Msk (0x04UL)
#define R_MTU_TOCR2A_OLS2P_Pos (2UL)
#define R_MTU_TOCR2A_OLS2N_Msk (0x08UL)
#define R_MTU_TOCR2A_OLS2N_Pos (3UL)
#define R_MTU_TOCR2A_OLS3P_Msk (0x10UL)
#define R_MTU_TOCR2A_OLS3P_Pos (4UL)
#define R_MTU_TOCR2A_OLS3N_Msk (0x20UL)
#define R_MTU_TOCR2A_OLS3N_Pos (5UL)
#define R_MTU_TOCR2A_BF_Msk (0xC0UL)
#define R_MTU_TOCR2A_BF_Pos (6UL)
#define R_MTU_TCDRA_TCDRA_Msk (0xFFFFUL)
#define R_MTU_TCDRA_TCDRA_Pos (0UL)
#define R_MTU_TDDRA_TDDRA_Msk (0xFFFFUL)
#define R_MTU_TDDRA_TDDRA_Pos (0UL)
#define R_MTU_TCNTSA_TCNTSA_Msk (0xFFFFUL)
#define R_MTU_TCNTSA_TCNTSA_Pos (0UL)
#define R_MTU_TCBRA_TCBRA_Msk (0xFFFFUL)
#define R_MTU_TCBRA_TCBRA_Pos (0UL)
#define R_MTU_TITCR1A_T4VCOR_Msk (0x07UL)
#define R_MTU_TITCR1A_T4VCOR_Pos (0UL)
#define R_MTU_TITCR1A_T4VEN_Msk (0x08UL)
#define R_MTU_TITCR1A_T4VEN_Pos (3UL)
#define R_MTU_TITCR1A_T3ACOR_Msk (0x70UL)
#define R_MTU_TITCR1A_T3ACOR_Pos (4UL)
#define R_MTU_TITCR1A_T3AEN_Msk (0x80UL)
#define R_MTU_TITCR1A_T3AEN_Pos (7UL)
#define R_MTU_TITCNT1A_T4VCNT_Msk (0x07UL)
#define R_MTU_TITCNT1A_T4VCNT_Pos (0UL)
#define R_MTU_TITCNT1A_T3ACNT_Msk (0x70UL)
#define R_MTU_TITCNT1A_T3ACNT_Pos (4UL)
#define R_MTU_TBTERA_BTE_Msk (0x03UL)
#define R_MTU_TBTERA_BTE_Pos (0UL)
#define R_MTU_TDERA_TDER_Msk (0x01UL)
#define R_MTU_TDERA_TDER_Pos (0UL)
#define R_MTU_TOLBRA_OLS1P_Msk (0x01UL)
#define R_MTU_TOLBRA_OLS1P_Pos (0UL)
#define R_MTU_TOLBRA_OLS1N_Msk (0x02UL)
#define R_MTU_TOLBRA_OLS1N_Pos (1UL)
#define R_MTU_TOLBRA_OLS2P_Msk (0x04UL)
#define R_MTU_TOLBRA_OLS2P_Pos (2UL)
#define R_MTU_TOLBRA_OLS2N_Msk (0x08UL)
#define R_MTU_TOLBRA_OLS2N_Pos (3UL)
#define R_MTU_TOLBRA_OLS3P_Msk (0x10UL)
#define R_MTU_TOLBRA_OLS3P_Pos (4UL)
#define R_MTU_TOLBRA_OLS3N_Msk (0x20UL)
#define R_MTU_TOLBRA_OLS3N_Pos (5UL)
#define R_MTU_TITMRA_TITM_Msk (0x01UL)
#define R_MTU_TITMRA_TITM_Pos (0UL)
#define R_MTU_TITCR2A_TRG4COR_Msk (0x07UL)
#define R_MTU_TITCR2A_TRG4COR_Pos (0UL)
#define R_MTU_TITCNT2A_TRG4CNT_Msk (0x07UL)
#define R_MTU_TITCNT2A_TRG4CNT_Pos (0UL)
#define R_MTU_TWCRA_WRE_Msk (0x01UL)
#define R_MTU_TWCRA_WRE_Pos (0UL)
#define R_MTU_TWCRA_SCC_Msk (0x02UL)
#define R_MTU_TWCRA_SCC_Pos (1UL)
#define R_MTU_TWCRA_CCE_Msk (0x80UL)
#define R_MTU_TWCRA_CCE_Pos (7UL)
#define R_MTU_TMDR2A_DRS_Msk (0x01UL)
#define R_MTU_TMDR2A_DRS_Pos (0UL)
#define R_MTU_TSTRA_CST0_Msk (0x01UL)
#define R_MTU_TSTRA_CST0_Pos (0UL)
#define R_MTU_TSTRA_CST1_Msk (0x02UL)
#define R_MTU_TSTRA_CST1_Pos (1UL)
#define R_MTU_TSTRA_CST2_Msk (0x04UL)
#define R_MTU_TSTRA_CST2_Pos (2UL)
#define R_MTU_TSTRA_CST8_Msk (0x08UL)
#define R_MTU_TSTRA_CST8_Pos (3UL)
#define R_MTU_TSTRA_CST3_Msk (0x40UL)
#define R_MTU_TSTRA_CST3_Pos (6UL)
#define R_MTU_TSTRA_CST4_Msk (0x80UL)
#define R_MTU_TSTRA_CST4_Pos (7UL)
#define R_MTU_TSYRA_SYNC0_Msk (0x01UL)
#define R_MTU_TSYRA_SYNC0_Pos (0UL)
#define R_MTU_TSYRA_SYNC1_Msk (0x02UL)
#define R_MTU_TSYRA_SYNC1_Pos (1UL)
#define R_MTU_TSYRA_SYNC2_Msk (0x04UL)
#define R_MTU_TSYRA_SYNC2_Pos (2UL)
#define R_MTU_TSYRA_SYNC3_Msk (0x40UL)
#define R_MTU_TSYRA_SYNC3_Pos (6UL)
#define R_MTU_TSYRA_SYNC4_Msk (0x80UL)
#define R_MTU_TSYRA_SYNC4_Pos (7UL)
#define R_MTU_TCSYSTR_SCH7_Msk (0x01UL)
#define R_MTU_TCSYSTR_SCH7_Pos (0UL)
#define R_MTU_TCSYSTR_SCH6_Msk (0x02UL)
#define R_MTU_TCSYSTR_SCH6_Pos (1UL)
#define R_MTU_TCSYSTR_SCH4_Msk (0x08UL)
#define R_MTU_TCSYSTR_SCH4_Pos (3UL)
#define R_MTU_TCSYSTR_SCH3_Msk (0x10UL)
#define R_MTU_TCSYSTR_SCH3_Pos (4UL)
#define R_MTU_TCSYSTR_SCH2_Msk (0x20UL)
#define R_MTU_TCSYSTR_SCH2_Pos (5UL)
#define R_MTU_TCSYSTR_SCH1_Msk (0x40UL)
#define R_MTU_TCSYSTR_SCH1_Pos (6UL)
#define R_MTU_TCSYSTR_SCH0_Msk (0x80UL)
#define R_MTU_TCSYSTR_SCH0_Pos (7UL)
#define R_MTU_TRWERA_RWE_Msk (0x01UL)
#define R_MTU_TRWERA_RWE_Pos (0UL)
#define R_MTU_TOERB_OE6B_Msk (0x01UL)
#define R_MTU_TOERB_OE6B_Pos (0UL)
#define R_MTU_TOERB_OE7A_Msk (0x02UL)
#define R_MTU_TOERB_OE7A_Pos (1UL)
#define R_MTU_TOERB_OE7B_Msk (0x04UL)
#define R_MTU_TOERB_OE7B_Pos (2UL)
#define R_MTU_TOERB_OE6D_Msk (0x08UL)
#define R_MTU_TOERB_OE6D_Pos (3UL)
#define R_MTU_TOERB_OE7C_Msk (0x10UL)
#define R_MTU_TOERB_OE7C_Pos (4UL)
#define R_MTU_TOERB_OE7D_Msk (0x20UL)
#define R_MTU_TOERB_OE7D_Pos (5UL)
#define R_MTU_TOCR1B_OLSP_Msk (0x01UL)
#define R_MTU_TOCR1B_OLSP_Pos (0UL)
#define R_MTU_TOCR1B_OLSN_Msk (0x02UL)
#define R_MTU_TOCR1B_OLSN_Pos (1UL)
#define R_MTU_TOCR1B_TOCS_Msk (0x04UL)
#define R_MTU_TOCR1B_TOCS_Pos (2UL)
#define R_MTU_TOCR1B_TOCL_Msk (0x08UL)
#define R_MTU_TOCR1B_TOCL_Pos (3UL)
#define R_MTU_TOCR1B_PSYE_Msk (0x40UL)
#define R_MTU_TOCR1B_PSYE_Pos (6UL)
#define R_MTU_TOCR2B_OLS1P_Msk (0x01UL)
#define R_MTU_TOCR2B_OLS1P_Pos (0UL)
#define R_MTU_TOCR2B_OLS1N_Msk (0x02UL)
#define R_MTU_TOCR2B_OLS1N_Pos (1UL)
#define R_MTU_TOCR2B_OLS2P_Msk (0x04UL)
#define R_MTU_TOCR2B_OLS2P_Pos (2UL)
#define R_MTU_TOCR2B_OLS2N_Msk (0x08UL)
#define R_MTU_TOCR2B_OLS2N_Pos (3UL)
#define R_MTU_TOCR2B_OLS3P_Msk (0x10UL)
#define R_MTU_TOCR2B_OLS3P_Pos (4UL)
#define R_MTU_TOCR2B_OLS3N_Msk (0x20UL)
#define R_MTU_TOCR2B_OLS3N_Pos (5UL)
#define R_MTU_TOCR2B_BF_Msk (0xC0UL)
#define R_MTU_TOCR2B_BF_Pos (6UL)
#define R_MTU_TCDRB_TCDRB_Msk (0xFFFFUL)
#define R_MTU_TCDRB_TCDRB_Pos (0UL)
#define R_MTU_TDDRB_TDDRB_Msk (0xFFFFUL)
#define R_MTU_TDDRB_TDDRB_Pos (0UL)
#define R_MTU_TCNTSB_TCNTSB_Msk (0xFFFFUL)
#define R_MTU_TCNTSB_TCNTSB_Pos (0UL)
#define R_MTU_TCBRB_TCBRB_Msk (0xFFFFUL)
#define R_MTU_TCBRB_TCBRB_Pos (0UL)
#define R_MTU_TITCR1B_T7VCOR_Msk (0x07UL)
#define R_MTU_TITCR1B_T7VCOR_Pos (0UL)
#define R_MTU_TITCR1B_T7VEN_Msk (0x08UL)
#define R_MTU_TITCR1B_T7VEN_Pos (3UL)
#define R_MTU_TITCR1B_T6ACOR_Msk (0x70UL)
#define R_MTU_TITCR1B_T6ACOR_Pos (4UL)
#define R_MTU_TITCR1B_T6AEN_Msk (0x80UL)
#define R_MTU_TITCR1B_T6AEN_Pos (7UL)
#define R_MTU_TITCNT1B_T7VCNT_Msk (0x07UL)
#define R_MTU_TITCNT1B_T7VCNT_Pos (0UL)
#define R_MTU_TITCNT1B_T6ACNT_Msk (0x70UL)
#define R_MTU_TITCNT1B_T6ACNT_Pos (4UL)
#define R_MTU_TBTERB_BTE_Msk (0x03UL)
#define R_MTU_TBTERB_BTE_Pos (0UL)
#define R_MTU_TDERB_TDER_Msk (0x01UL)
#define R_MTU_TDERB_TDER_Pos (0UL)
#define R_MTU_TOLBRB_OLS1P_Msk (0x01UL)
#define R_MTU_TOLBRB_OLS1P_Pos (0UL)
#define R_MTU_TOLBRB_OLS1N_Msk (0x02UL)
#define R_MTU_TOLBRB_OLS1N_Pos (1UL)
#define R_MTU_TOLBRB_OLS2P_Msk (0x04UL)
#define R_MTU_TOLBRB_OLS2P_Pos (2UL)
#define R_MTU_TOLBRB_OLS2N_Msk (0x08UL)
#define R_MTU_TOLBRB_OLS2N_Pos (3UL)
#define R_MTU_TOLBRB_OLS3P_Msk (0x10UL)
#define R_MTU_TOLBRB_OLS3P_Pos (4UL)
#define R_MTU_TOLBRB_OLS3N_Msk (0x20UL)
#define R_MTU_TOLBRB_OLS3N_Pos (5UL)
#define R_MTU_TITMRB_TITM_Msk (0x01UL)
#define R_MTU_TITMRB_TITM_Pos (0UL)
#define R_MTU_TITCR2B_TRG7COR_Msk (0x07UL)
#define R_MTU_TITCR2B_TRG7COR_Pos (0UL)
#define R_MTU_TITCNT2B_TRG7CNT_Msk (0x07UL)
#define R_MTU_TITCNT2B_TRG7CNT_Pos (0UL)
#define R_MTU_TWCRB_WRE_Msk (0x01UL)
#define R_MTU_TWCRB_WRE_Pos (0UL)
#define R_MTU_TWCRB_SCC_Msk (0x02UL)
#define R_MTU_TWCRB_SCC_Pos (1UL)
#define R_MTU_TWCRB_CCE_Msk (0x80UL)
#define R_MTU_TWCRB_CCE_Pos (7UL)
#define R_MTU_TMDR2B_DRS_Msk (0x01UL)
#define R_MTU_TMDR2B_DRS_Pos (0UL)
#define R_MTU_TSTRB_CST6_Msk (0x40UL)
#define R_MTU_TSTRB_CST6_Pos (6UL)
#define R_MTU_TSTRB_CST7_Msk (0x80UL)
#define R_MTU_TSTRB_CST7_Pos (7UL)
#define R_MTU_TSYRB_SYNC6_Msk (0x40UL)
#define R_MTU_TSYRB_SYNC6_Pos (6UL)
#define R_MTU_TSYRB_SYNC7_Msk (0x80UL)
#define R_MTU_TSYRB_SYNC7_Pos (7UL)
#define R_MTU_TRWERB_RWE_Msk (0x01UL)
#define R_MTU_TRWERB_RWE_Pos (0UL)
#define R_MTU_NFCR0_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR0_NFAEN_Pos (0UL)
#define R_MTU_NFCR0_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR0_NFBEN_Pos (1UL)
#define R_MTU_NFCR0_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR0_NFCEN_Pos (2UL)
#define R_MTU_NFCR0_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR0_NFDEN_Pos (3UL)
#define R_MTU_NFCR0_NFCS_Msk (0x30UL)
#define R_MTU_NFCR0_NFCS_Pos (4UL)
#define R_MTU_NFCRC_NFAEN_Msk (0x01UL)
#define R_MTU_NFCRC_NFAEN_Pos (0UL)
#define R_MTU_NFCRC_NFBEN_Msk (0x02UL)
#define R_MTU_NFCRC_NFBEN_Pos (1UL)
#define R_MTU_NFCRC_NFCEN_Msk (0x04UL)
#define R_MTU_NFCRC_NFCEN_Pos (2UL)
#define R_MTU_NFCRC_NFDEN_Msk (0x08UL)
#define R_MTU_NFCRC_NFDEN_Pos (3UL)
#define R_MTU_NFCRC_NFCS_Msk (0x30UL)
#define R_MTU_NFCRC_NFCS_Pos (4UL)
#define R_MTU_TCR_TPSC_Msk (0x07UL)
#define R_MTU_TCR_TPSC_Pos (0UL)
#define R_MTU_TCR_CKEG_Msk (0x18UL)
#define R_MTU_TCR_CKEG_Pos (3UL)
#define R_MTU_TCR_CCLR_Msk (0xE0UL)
#define R_MTU_TCR_CCLR_Pos (5UL)
#define R_MTU_TMDR1_MD_Msk (0x0FUL)
#define R_MTU_TMDR1_MD_Pos (0UL)
#define R_MTU_TMDR1_BFA_Msk (0x10UL)
#define R_MTU_TMDR1_BFA_Pos (4UL)
#define R_MTU_TMDR1_BFB_Msk (0x20UL)
#define R_MTU_TMDR1_BFB_Pos (5UL)
#define R_MTU_TMDR1_BFE_Msk (0x40UL)
#define R_MTU_TMDR1_BFE_Pos (6UL)
#define R_MTU_TIORH_IOA_Msk (0x0FUL)
#define R_MTU_TIORH_IOA_Pos (0UL)
#define R_MTU_TIORH_IOB_Msk (0xF0UL)
#define R_MTU_TIORH_IOB_Pos (4UL)
#define R_MTU_TIORL_IOC_Msk (0x0FUL)
#define R_MTU_TIORL_IOC_Pos (0UL)
#define R_MTU_TIORL_IOD_Msk (0xF0UL)
#define R_MTU_TIORL_IOD_Pos (4UL)
#define R_MTU_TIER_TGIEA_Msk (0x01UL)
#define R_MTU_TIER_TGIEA_Pos (0UL)
#define R_MTU_TIER_TGIEB_Msk (0x02UL)
#define R_MTU_TIER_TGIEB_Pos (1UL)
#define R_MTU_TIER_TGIEC_Msk (0x04UL)
#define R_MTU_TIER_TGIEC_Pos (2UL)
#define R_MTU_TIER_TGIED_Msk (0x08UL)
#define R_MTU_TIER_TGIED_Pos (3UL)
#define R_MTU_TIER_TCIEV_Msk (0x10UL)
#define R_MTU_TIER_TCIEV_Pos (4UL)
#define R_MTU_TIER_TTGE_Msk (0x80UL)
#define R_MTU_TIER_TTGE_Pos (7UL)
#define R_MTU_TCNT_TCNT_Msk (0xFFFFUL)
#define R_MTU_TCNT_TCNT_Pos (0UL)
#define R_MTU_TGRA_TGRA_Msk (0xFFFFUL)
#define R_MTU_TGRA_TGRA_Pos (0UL)
#define R_MTU_TGRB_TGRB_Msk (0xFFFFUL)
#define R_MTU_TGRB_TGRB_Pos (0UL)
#define R_MTU_TGRC_TGRC_Msk (0xFFFFUL)
#define R_MTU_TGRC_TGRC_Pos (0UL)
#define R_MTU_TGRD_TGRD_Msk (0xFFFFUL)
#define R_MTU_TGRD_TGRD_Pos (0UL)
#define R_MTU_TGRE_TGRE_Msk (0xFFFFUL)
#define R_MTU_TGRE_TGRE_Pos (0UL)
#define R_MTU_TGRF_TGRF_Msk (0xFFFFUL)
#define R_MTU_TGRF_TGRF_Pos (0UL)
#define R_MTU_TIER2_TGIEE_Msk (0x01UL)
#define R_MTU_TIER2_TGIEE_Pos (0UL)
#define R_MTU_TIER2_TGIEF_Msk (0x02UL)
#define R_MTU_TIER2_TGIEF_Pos (1UL)
#define R_MTU_TIER2_TTGE2_Msk (0x80UL)
#define R_MTU_TIER2_TTGE2_Pos (7UL)
#define R_MTU_TBTM_TTSA_Msk (0x01UL)
#define R_MTU_TBTM_TTSA_Pos (0UL)
#define R_MTU_TBTM_TTSB_Msk (0x02UL)
#define R_MTU_TBTM_TTSB_Pos (1UL)
#define R_MTU_TBTM_TTSE_Msk (0x04UL)
#define R_MTU_TBTM_TTSE_Pos (2UL)
#define R_MTU_TCR2_TPSC2_Msk (0x07UL)
#define R_MTU_TCR2_TPSC2_Pos (0UL)
#define R_MTU_NFCR1_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR1_NFAEN_Pos (0UL)
#define R_MTU_NFCR1_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR1_NFBEN_Pos (1UL)
#define R_MTU_NFCR1_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR1_NFCEN_Pos (2UL)
#define R_MTU_NFCR1_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR1_NFDEN_Pos (3UL)
#define R_MTU_NFCR1_NFCS_Msk (0x30UL)
#define R_MTU_NFCR1_NFCS_Pos (4UL)
#define R_MTU_TIOR_IOA_Msk (0x0FUL)
#define R_MTU_TIOR_IOA_Pos (0UL)
#define R_MTU_TIOR_IOB_Msk (0xF0UL)
#define R_MTU_TIOR_IOB_Pos (4UL)
#define R_MTU_TIER_TCIEU_Msk (0x20UL)
#define R_MTU_TIER_TCIEU_Pos (5UL)
#define R_MTU_TSR_TCFD_Msk (0x80UL)
#define R_MTU_TSR_TCFD_Pos (7UL)
#define R_MTU_TICCR_I1AE_Msk (0x01UL)
#define R_MTU_TICCR_I1AE_Pos (0UL)
#define R_MTU_TICCR_I1BE_Msk (0x02UL)
#define R_MTU_TICCR_I1BE_Pos (1UL)
#define R_MTU_TICCR_I2AE_Msk (0x04UL)
#define R_MTU_TICCR_I2AE_Pos (2UL)
#define R_MTU_TICCR_I2BE_Msk (0x08UL)
#define R_MTU_TICCR_I2BE_Pos (3UL)
#define R_MTU_TMDR3_LWA_Msk (0x01UL)
#define R_MTU_TMDR3_LWA_Pos (0UL)
#define R_MTU_TMDR3_PHCKSEL_Msk (0x02UL)
#define R_MTU_TMDR3_PHCKSEL_Pos (1UL)
#define R_MTU_TCR2_PCB_Msk (0x18UL)
#define R_MTU_TCR2_PCB_Pos (3UL)
#define R_MTU_TCNTLW_TCNTLW_Msk (0xFFFFFFFFUL)
#define R_MTU_TCNTLW_TCNTLW_Pos (0UL)
#define R_MTU_TGRALW_TGRALW_Msk (0xFFFFFFFFUL)
#define R_MTU_TGRALW_TGRALW_Pos (0UL)
#define R_MTU_TGRBLW_TGRBLW_Msk (0xFFFFFFFFUL)
#define R_MTU_TGRBLW_TGRBLW_Pos (0UL)
#define R_MTU_NFCR2_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR2_NFAEN_Pos (0UL)
#define R_MTU_NFCR2_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR2_NFBEN_Pos (1UL)
#define R_MTU_NFCR2_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR2_NFCEN_Pos (2UL)
#define R_MTU_NFCR2_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR2_NFDEN_Pos (3UL)
#define R_MTU_NFCR2_NFCS_Msk (0x30UL)
#define R_MTU_NFCR2_NFCS_Pos (4UL)
#define R_MTU_NFCR3_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR3_NFAEN_Pos (0UL)
#define R_MTU_NFCR3_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR3_NFBEN_Pos (1UL)
#define R_MTU_NFCR3_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR3_NFCEN_Pos (2UL)
#define R_MTU_NFCR3_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR3_NFDEN_Pos (3UL)
#define R_MTU_NFCR3_NFCS_Msk (0x30UL)
#define R_MTU_NFCR3_NFCS_Pos (4UL)
#define R_MTU_TIER_TTGE2_Msk (0x40UL)
#define R_MTU_TIER_TTGE2_Pos (6UL)
#define R_MTU_TADCR_ITB4VE_Msk (0x0001UL)
#define R_MTU_TADCR_ITB4VE_Pos (0UL)
#define R_MTU_TADCR_ITB3AE_Msk (0x0002UL)
#define R_MTU_TADCR_ITB3AE_Pos (1UL)
#define R_MTU_TADCR_ITA4VE_Msk (0x0004UL)
#define R_MTU_TADCR_ITA4VE_Pos (2UL)
#define R_MTU_TADCR_ITA3AE_Msk (0x0008UL)
#define R_MTU_TADCR_ITA3AE_Pos (3UL)
#define R_MTU_TADCR_DT4BE_Msk (0x0010UL)
#define R_MTU_TADCR_DT4BE_Pos (4UL)
#define R_MTU_TADCR_UT4BE_Msk (0x0020UL)
#define R_MTU_TADCR_UT4BE_Pos (5UL)
#define R_MTU_TADCR_DT4AE_Msk (0x0040UL)
#define R_MTU_TADCR_DT4AE_Pos (6UL)
#define R_MTU_TADCR_UT4AE_Msk (0x0080UL)
#define R_MTU_TADCR_UT4AE_Pos (7UL)
#define R_MTU_TADCR_BF_Msk (0xC000UL)
#define R_MTU_TADCR_BF_Pos (14UL)
#define R_MTU_TADCORA_TADCORA_Msk (0xFFFFUL)
#define R_MTU_TADCORA_TADCORA_Pos (0UL)
#define R_MTU_TADCORB_TADCORB_Msk (0xFFFFUL)
#define R_MTU_TADCORB_TADCORB_Pos (0UL)
#define R_MTU_TADCOBRA_TADCOBRA_Msk (0xFFFFUL)
#define R_MTU_TADCOBRA_TADCOBRA_Pos (0UL)
#define R_MTU_TADCOBRB_TADCOBRB_Msk (0xFFFFUL)
#define R_MTU_TADCOBRB_TADCOBRB_Pos (0UL)
#define R_MTU_NFCR4_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR4_NFAEN_Pos (0UL)
#define R_MTU_NFCR4_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR4_NFBEN_Pos (1UL)
#define R_MTU_NFCR4_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR4_NFCEN_Pos (2UL)
#define R_MTU_NFCR4_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR4_NFDEN_Pos (3UL)
#define R_MTU_NFCR4_NFCS_Msk (0x30UL)
#define R_MTU_NFCR4_NFCS_Pos (4UL)
#define R_MTU_NFCR5_NFUEN_Msk (0x01UL)
#define R_MTU_NFCR5_NFUEN_Pos (0UL)
#define R_MTU_NFCR5_NFVEN_Msk (0x02UL)
#define R_MTU_NFCR5_NFVEN_Pos (1UL)
#define R_MTU_NFCR5_NFWEN_Msk (0x04UL)
#define R_MTU_NFCR5_NFWEN_Pos (2UL)
#define R_MTU_NFCR5_NFCS_Msk (0x30UL)
#define R_MTU_NFCR5_NFCS_Pos (4UL)
#define R_MTU_TCNTU_TCNT_Msk (0xFFFFUL)
#define R_MTU_TCNTU_TCNT_Pos (0UL)
#define R_MTU_TGRU_TGRU_Msk (0xFFFFUL)
#define R_MTU_TGRU_TGRU_Pos (0UL)
#define R_MTU_TCRU_TPSC_Msk (0x03UL)
#define R_MTU_TCRU_TPSC_Pos (0UL)
#define R_MTU_TCR2U_TPSC2_Msk (0x07UL)
#define R_MTU_TCR2U_TPSC2_Pos (0UL)
#define R_MTU_TCR2U_CKEG_Msk (0x18UL)
#define R_MTU_TCR2U_CKEG_Pos (3UL)
#define R_MTU_TIORU_IOC_Msk (0x1FUL)
#define R_MTU_TIORU_IOC_Pos (0UL)
#define R_MTU_TCNTV_TCNT_Msk (0xFFFFUL)
#define R_MTU_TCNTV_TCNT_Pos (0UL)
#define R_MTU_TGRV_TGRV_Msk (0xFFFFUL)
#define R_MTU_TGRV_TGRV_Pos (0UL)
#define R_MTU_TCRV_TPSC_Msk (0x03UL)
#define R_MTU_TCRV_TPSC_Pos (0UL)
#define R_MTU_TCR2V_TPSC2_Msk (0x07UL)
#define R_MTU_TCR2V_TPSC2_Pos (0UL)
#define R_MTU_TCR2V_CKEG_Msk (0x18UL)
#define R_MTU_TCR2V_CKEG_Pos (3UL)
#define R_MTU_TIORV_IOC_Msk (0x1FUL)
#define R_MTU_TIORV_IOC_Pos (0UL)
#define R_MTU_TCNTW_TCNT_Msk (0xFFFFUL)
#define R_MTU_TCNTW_TCNT_Pos (0UL)
#define R_MTU_TGRW_TGRW_Msk (0xFFFFUL)
#define R_MTU_TGRW_TGRW_Pos (0UL)
#define R_MTU_TCRW_TPSC_Msk (0x03UL)
#define R_MTU_TCRW_TPSC_Pos (0UL)
#define R_MTU_TCR2W_TPSC2_Msk (0x07UL)
#define R_MTU_TCR2W_TPSC2_Pos (0UL)
#define R_MTU_TCR2W_CKEG_Msk (0x18UL)
#define R_MTU_TCR2W_CKEG_Pos (3UL)
#define R_MTU_TIORW_IOC_Msk (0x1FUL)
#define R_MTU_TIORW_IOC_Pos (0UL)
#define R_MTU_TIER_TGIE5W_Msk (0x01UL)
#define R_MTU_TIER_TGIE5W_Pos (0UL)
#define R_MTU_TIER_TGIE5V_Msk (0x02UL)
#define R_MTU_TIER_TGIE5V_Pos (1UL)
#define R_MTU_TIER_TGIE5U_Msk (0x04UL)
#define R_MTU_TIER_TGIE5U_Pos (2UL)
#define R_MTU_TSTR_CSTW5_Msk (0x01UL)
#define R_MTU_TSTR_CSTW5_Pos (0UL)
#define R_MTU_TSTR_CSTV5_Msk (0x02UL)
#define R_MTU_TSTR_CSTV5_Pos (1UL)
#define R_MTU_TSTR_CSTU5_Msk (0x04UL)
#define R_MTU_TSTR_CSTU5_Pos (2UL)
#define R_MTU_TCNTCMPCLR_CMPCLR5W_Msk (0x01UL)
#define R_MTU_TCNTCMPCLR_CMPCLR5W_Pos (0UL)
#define R_MTU_TCNTCMPCLR_CMPCLR5V_Msk (0x02UL)
#define R_MTU_TCNTCMPCLR_CMPCLR5V_Pos (1UL)
#define R_MTU_TCNTCMPCLR_CMPCLR5U_Msk (0x04UL)
#define R_MTU_TCNTCMPCLR_CMPCLR5U_Pos (2UL)
#define R_MTU_TSYCR_CE2B_Msk (0x01UL)
#define R_MTU_TSYCR_CE2B_Pos (0UL)
#define R_MTU_TSYCR_CE2A_Msk (0x02UL)
#define R_MTU_TSYCR_CE2A_Pos (1UL)
#define R_MTU_TSYCR_CE1B_Msk (0x04UL)
#define R_MTU_TSYCR_CE1B_Pos (2UL)
#define R_MTU_TSYCR_CE1A_Msk (0x08UL)
#define R_MTU_TSYCR_CE1A_Pos (3UL)
#define R_MTU_TSYCR_CE0D_Msk (0x10UL)
#define R_MTU_TSYCR_CE0D_Pos (4UL)
#define R_MTU_TSYCR_CE0C_Msk (0x20UL)
#define R_MTU_TSYCR_CE0C_Pos (5UL)
#define R_MTU_TSYCR_CE0B_Msk (0x40UL)
#define R_MTU_TSYCR_CE0B_Pos (6UL)
#define R_MTU_TSYCR_CE0A_Msk (0x80UL)
#define R_MTU_TSYCR_CE0A_Pos (7UL)
#define R_MTU_NFCR6_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR6_NFAEN_Pos (0UL)
#define R_MTU_NFCR6_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR6_NFBEN_Pos (1UL)
#define R_MTU_NFCR6_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR6_NFCEN_Pos (2UL)
#define R_MTU_NFCR6_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR6_NFDEN_Pos (3UL)
#define R_MTU_NFCR6_NFCS_Msk (0x30UL)
#define R_MTU_NFCR6_NFCS_Pos (4UL)
#define R_MTU_TADCR_ITB7VE_Msk (0x0001UL)
#define R_MTU_TADCR_ITB7VE_Pos (0UL)
#define R_MTU_TADCR_ITB6AE_Msk (0x0002UL)
#define R_MTU_TADCR_ITB6AE_Pos (1UL)
#define R_MTU_TADCR_ITA7VE_Msk (0x0004UL)
#define R_MTU_TADCR_ITA7VE_Pos (2UL)
#define R_MTU_TADCR_ITA6AE_Msk (0x0008UL)
#define R_MTU_TADCR_ITA6AE_Pos (3UL)
#define R_MTU_TADCR_DT7BE_Msk (0x0010UL)
#define R_MTU_TADCR_DT7BE_Pos (4UL)
#define R_MTU_TADCR_UT7BE_Msk (0x0020UL)
#define R_MTU_TADCR_UT7BE_Pos (5UL)
#define R_MTU_TADCR_DT7AE_Msk (0x0040UL)
#define R_MTU_TADCR_DT7AE_Pos (6UL)
#define R_MTU_TADCR_UT7AE_Msk (0x0080UL)
#define R_MTU_TADCR_UT7AE_Pos (7UL)
#define R_MTU_NFCR7_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR7_NFAEN_Pos (0UL)
#define R_MTU_NFCR7_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR7_NFBEN_Pos (1UL)
#define R_MTU_NFCR7_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR7_NFCEN_Pos (2UL)
#define R_MTU_NFCR7_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR7_NFDEN_Pos (3UL)
#define R_MTU_NFCR7_NFCS_Msk (0x30UL)
#define R_MTU_NFCR7_NFCS_Pos (4UL)
#define R_MTU_NFCR8_NFAEN_Msk (0x01UL)
#define R_MTU_NFCR8_NFAEN_Pos (0UL)
#define R_MTU_NFCR8_NFBEN_Msk (0x02UL)
#define R_MTU_NFCR8_NFBEN_Pos (1UL)
#define R_MTU_NFCR8_NFCEN_Msk (0x04UL)
#define R_MTU_NFCR8_NFCEN_Pos (2UL)
#define R_MTU_NFCR8_NFDEN_Msk (0x08UL)
#define R_MTU_NFCR8_NFDEN_Pos (3UL)
#define R_MTU_NFCR8_NFCS_Msk (0x30UL)
#define R_MTU_NFCR8_NFCS_Pos (4UL)
#endif

View File

@ -0,0 +1,49 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : poeg_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for poeg.
*********************************************************************************************************************/
#ifndef POEG_IOBITMASK_H
#define POEG_IOBITMASK_H
#define R_POEG_POEGGn_PIDF_Msk (0x00000001UL)
#define R_POEG_POEGGn_PIDF_Pos (0UL)
#define R_POEG_POEGGn_IOCF_Msk (0x00000002UL)
#define R_POEG_POEGGn_IOCF_Pos (1UL)
#define R_POEG_POEGGn_SSF_Msk (0x00000008UL)
#define R_POEG_POEGGn_SSF_Pos (3UL)
#define R_POEG_POEGGn_PIDE_Msk (0x00000010UL)
#define R_POEG_POEGGn_PIDE_Pos (4UL)
#define R_POEG_POEGGn_IOCE_Msk (0x00000020UL)
#define R_POEG_POEGGn_IOCE_Pos (5UL)
#define R_POEG_POEGGn_ST_Msk (0x00010000UL)
#define R_POEG_POEGGn_ST_Pos (16UL)
#define R_POEG_POEGGn_INV_Msk (0x10000000UL)
#define R_POEG_POEGGn_INV_Pos (28UL)
#define R_POEG_POEGGn_NFEN_Msk (0x20000000UL)
#define R_POEG_POEGGn_NFEN_Pos (29UL)
#define R_POEG_POEGGn_NFCS_Msk (0xC0000000UL)
#define R_POEG_POEGGn_NFCS_Pos (30UL)
#endif /* POEG_IOBITMASK_H */

View File

@ -0,0 +1,187 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : riic_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for riic.
*********************************************************************************************************************/
#ifndef RIIC_IOBITMASK_H
#define RIIC_IOBITMASK_H
#define R_RIIC0_ICCR1_SDAI_Msk (0x00000001UL)
#define R_RIIC0_ICCR1_SDAI_Pos (0UL)
#define R_RIIC0_ICCR1_SCLI_Msk (0x00000002UL)
#define R_RIIC0_ICCR1_SCLI_Pos (1UL)
#define R_RIIC0_ICCR1_SDAO_Msk (0x00000004UL)
#define R_RIIC0_ICCR1_SDAO_Pos (2UL)
#define R_RIIC0_ICCR1_SCLO_Msk (0x00000008UL)
#define R_RIIC0_ICCR1_SCLO_Pos (3UL)
#define R_RIIC0_ICCR1_SOWP_Msk (0x00000010UL)
#define R_RIIC0_ICCR1_SOWP_Pos (4UL)
#define R_RIIC0_ICCR1_CLO_Msk (0x00000020UL)
#define R_RIIC0_ICCR1_CLO_Pos (5UL)
#define R_RIIC0_ICCR1_IICRST_Msk (0x00000040UL)
#define R_RIIC0_ICCR1_IICRST_Pos (6UL)
#define R_RIIC0_ICCR1_ICE_Msk (0x00000080UL)
#define R_RIIC0_ICCR1_ICE_Pos (7UL)
#define R_RIIC0_ICCR2_ST_Msk (0x00000002UL)
#define R_RIIC0_ICCR2_ST_Pos (1UL)
#define R_RIIC0_ICCR2_RS_Msk (0x00000004UL)
#define R_RIIC0_ICCR2_RS_Pos (2UL)
#define R_RIIC0_ICCR2_SP_Msk (0x00000008UL)
#define R_RIIC0_ICCR2_SP_Pos (3UL)
#define R_RIIC0_ICCR2_TRS_Msk (0x00000020UL)
#define R_RIIC0_ICCR2_TRS_Pos (5UL)
#define R_RIIC0_ICCR2_MST_Msk (0x00000040UL)
#define R_RIIC0_ICCR2_MST_Pos (6UL)
#define R_RIIC0_ICCR2_BBSY_Msk (0x00000080UL)
#define R_RIIC0_ICCR2_BBSY_Pos (7UL)
#define R_RIIC0_ICMR1_BC_Msk (0x00000007UL)
#define R_RIIC0_ICMR1_BC_Pos (0UL)
#define R_RIIC0_ICMR1_BCWP_Msk (0x00000008UL)
#define R_RIIC0_ICMR1_BCWP_Pos (3UL)
#define R_RIIC0_ICMR1_CKS_Msk (0x00000070UL)
#define R_RIIC0_ICMR1_CKS_Pos (4UL)
#define R_RIIC0_ICMR2_TMOS_Msk (0x00000001UL)
#define R_RIIC0_ICMR2_TMOS_Pos (0UL)
#define R_RIIC0_ICMR2_TMOL_Msk (0x00000002UL)
#define R_RIIC0_ICMR2_TMOL_Pos (1UL)
#define R_RIIC0_ICMR2_TMOH_Msk (0x00000004UL)
#define R_RIIC0_ICMR2_TMOH_Pos (2UL)
#define R_RIIC0_ICMR2_SDDL_Msk (0x00000070UL)
#define R_RIIC0_ICMR2_SDDL_Pos (4UL)
#define R_RIIC0_ICMR2_DLCS_Msk (0x00000080UL)
#define R_RIIC0_ICMR2_DLCS_Pos (7UL)
#define R_RIIC0_ICMR3_NF_Msk (0x00000003UL)
#define R_RIIC0_ICMR3_NF_Pos (0UL)
#define R_RIIC0_ICMR3_ACKBR_Msk (0x00000004UL)
#define R_RIIC0_ICMR3_ACKBR_Pos (2UL)
#define R_RIIC0_ICMR3_ACKBT_Msk (0x00000008UL)
#define R_RIIC0_ICMR3_ACKBT_Pos (3UL)
#define R_RIIC0_ICMR3_ACKWP_Msk (0x00000010UL)
#define R_RIIC0_ICMR3_ACKWP_Pos (4UL)
#define R_RIIC0_ICMR3_RDRFS_Msk (0x00000020UL)
#define R_RIIC0_ICMR3_RDRFS_Pos (5UL)
#define R_RIIC0_ICMR3_WAIT_Msk (0x00000040UL)
#define R_RIIC0_ICMR3_WAIT_Pos (6UL)
#define R_RIIC0_ICMR3_SMBE_Msk (0x00000080UL)
#define R_RIIC0_ICMR3_SMBE_Pos (7UL)
#define R_RIIC0_ICFER_TMOE_Msk (0x00000001UL)
#define R_RIIC0_ICFER_TMOE_Pos (0UL)
#define R_RIIC0_ICFER_MALE_Msk (0x00000002UL)
#define R_RIIC0_ICFER_MALE_Pos (1UL)
#define R_RIIC0_ICFER_NALE_Msk (0x00000004UL)
#define R_RIIC0_ICFER_NALE_Pos (2UL)
#define R_RIIC0_ICFER_SALE_Msk (0x00000008UL)
#define R_RIIC0_ICFER_SALE_Pos (3UL)
#define R_RIIC0_ICFER_NACKE_Msk (0x00000010UL)
#define R_RIIC0_ICFER_NACKE_Pos (4UL)
#define R_RIIC0_ICFER_NFE_Msk (0x00000020UL)
#define R_RIIC0_ICFER_NFE_Pos (5UL)
#define R_RIIC0_ICFER_SCLE_Msk (0x00000040UL)
#define R_RIIC0_ICFER_SCLE_Pos (6UL)
#define R_RIIC0_ICFER_FMPE_Msk (0x00000080UL)
#define R_RIIC0_ICFER_FMPE_Pos (7UL)
#define R_RIIC0_ICSER_SAR0_Msk (0x00000001UL)
#define R_RIIC0_ICSER_SAR0_Pos (0UL)
#define R_RIIC0_ICSER_SAR1_Msk (0x00000002UL)
#define R_RIIC0_ICSER_SAR1_Pos (1UL)
#define R_RIIC0_ICSER_SAR2_Msk (0x00000004UL)
#define R_RIIC0_ICSER_SAR2_Pos (2UL)
#define R_RIIC0_ICSER_GCE_Msk (0x00000008UL)
#define R_RIIC0_ICSER_GCE_Pos (3UL)
#define R_RIIC0_ICSER_DIDE_Msk (0x00000020UL)
#define R_RIIC0_ICSER_DIDE_Pos (5UL)
#define R_RIIC0_ICSER_HOAE_Msk (0x00000080UL)
#define R_RIIC0_ICSER_HOAE_Pos (7UL)
#define R_RIIC0_ICIER_TMOIE_Msk (0x00000001UL)
#define R_RIIC0_ICIER_TMOIE_Pos (0UL)
#define R_RIIC0_ICIER_ALIE_Msk (0x00000002UL)
#define R_RIIC0_ICIER_ALIE_Pos (1UL)
#define R_RIIC0_ICIER_STIE_Msk (0x00000004UL)
#define R_RIIC0_ICIER_STIE_Pos (2UL)
#define R_RIIC0_ICIER_SPIE_Msk (0x00000008UL)
#define R_RIIC0_ICIER_SPIE_Pos (3UL)
#define R_RIIC0_ICIER_NAKIE_Msk (0x00000010UL)
#define R_RIIC0_ICIER_NAKIE_Pos (4UL)
#define R_RIIC0_ICIER_RIE_Msk (0x00000020UL)
#define R_RIIC0_ICIER_RIE_Pos (5UL)
#define R_RIIC0_ICIER_TEIE_Msk (0x00000040UL)
#define R_RIIC0_ICIER_TEIE_Pos (6UL)
#define R_RIIC0_ICIER_TIE_Msk (0x00000080UL)
#define R_RIIC0_ICIER_TIE_Pos (7UL)
#define R_RIIC0_ICSR1_AAS0_Msk (0x00000001UL)
#define R_RIIC0_ICSR1_AAS0_Pos (0UL)
#define R_RIIC0_ICSR1_AAS1_Msk (0x00000002UL)
#define R_RIIC0_ICSR1_AAS1_Pos (1UL)
#define R_RIIC0_ICSR1_AAS2_Msk (0x00000004UL)
#define R_RIIC0_ICSR1_AAS2_Pos (2UL)
#define R_RIIC0_ICSR1_GCA_Msk (0x00000008UL)
#define R_RIIC0_ICSR1_GCA_Pos (3UL)
#define R_RIIC0_ICSR1_DID_Msk (0x00000020UL)
#define R_RIIC0_ICSR1_DID_Pos (5UL)
#define R_RIIC0_ICSR1_HOA_Msk (0x00000080UL)
#define R_RIIC0_ICSR1_HOA_Pos (7UL)
#define R_RIIC0_ICSR2_TMOF_Msk (0x00000001UL)
#define R_RIIC0_ICSR2_TMOF_Pos (0UL)
#define R_RIIC0_ICSR2_AL_Msk (0x00000002UL)
#define R_RIIC0_ICSR2_AL_Pos (1UL)
#define R_RIIC0_ICSR2_START_Msk (0x00000004UL)
#define R_RIIC0_ICSR2_START_Pos (2UL)
#define R_RIIC0_ICSR2_STOP_Msk (0x00000008UL)
#define R_RIIC0_ICSR2_STOP_Pos (3UL)
#define R_RIIC0_ICSR2_NACKF_Msk (0x00000010UL)
#define R_RIIC0_ICSR2_NACKF_Pos (4UL)
#define R_RIIC0_ICSR2_RDRF_Msk (0x00000020UL)
#define R_RIIC0_ICSR2_RDRF_Pos (5UL)
#define R_RIIC0_ICSR2_TEND_Msk (0x00000040UL)
#define R_RIIC0_ICSR2_TEND_Pos (6UL)
#define R_RIIC0_ICSR2_TDRE_Msk (0x00000080UL)
#define R_RIIC0_ICSR2_TDRE_Pos (7UL)
#define R_RIIC0_ICSAR0_SVA0_Msk (0x00000001UL)
#define R_RIIC0_ICSAR0_SVA0_Pos (0UL)
#define R_RIIC0_ICSAR0_SVA_Msk (0x000003FEUL)
#define R_RIIC0_ICSAR0_SVA_Pos (1UL)
#define R_RIIC0_ICSAR0_FS0_Msk (0x00008000UL)
#define R_RIIC0_ICSAR0_FS0_Pos (15UL)
#define R_RIIC0_ICSAR1_SVA0_Msk (0x00000001UL)
#define R_RIIC0_ICSAR1_SVA0_Pos (0UL)
#define R_RIIC0_ICSAR1_SVA_Msk (0x000003FEUL)
#define R_RIIC0_ICSAR1_SVA_Pos (1UL)
#define R_RIIC0_ICSAR1_FS1_Msk (0x00008000UL)
#define R_RIIC0_ICSAR1_FS1_Pos (15UL)
#define R_RIIC0_ICSAR2_SVA0_Msk (0x00000001UL)
#define R_RIIC0_ICSAR2_SVA0_Pos (0UL)
#define R_RIIC0_ICSAR2_SVA_Msk (0x000003FEUL)
#define R_RIIC0_ICSAR2_SVA_Pos (1UL)
#define R_RIIC0_ICSAR2_FS2_Msk (0x00008000UL)
#define R_RIIC0_ICSAR2_FS2_Pos (15UL)
#define R_RIIC0_ICBRL_BRL_Msk (0x0000001FUL)
#define R_RIIC0_ICBRL_BRL_Pos (0UL)
#define R_RIIC0_ICBRH_BRH_Msk (0x0000001FUL)
#define R_RIIC0_ICBRH_BRH_Pos (0UL)
#define R_RIIC0_ICDRT_DRT_Msk (0x000000FFUL)
#define R_RIIC0_ICDRT_DRT_Pos (0UL)
#define R_RIIC0_ICDRR_DRR_Msk (0x000000FFUL)
#define R_RIIC0_ICDRR_DRR_Pos (0UL)
#endif /* RIIC_IOBITMASK_H */

View File

@ -0,0 +1,163 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : rspi_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for rspi.
*********************************************************************************************************************/
#ifndef RSPI_IOBITMASK_H
#define RSPI_IOBITMASK_H
#define R_RSPI0_SPCR_MODFEN_Msk (0x04UL)
#define R_RSPI0_SPCR_MODFEN_Pos (2UL)
#define R_RSPI0_SPCR_MSTR_Msk (0x08UL)
#define R_RSPI0_SPCR_MSTR_Pos (3UL)
#define R_RSPI0_SPCR_SPEIE_Msk (0x10UL)
#define R_RSPI0_SPCR_SPEIE_Pos (4UL)
#define R_RSPI0_SPCR_SPTIE_Msk (0x20UL)
#define R_RSPI0_SPCR_SPTIE_Pos (5UL)
#define R_RSPI0_SPCR_SPE_Msk (0x40UL)
#define R_RSPI0_SPCR_SPE_Pos (6UL)
#define R_RSPI0_SPCR_SPRIE_Msk (0x80UL)
#define R_RSPI0_SPCR_SPRIE_Pos (7UL)
#define R_RSPI0_SSLP_SSL0P_Msk (0x01UL)
#define R_RSPI0_SSLP_SSL0P_Pos (0UL)
#define R_RSPI0_SPPCR_SPLP_Msk (0x01UL)
#define R_RSPI0_SPPCR_SPLP_Pos (0UL)
#define R_RSPI0_SPPCR_MOIFV_Msk (0x10UL)
#define R_RSPI0_SPPCR_MOIFV_Pos (4UL)
#define R_RSPI0_SPPCR_MOIFE_Msk (0x20UL)
#define R_RSPI0_SPPCR_MOIFE_Pos (5UL)
#define R_RSPI0_SPSR_OVRF_Msk (0x01UL)
#define R_RSPI0_SPSR_OVRF_Pos (0UL)
#define R_RSPI0_SPSR_MODF_Msk (0x04UL)
#define R_RSPI0_SPSR_MODF_Pos (2UL)
#define R_RSPI0_SPSR_SPTEF_Msk (0x20UL)
#define R_RSPI0_SPSR_SPTEF_Pos (5UL)
#define R_RSPI0_SPSR_TEND_Msk (0x40UL)
#define R_RSPI0_SPSR_TEND_Pos (6UL)
#define R_RSPI0_SPSR_SPRF_Msk (0x80UL)
#define R_RSPI0_SPSR_SPRF_Pos (7UL)
#define R_RSPI0_SPDR_SPD_Msk (0xFFFFFFFFUL)
#define R_RSPI0_SPDR_SPD_Pos (0UL)
#define R_RSPI0_SPSCR_SPSLN_Msk (0x03UL)
#define R_RSPI0_SPSCR_SPSLN_Pos (0UL)
#define R_RSPI0_SPSSR_SPCP_Msk (0x03UL)
#define R_RSPI0_SPSSR_SPCP_Pos (0UL)
#define R_RSPI0_SPBR_SPR_Msk (0xFFUL)
#define R_RSPI0_SPBR_SPR_Pos (0UL)
#define R_RSPI0_SPDCR_SPLW_Msk (0x60UL)
#define R_RSPI0_SPDCR_SPLW_Pos (5UL)
#define R_RSPI0_SPDCR_TXDMY_Msk (0x80UL)
#define R_RSPI0_SPDCR_TXDMY_Pos (7UL)
#define R_RSPI0_SPCKD_SCKDL_Msk (0x07UL)
#define R_RSPI0_SPCKD_SCKDL_Pos (0UL)
#define R_RSPI0_SSLND_SLNDL_Msk (0x07UL)
#define R_RSPI0_SSLND_SLNDL_Pos (0UL)
#define R_RSPI0_SPND_SPNDL_Msk (0x07UL)
#define R_RSPI0_SPND_SPNDL_Pos (0UL)
#define R_RSPI0_SPCMD0_CPHA_Msk (0x0001UL)
#define R_RSPI0_SPCMD0_CPHA_Pos (0UL)
#define R_RSPI0_SPCMD0_CPOL_Msk (0x0002UL)
#define R_RSPI0_SPCMD0_CPOL_Pos (1UL)
#define R_RSPI0_SPCMD0_BRDV_Msk (0x000CUL)
#define R_RSPI0_SPCMD0_BRDV_Pos (2UL)
#define R_RSPI0_SPCMD0_SSLKP_Msk (0x0080UL)
#define R_RSPI0_SPCMD0_SSLKP_Pos (7UL)
#define R_RSPI0_SPCMD0_SPB_Msk (0x0F00UL)
#define R_RSPI0_SPCMD0_SPB_Pos (8UL)
#define R_RSPI0_SPCMD0_LSBF_Msk (0x1000UL)
#define R_RSPI0_SPCMD0_LSBF_Pos (12UL)
#define R_RSPI0_SPCMD0_SPNDEN_Msk (0x2000UL)
#define R_RSPI0_SPCMD0_SPNDEN_Pos (13UL)
#define R_RSPI0_SPCMD0_SLNDEN_Msk (0x4000UL)
#define R_RSPI0_SPCMD0_SLNDEN_Pos (14UL)
#define R_RSPI0_SPCMD0_SCKDEN_Msk (0x8000UL)
#define R_RSPI0_SPCMD0_SCKDEN_Pos (15UL)
#define R_RSPI0_SPCMD1_CPHA_Msk (0x0001UL)
#define R_RSPI0_SPCMD1_CPHA_Pos (0UL)
#define R_RSPI0_SPCMD1_CPOL_Msk (0x0002UL)
#define R_RSPI0_SPCMD1_CPOL_Pos (1UL)
#define R_RSPI0_SPCMD1_BRDV_Msk (0x000CUL)
#define R_RSPI0_SPCMD1_BRDV_Pos (2UL)
#define R_RSPI0_SPCMD1_SSLKP_Msk (0x0080UL)
#define R_RSPI0_SPCMD1_SSLKP_Pos (7UL)
#define R_RSPI0_SPCMD1_SPB_Msk (0x0F00UL)
#define R_RSPI0_SPCMD1_SPB_Pos (8UL)
#define R_RSPI0_SPCMD1_LSBF_Msk (0x1000UL)
#define R_RSPI0_SPCMD1_LSBF_Pos (12UL)
#define R_RSPI0_SPCMD1_SPNDEN_Msk (0x2000UL)
#define R_RSPI0_SPCMD1_SPNDEN_Pos (13UL)
#define R_RSPI0_SPCMD1_SLNDEN_Msk (0x4000UL)
#define R_RSPI0_SPCMD1_SLNDEN_Pos (14UL)
#define R_RSPI0_SPCMD1_SCKDEN_Msk (0x8000UL)
#define R_RSPI0_SPCMD1_SCKDEN_Pos (15UL)
#define R_RSPI0_SPCMD2_CPHA_Msk (0x0001UL)
#define R_RSPI0_SPCMD2_CPHA_Pos (0UL)
#define R_RSPI0_SPCMD2_CPOL_Msk (0x0002UL)
#define R_RSPI0_SPCMD2_CPOL_Pos (1UL)
#define R_RSPI0_SPCMD2_BRDV_Msk (0x000CUL)
#define R_RSPI0_SPCMD2_BRDV_Pos (2UL)
#define R_RSPI0_SPCMD2_SSLKP_Msk (0x0080UL)
#define R_RSPI0_SPCMD2_SSLKP_Pos (7UL)
#define R_RSPI0_SPCMD2_SPB_Msk (0x0F00UL)
#define R_RSPI0_SPCMD2_SPB_Pos (8UL)
#define R_RSPI0_SPCMD2_LSBF_Msk (0x1000UL)
#define R_RSPI0_SPCMD2_LSBF_Pos (12UL)
#define R_RSPI0_SPCMD2_SPNDEN_Msk (0x2000UL)
#define R_RSPI0_SPCMD2_SPNDEN_Pos (13UL)
#define R_RSPI0_SPCMD2_SLNDEN_Msk (0x4000UL)
#define R_RSPI0_SPCMD2_SLNDEN_Pos (14UL)
#define R_RSPI0_SPCMD2_SCKDEN_Msk (0x8000UL)
#define R_RSPI0_SPCMD2_SCKDEN_Pos (15UL)
#define R_RSPI0_SPCMD3_CPHA_Msk (0x0001UL)
#define R_RSPI0_SPCMD3_CPHA_Pos (0UL)
#define R_RSPI0_SPCMD3_CPOL_Msk (0x0002UL)
#define R_RSPI0_SPCMD3_CPOL_Pos (1UL)
#define R_RSPI0_SPCMD3_BRDV_Msk (0x000CUL)
#define R_RSPI0_SPCMD3_BRDV_Pos (2UL)
#define R_RSPI0_SPCMD3_SSLKP_Msk (0x0080UL)
#define R_RSPI0_SPCMD3_SSLKP_Pos (7UL)
#define R_RSPI0_SPCMD3_SPB_Msk (0x0F00UL)
#define R_RSPI0_SPCMD3_SPB_Pos (8UL)
#define R_RSPI0_SPCMD3_LSBF_Msk (0x1000UL)
#define R_RSPI0_SPCMD3_LSBF_Pos (12UL)
#define R_RSPI0_SPCMD3_SPNDEN_Msk (0x2000UL)
#define R_RSPI0_SPCMD3_SPNDEN_Pos (13UL)
#define R_RSPI0_SPCMD3_SLNDEN_Msk (0x4000UL)
#define R_RSPI0_SPCMD3_SLNDEN_Pos (14UL)
#define R_RSPI0_SPCMD3_SCKDEN_Msk (0x8000UL)
#define R_RSPI0_SPCMD3_SCKDEN_Pos (15UL)
#define R_RSPI0_SPBFCR_RXTRG_Msk (0x07UL)
#define R_RSPI0_SPBFCR_RXTRG_Pos (0UL)
#define R_RSPI0_SPBFCR_TXTRG_Msk (0x30UL)
#define R_RSPI0_SPBFCR_TXTRG_Pos (4UL)
#define R_RSPI0_SPBFCR_RXRST_Msk (0x40UL)
#define R_RSPI0_SPBFCR_RXRST_Pos (6UL)
#define R_RSPI0_SPBFCR_TXRST_Msk (0x80UL)
#define R_RSPI0_SPBFCR_TXRST_Pos (7UL)
#define R_RSPI0_SPBFDR_R_Msk (0x003FUL)
#define R_RSPI0_SPBFDR_R_Pos (0UL)
#define R_RSPI0_SPBFDR_T_Msk (0x0F00UL)
#define R_RSPI0_SPBFDR_T_Pos (8UL)
#endif /* RSPI_IOBITMASK_H */

View File

@ -0,0 +1,141 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : scifa_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for scifa.
*********************************************************************************************************************/
#ifndef SCIFA_IOBITMASK_H
#define SCIFA_IOBITMASK_H
#define R_SCIFA0_SMR_CKS_Msk (0x0003UL)
#define R_SCIFA0_SMR_CKS_Pos (0UL)
#define R_SCIFA0_SMR_STOP_Msk (0x0008UL)
#define R_SCIFA0_SMR_STOP_Pos (3UL)
#define R_SCIFA0_SMR_PM_Msk (0x0010UL)
#define R_SCIFA0_SMR_PM_Pos (4UL)
#define R_SCIFA0_SMR_PE_Msk (0x0020UL)
#define R_SCIFA0_SMR_PE_Pos (5UL)
#define R_SCIFA0_SMR_CHR_Msk (0x0040UL)
#define R_SCIFA0_SMR_CHR_Pos (6UL)
#define R_SCIFA0_SMR_CM_Msk (0x0080UL)
#define R_SCIFA0_SMR_CM_Pos (7UL)
#define R_SCIFA0_MDDR_MDDR_Msk (0xFFUL)
#define R_SCIFA0_MDDR_MDDR_Pos (0UL)
#define R_SCIFA0_BRR_BRR_Msk (0xFFUL)
#define R_SCIFA0_BRR_BRR_Pos (0UL)
#define R_SCIFA0_SCR_CKE_Msk (0x0003UL)
#define R_SCIFA0_SCR_CKE_Pos (0UL)
#define R_SCIFA0_SCR_TEIE_Msk (0x0004UL)
#define R_SCIFA0_SCR_TEIE_Pos (2UL)
#define R_SCIFA0_SCR_REIE_Msk (0x0008UL)
#define R_SCIFA0_SCR_REIE_Pos (3UL)
#define R_SCIFA0_SCR_RE_Msk (0x0010UL)
#define R_SCIFA0_SCR_RE_Pos (4UL)
#define R_SCIFA0_SCR_TE_Msk (0x0020UL)
#define R_SCIFA0_SCR_TE_Pos (5UL)
#define R_SCIFA0_SCR_RIE_Msk (0x0040UL)
#define R_SCIFA0_SCR_RIE_Pos (6UL)
#define R_SCIFA0_SCR_TIE_Msk (0x0080UL)
#define R_SCIFA0_SCR_TIE_Pos (7UL)
#define R_SCIFA0_FTDR_FTDR_Msk (0xFFUL)
#define R_SCIFA0_FTDR_FTDR_Pos (0UL)
#define R_SCIFA0_FSR_DR_Msk (0x0001UL)
#define R_SCIFA0_FSR_DR_Pos (0UL)
#define R_SCIFA0_FSR_RDF_Msk (0x0002UL)
#define R_SCIFA0_FSR_RDF_Pos (1UL)
#define R_SCIFA0_FSR_PER_Msk (0x0004UL)
#define R_SCIFA0_FSR_PER_Pos (2UL)
#define R_SCIFA0_FSR_FER_Msk (0x0008UL)
#define R_SCIFA0_FSR_FER_Pos (3UL)
#define R_SCIFA0_FSR_BRK_Msk (0x0010UL)
#define R_SCIFA0_FSR_BRK_Pos (4UL)
#define R_SCIFA0_FSR_TDFE_Msk (0x0020UL)
#define R_SCIFA0_FSR_TDFE_Pos (5UL)
#define R_SCIFA0_FSR_TEND_Msk (0x0040UL)
#define R_SCIFA0_FSR_TEND_Pos (6UL)
#define R_SCIFA0_FSR_ER_Msk (0x0080UL)
#define R_SCIFA0_FSR_ER_Pos (7UL)
#define R_SCIFA0_FRDR_FRDR_Msk (0xFFUL)
#define R_SCIFA0_FRDR_FRDR_Pos (0UL)
#define R_SCIFA0_FCR_LOOP_Msk (0x0001UL)
#define R_SCIFA0_FCR_LOOP_Pos (0UL)
#define R_SCIFA0_FCR_RFRST_Msk (0x0002UL)
#define R_SCIFA0_FCR_RFRST_Pos (1UL)
#define R_SCIFA0_FCR_TFRST_Msk (0x0004UL)
#define R_SCIFA0_FCR_TFRST_Pos (2UL)
#define R_SCIFA0_FCR_MCE_Msk (0x0008UL)
#define R_SCIFA0_FCR_MCE_Pos (3UL)
#define R_SCIFA0_FCR_TTRG_Msk (0x0030UL)
#define R_SCIFA0_FCR_TTRG_Pos (4UL)
#define R_SCIFA0_FCR_RTRG_Msk (0x00C0UL)
#define R_SCIFA0_FCR_RTRG_Pos (6UL)
#define R_SCIFA0_FCR_RSTRG_Msk (0x0700UL)
#define R_SCIFA0_FCR_RSTRG_Pos (8UL)
#define R_SCIFA0_FDR_R_Msk (0x001FUL)
#define R_SCIFA0_FDR_R_Pos (0UL)
#define R_SCIFA0_FDR_T_Msk (0x1F00UL)
#define R_SCIFA0_FDR_T_Pos (8UL)
#define R_SCIFA0_SPTR_SPB2DT_Msk (0x0001UL)
#define R_SCIFA0_SPTR_SPB2DT_Pos (0UL)
#define R_SCIFA0_SPTR_SPB2IO_Msk (0x0002UL)
#define R_SCIFA0_SPTR_SPB2IO_Pos (1UL)
#define R_SCIFA0_SPTR_SCKDT_Msk (0x0004UL)
#define R_SCIFA0_SPTR_SCKDT_Pos (2UL)
#define R_SCIFA0_SPTR_SCKIO_Msk (0x0008UL)
#define R_SCIFA0_SPTR_SCKIO_Pos (3UL)
#define R_SCIFA0_SPTR_CTS2DT_Msk (0x0010UL)
#define R_SCIFA0_SPTR_CTS2DT_Pos (4UL)
#define R_SCIFA0_SPTR_CTS2IO_Msk (0x0020UL)
#define R_SCIFA0_SPTR_CTS2IO_Pos (5UL)
#define R_SCIFA0_SPTR_RTS2DT_Msk (0x0040UL)
#define R_SCIFA0_SPTR_RTS2DT_Pos (6UL)
#define R_SCIFA0_SPTR_RTS2IO_Msk (0x0080UL)
#define R_SCIFA0_SPTR_RTS2IO_Pos (7UL)
#define R_SCIFA0_LSR_ORER_Msk (0x0001UL)
#define R_SCIFA0_LSR_ORER_Pos (0UL)
#define R_SCIFA0_LSR_FER_Msk (0x003CUL)
#define R_SCIFA0_LSR_FER_Pos (2UL)
#define R_SCIFA0_LSR_PER_Msk (0x0F00UL)
#define R_SCIFA0_LSR_PER_Pos (8UL)
#define R_SCIFA0_SEMR_ABCS0_Msk (0x01UL)
#define R_SCIFA0_SEMR_ABCS0_Pos (0UL)
#define R_SCIFA0_SEMR_NFEN_Msk (0x04UL)
#define R_SCIFA0_SEMR_NFEN_Pos (2UL)
#define R_SCIFA0_SEMR_DIR_Msk (0x08UL)
#define R_SCIFA0_SEMR_DIR_Pos (3UL)
#define R_SCIFA0_SEMR_MDDRS_Msk (0x10UL)
#define R_SCIFA0_SEMR_MDDRS_Pos (4UL)
#define R_SCIFA0_SEMR_BRME_Msk (0x20UL)
#define R_SCIFA0_SEMR_BRME_Pos (5UL)
#define R_SCIFA0_SEMR_BGDM_Msk (0x80UL)
#define R_SCIFA0_SEMR_BGDM_Pos (7UL)
#define R_SCIFA0_FTCR_TFTC_Msk (0x001FUL)
#define R_SCIFA0_FTCR_TFTC_Pos (0UL)
#define R_SCIFA0_FTCR_TTRGS_Msk (0x0080UL)
#define R_SCIFA0_FTCR_TTRGS_Pos (7UL)
#define R_SCIFA0_FTCR_RFTC_Msk (0x1F00UL)
#define R_SCIFA0_FTCR_RFTC_Pos (8UL)
#define R_SCIFA0_FTCR_RTRGS_Msk (0x8000UL)
#define R_SCIFA0_FTCR_RTRGS_Pos (15UL)
#endif /* SCIFA_IOBITMASK_H */

View File

@ -0,0 +1,217 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : spibsc_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for spibsc.
*********************************************************************************************************************/
#ifndef SPIBSC_IOBITMASK_H
#define SPIBSC_IOBITMASK_H
#define R_SPIBSC_CMNCR_BSZ_Msk (0x00000003UL)
#define R_SPIBSC_CMNCR_BSZ_Pos (0UL)
#define R_SPIBSC_CMNCR_IO0FV_Msk (0x00000300UL)
#define R_SPIBSC_CMNCR_IO0FV_Pos (8UL)
#define R_SPIBSC_CMNCR_IO2FV_Msk (0x00003000UL)
#define R_SPIBSC_CMNCR_IO2FV_Pos (12UL)
#define R_SPIBSC_CMNCR_IO3FV_Msk (0x0000C000UL)
#define R_SPIBSC_CMNCR_IO3FV_Pos (14UL)
#define R_SPIBSC_CMNCR_MOIIO0_Msk (0x00030000UL)
#define R_SPIBSC_CMNCR_MOIIO0_Pos (16UL)
#define R_SPIBSC_CMNCR_MOIIO1_Msk (0x000C0000UL)
#define R_SPIBSC_CMNCR_MOIIO1_Pos (18UL)
#define R_SPIBSC_CMNCR_MOIIO2_Msk (0x00300000UL)
#define R_SPIBSC_CMNCR_MOIIO2_Pos (20UL)
#define R_SPIBSC_CMNCR_MOIIO3_Msk (0x00C00000UL)
#define R_SPIBSC_CMNCR_MOIIO3_Pos (22UL)
#define R_SPIBSC_CMNCR_MD_Msk (0x80000000UL)
#define R_SPIBSC_CMNCR_MD_Pos (31UL)
#define R_SPIBSC_SSLDR_SCKDL_Msk (0x00000007UL)
#define R_SPIBSC_SSLDR_SCKDL_Pos (0UL)
#define R_SPIBSC_SSLDR_SLNDL_Msk (0x00000700UL)
#define R_SPIBSC_SSLDR_SLNDL_Pos (8UL)
#define R_SPIBSC_SSLDR_SPNDL_Msk (0x00070000UL)
#define R_SPIBSC_SSLDR_SPNDL_Pos (16UL)
#define R_SPIBSC_DRCR_SSLE_Msk (0x00000001UL)
#define R_SPIBSC_DRCR_SSLE_Pos (0UL)
#define R_SPIBSC_DRCR_RBE_Msk (0x00000100UL)
#define R_SPIBSC_DRCR_RBE_Pos (8UL)
#define R_SPIBSC_DRCR_RCF_Msk (0x00000200UL)
#define R_SPIBSC_DRCR_RCF_Pos (9UL)
#define R_SPIBSC_DRCR_RBURST_Msk (0x001F0000UL)
#define R_SPIBSC_DRCR_RBURST_Pos (16UL)
#define R_SPIBSC_DRCR_SSLN_Msk (0x01000000UL)
#define R_SPIBSC_DRCR_SSLN_Pos (24UL)
#define R_SPIBSC_DRCMR_OCMD_Msk (0x000000FFUL)
#define R_SPIBSC_DRCMR_OCMD_Pos (0UL)
#define R_SPIBSC_DRCMR_CMD_Msk (0x00FF0000UL)
#define R_SPIBSC_DRCMR_CMD_Pos (16UL)
#define R_SPIBSC_DREAR_EAC_Msk (0x00000007UL)
#define R_SPIBSC_DREAR_EAC_Pos (0UL)
#define R_SPIBSC_DREAR_EAV_Msk (0x00FF0000UL)
#define R_SPIBSC_DREAR_EAV_Pos (16UL)
#define R_SPIBSC_DROPR_OPD0_Msk (0x000000FFUL)
#define R_SPIBSC_DROPR_OPD0_Pos (0UL)
#define R_SPIBSC_DROPR_OPD1_Msk (0x0000FF00UL)
#define R_SPIBSC_DROPR_OPD1_Pos (8UL)
#define R_SPIBSC_DROPR_OPD2_Msk (0x00FF0000UL)
#define R_SPIBSC_DROPR_OPD2_Pos (16UL)
#define R_SPIBSC_DROPR_OPD3_Msk (0xFF000000UL)
#define R_SPIBSC_DROPR_OPD3_Pos (24UL)
#define R_SPIBSC_DRENR_OPDE_Msk (0x000000F0UL)
#define R_SPIBSC_DRENR_OPDE_Pos (4UL)
#define R_SPIBSC_DRENR_ADE_Msk (0x00000F00UL)
#define R_SPIBSC_DRENR_ADE_Pos (8UL)
#define R_SPIBSC_DRENR_OCDE_Msk (0x00001000UL)
#define R_SPIBSC_DRENR_OCDE_Pos (12UL)
#define R_SPIBSC_DRENR_CDE_Msk (0x00004000UL)
#define R_SPIBSC_DRENR_CDE_Pos (14UL)
#define R_SPIBSC_DRENR_DME_Msk (0x00008000UL)
#define R_SPIBSC_DRENR_DME_Pos (15UL)
#define R_SPIBSC_DRENR_DRDB_Msk (0x00030000UL)
#define R_SPIBSC_DRENR_DRDB_Pos (16UL)
#define R_SPIBSC_DRENR_OPDB_Msk (0x00300000UL)
#define R_SPIBSC_DRENR_OPDB_Pos (20UL)
#define R_SPIBSC_DRENR_ADB_Msk (0x03000000UL)
#define R_SPIBSC_DRENR_ADB_Pos (24UL)
#define R_SPIBSC_DRENR_OCDB_Msk (0x30000000UL)
#define R_SPIBSC_DRENR_OCDB_Pos (28UL)
#define R_SPIBSC_DRENR_CDB_Msk (0xC0000000UL)
#define R_SPIBSC_DRENR_CDB_Pos (30UL)
#define R_SPIBSC_SMCR_SPIE_Msk (0x00000001UL)
#define R_SPIBSC_SMCR_SPIE_Pos (0UL)
#define R_SPIBSC_SMCR_SPIWE_Msk (0x00000002UL)
#define R_SPIBSC_SMCR_SPIWE_Pos (1UL)
#define R_SPIBSC_SMCR_SPIRE_Msk (0x00000004UL)
#define R_SPIBSC_SMCR_SPIRE_Pos (2UL)
#define R_SPIBSC_SMCR_SSLKP_Msk (0x00000100UL)
#define R_SPIBSC_SMCR_SSLKP_Pos (8UL)
#define R_SPIBSC_SMCMR_OCMD_Msk (0x000000FFUL)
#define R_SPIBSC_SMCMR_OCMD_Pos (0UL)
#define R_SPIBSC_SMCMR_CMD_Msk (0x00FF0000UL)
#define R_SPIBSC_SMCMR_CMD_Pos (16UL)
#define R_SPIBSC_SMADR_ADR_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_SMADR_ADR_Pos (0UL)
#define R_SPIBSC_SMOPR_OPD0_Msk (0x000000FFUL)
#define R_SPIBSC_SMOPR_OPD0_Pos (0UL)
#define R_SPIBSC_SMOPR_OPD1_Msk (0x0000FF00UL)
#define R_SPIBSC_SMOPR_OPD1_Pos (8UL)
#define R_SPIBSC_SMOPR_OPD2_Msk (0x00FF0000UL)
#define R_SPIBSC_SMOPR_OPD2_Pos (16UL)
#define R_SPIBSC_SMOPR_OPD3_Msk (0xFF000000UL)
#define R_SPIBSC_SMOPR_OPD3_Pos (24UL)
#define R_SPIBSC_SMENR_SPIDE_Msk (0x0000000FUL)
#define R_SPIBSC_SMENR_SPIDE_Pos (0UL)
#define R_SPIBSC_SMENR_OPDE_Msk (0x000000F0UL)
#define R_SPIBSC_SMENR_OPDE_Pos (4UL)
#define R_SPIBSC_SMENR_ADE_Msk (0x00000F00UL)
#define R_SPIBSC_SMENR_ADE_Pos (8UL)
#define R_SPIBSC_SMENR_OCDE_Msk (0x00001000UL)
#define R_SPIBSC_SMENR_OCDE_Pos (12UL)
#define R_SPIBSC_SMENR_CDE_Msk (0x00004000UL)
#define R_SPIBSC_SMENR_CDE_Pos (14UL)
#define R_SPIBSC_SMENR_DME_Msk (0x00008000UL)
#define R_SPIBSC_SMENR_DME_Pos (15UL)
#define R_SPIBSC_SMENR_SPIDB_Msk (0x00030000UL)
#define R_SPIBSC_SMENR_SPIDB_Pos (16UL)
#define R_SPIBSC_SMENR_OPDB_Msk (0x00300000UL)
#define R_SPIBSC_SMENR_OPDB_Pos (20UL)
#define R_SPIBSC_SMENR_ADB_Msk (0x03000000UL)
#define R_SPIBSC_SMENR_ADB_Pos (24UL)
#define R_SPIBSC_SMENR_OCDB_Msk (0x30000000UL)
#define R_SPIBSC_SMENR_OCDB_Pos (28UL)
#define R_SPIBSC_SMENR_CDB_Msk (0xC0000000UL)
#define R_SPIBSC_SMENR_CDB_Pos (30UL)
#define R_SPIBSC_SMRDR0_RDATA0_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_SMRDR0_RDATA0_Pos (0UL)
#define R_SPIBSC_SMRDR1_RDATA1_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_SMRDR1_RDATA1_Pos (0UL)
#define R_SPIBSC_SMWDR0_WDATA0_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_SMWDR0_WDATA0_Pos (0UL)
#define R_SPIBSC_SMWDR1_WDATA1_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_SMWDR1_WDATA1_Pos (0UL)
#define R_SPIBSC_CMNSR_TEND_Msk (0x00000001UL)
#define R_SPIBSC_CMNSR_TEND_Pos (0UL)
#define R_SPIBSC_CMNSR_SSLF_Msk (0x00000002UL)
#define R_SPIBSC_CMNSR_SSLF_Pos (1UL)
#define R_SPIBSC_DRDMCR_DMCYC_Msk (0x0000001FUL)
#define R_SPIBSC_DRDMCR_DMCYC_Pos (0UL)
#define R_SPIBSC_DRDRENR_DRDRE_Msk (0x00000001UL)
#define R_SPIBSC_DRDRENR_DRDRE_Pos (0UL)
#define R_SPIBSC_DRDRENR_OPDRE_Msk (0x00000010UL)
#define R_SPIBSC_DRDRENR_OPDRE_Pos (4UL)
#define R_SPIBSC_DRDRENR_ADDRE_Msk (0x00000100UL)
#define R_SPIBSC_DRDRENR_ADDRE_Pos (8UL)
#define R_SPIBSC_DRDRENR_HYPE_Msk (0x00007000UL)
#define R_SPIBSC_DRDRENR_HYPE_Pos (12UL)
#define R_SPIBSC_SMDMCR_DMCYC_Msk (0x0000001FUL)
#define R_SPIBSC_SMDMCR_DMCYC_Pos (0UL)
#define R_SPIBSC_SMDRENR_SPIDRE_Msk (0x00000001UL)
#define R_SPIBSC_SMDRENR_SPIDRE_Pos (0UL)
#define R_SPIBSC_SMDRENR_OPDRE_Msk (0x00000010UL)
#define R_SPIBSC_SMDRENR_OPDRE_Pos (4UL)
#define R_SPIBSC_SMDRENR_ADDRE_Msk (0x00000100UL)
#define R_SPIBSC_SMDRENR_ADDRE_Pos (8UL)
#define R_SPIBSC_SMDRENR_HYPE_Msk (0x00007000UL)
#define R_SPIBSC_SMDRENR_HYPE_Pos (12UL)
#define R_SPIBSC_PHYADJ1_ADJ1_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_PHYADJ1_ADJ1_Pos (0UL)
#define R_SPIBSC_PHYADJ2_ADJ2_Msk (0xFFFFFFFFUL)
#define R_SPIBSC_PHYADJ2_ADJ2_Pos (0UL)
#define R_SPIBSC_PHYCNT_PHYMEM_Msk (0x00000003UL)
#define R_SPIBSC_PHYCNT_PHYMEM_Pos (0UL)
#define R_SPIBSC_PHYCNT_WBUF_Msk (0x00000004UL)
#define R_SPIBSC_PHYCNT_WBUF_Pos (2UL)
#define R_SPIBSC_PHYCNT_WBUF2_Msk (0x00000010UL)
#define R_SPIBSC_PHYCNT_WBUF2_Pos (4UL)
#define R_SPIBSC_PHYCNT_CKSEL_Msk (0x00030000UL)
#define R_SPIBSC_PHYCNT_CKSEL_Pos (16UL)
#define R_SPIBSC_PHYCNT_HS_Msk (0x00040000UL)
#define R_SPIBSC_PHYCNT_HS_Pos (18UL)
#define R_SPIBSC_PHYCNT_OCT_Msk (0x00100000UL)
#define R_SPIBSC_PHYCNT_OCT_Pos (20UL)
#define R_SPIBSC_PHYCNT_EXDS_Msk (0x00200000UL)
#define R_SPIBSC_PHYCNT_EXDS_Pos (21UL)
#define R_SPIBSC_PHYCNT_OCTA_Msk (0x00C00000UL)
#define R_SPIBSC_PHYCNT_OCTA_Pos (22UL)
#define R_SPIBSC_PHYCNT_ALT_ALIGN_Msk (0x40000000UL)
#define R_SPIBSC_PHYCNT_ALT_ALIGN_Pos (30UL)
#define R_SPIBSC_PHYCNT_CAL_Msk (0x80000000UL)
#define R_SPIBSC_PHYCNT_CAL_Pos (31UL)
#define R_SPIBSC_PHYOFFSET1_DDRTMG_Msk (0x30000000UL)
#define R_SPIBSC_PHYOFFSET1_DDRTMG_Pos (28UL)
#define R_SPIBSC_PHYOFFSET2_OCTTMG_Msk (0x00000700UL)
#define R_SPIBSC_PHYOFFSET2_OCTTMG_Pos (8UL)
#define R_SPIBSC_PHYINT_INT_Msk (0x00000001UL)
#define R_SPIBSC_PHYINT_INT_Pos (0UL)
#define R_SPIBSC_PHYINT_WPVAL_Msk (0x00000002UL)
#define R_SPIBSC_PHYINT_WPVAL_Pos (1UL)
#define R_SPIBSC_PHYINT_RSTVAL_Msk (0x00000004UL)
#define R_SPIBSC_PHYINT_RSTVAL_Pos (2UL)
#define R_SPIBSC_PHYINT_INTEN_Msk (0x01000000UL)
#define R_SPIBSC_PHYINT_INTEN_Pos (24UL)
#define R_SPIBSC_PHYINT_WPEN_Msk (0x02000000UL)
#define R_SPIBSC_PHYINT_WPEN_Pos (25UL)
#define R_SPIBSC_PHYINT_RSTEN_Msk (0x04000000UL)
#define R_SPIBSC_PHYINT_RSTEN_Pos (26UL)
#endif /* SPIBSC_IOBITMASK_H */

View File

@ -0,0 +1,123 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : ssi_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for ssi.
*********************************************************************************************************************/
#ifndef SSI_IOBITMASK_H
#define SSI_IOBITMASK_H
#define R_SSI_SSICR_REN_Msk (0x00000001UL)
#define R_SSI_SSICR_REN_Pos (0UL)
#define R_SSI_SSICR_TEN_Msk (0x00000002UL)
#define R_SSI_SSICR_TEN_Pos (1UL)
#define R_SSI_SSICR_MUEN_Msk (0x00000008UL)
#define R_SSI_SSICR_MUEN_Pos (3UL)
#define R_SSI_SSICR_CKDV_Msk (0x000000F0UL)
#define R_SSI_SSICR_CKDV_Pos (4UL)
#define R_SSI_SSICR_DEL_Msk (0x00000100UL)
#define R_SSI_SSICR_DEL_Pos (8UL)
#define R_SSI_SSICR_PDTA_Msk (0x00000200UL)
#define R_SSI_SSICR_PDTA_Pos (9UL)
#define R_SSI_SSICR_SDTA_Msk (0x00000400UL)
#define R_SSI_SSICR_SDTA_Pos (10UL)
#define R_SSI_SSICR_SPDP_Msk (0x00000800UL)
#define R_SSI_SSICR_SPDP_Pos (11UL)
#define R_SSI_SSICR_LRCKP_Msk (0x00001000UL)
#define R_SSI_SSICR_LRCKP_Pos (12UL)
#define R_SSI_SSICR_BCKP_Msk (0x00002000UL)
#define R_SSI_SSICR_BCKP_Pos (13UL)
#define R_SSI_SSICR_MST_Msk (0x00004000UL)
#define R_SSI_SSICR_MST_Pos (14UL)
#define R_SSI_SSICR_SWL_Msk (0x00070000UL)
#define R_SSI_SSICR_SWL_Pos (16UL)
#define R_SSI_SSICR_DWL_Msk (0x00380000UL)
#define R_SSI_SSICR_DWL_Pos (19UL)
#define R_SSI_SSICR_FRM_Msk (0x00C00000UL)
#define R_SSI_SSICR_FRM_Pos (22UL)
#define R_SSI_SSICR_IIEN_Msk (0x02000000UL)
#define R_SSI_SSICR_IIEN_Pos (25UL)
#define R_SSI_SSICR_ROIEN_Msk (0x04000000UL)
#define R_SSI_SSICR_ROIEN_Pos (26UL)
#define R_SSI_SSICR_RUIEN_Msk (0x08000000UL)
#define R_SSI_SSICR_RUIEN_Pos (27UL)
#define R_SSI_SSICR_TOIEN_Msk (0x10000000UL)
#define R_SSI_SSICR_TOIEN_Pos (28UL)
#define R_SSI_SSICR_TUIEN_Msk (0x20000000UL)
#define R_SSI_SSICR_TUIEN_Pos (29UL)
#define R_SSI_SSICR_CKS_Msk (0x40000000UL)
#define R_SSI_SSICR_CKS_Pos (30UL)
#define R_SSI_SSISR_IIRQ_Msk (0x02000000UL)
#define R_SSI_SSISR_IIRQ_Pos (25UL)
#define R_SSI_SSISR_ROIRQ_Msk (0x04000000UL)
#define R_SSI_SSISR_ROIRQ_Pos (26UL)
#define R_SSI_SSISR_RUIRQ_Msk (0x08000000UL)
#define R_SSI_SSISR_RUIRQ_Pos (27UL)
#define R_SSI_SSISR_TOIRQ_Msk (0x10000000UL)
#define R_SSI_SSISR_TOIRQ_Pos (28UL)
#define R_SSI_SSISR_TUIRQ_Msk (0x20000000UL)
#define R_SSI_SSISR_TUIRQ_Pos (29UL)
#define R_SSI_SSIFCR_RFRST_Msk (0x00000001UL)
#define R_SSI_SSIFCR_RFRST_Pos (0UL)
#define R_SSI_SSIFCR_TFRST_Msk (0x00000002UL)
#define R_SSI_SSIFCR_TFRST_Pos (1UL)
#define R_SSI_SSIFCR_RIE_Msk (0x00000004UL)
#define R_SSI_SSIFCR_RIE_Pos (2UL)
#define R_SSI_SSIFCR_TIE_Msk (0x00000008UL)
#define R_SSI_SSIFCR_TIE_Pos (3UL)
#define R_SSI_SSIFCR_RXDNCE_Msk (0x00000100UL)
#define R_SSI_SSIFCR_RXDNCE_Pos (8UL)
#define R_SSI_SSIFCR_LRCKNCE_Msk (0x00000200UL)
#define R_SSI_SSIFCR_LRCKNCE_Pos (9UL)
#define R_SSI_SSIFCR_BCKNCE_Msk (0x00000400UL)
#define R_SSI_SSIFCR_BCKNCE_Pos (10UL)
#define R_SSI_SSIFCR_BSW_Msk (0x00000800UL)
#define R_SSI_SSIFCR_BSW_Pos (11UL)
#define R_SSI_SSIFCR_SSIRST_Msk (0x00010000UL)
#define R_SSI_SSIFCR_SSIRST_Pos (16UL)
#define R_SSI_SSIFCR_AUCKE_Msk (0x80000000UL)
#define R_SSI_SSIFCR_AUCKE_Pos (31UL)
#define R_SSI_SSIFSR_RDF_Msk (0x00000001UL)
#define R_SSI_SSIFSR_RDF_Pos (0UL)
#define R_SSI_SSIFSR_RDC_Msk (0x00003F00UL)
#define R_SSI_SSIFSR_RDC_Pos (8UL)
#define R_SSI_SSIFSR_TDE_Msk (0x00010000UL)
#define R_SSI_SSIFSR_TDE_Pos (16UL)
#define R_SSI_SSIFSR_TDC_Msk (0x3F000000UL)
#define R_SSI_SSIFSR_TDC_Pos (24UL)
#define R_SSI_SSIFTDR_SSIFTDR_Msk (0xFFFFFFFFUL)
#define R_SSI_SSIFTDR_SSIFTDR_Pos (0UL)
#define R_SSI_SSIFRDR_SSIFRDR_Msk (0xFFFFFFFFUL)
#define R_SSI_SSIFRDR_SSIFRDR_Pos (0UL)
#define R_SSI_SSIOFR_OMOD_Msk (0x00000003UL)
#define R_SSI_SSIOFR_OMOD_Pos (0UL)
#define R_SSI_SSIOFR_LRCONT_Msk (0x00000100UL)
#define R_SSI_SSIOFR_LRCONT_Pos (8UL)
#define R_SSI_SSIOFR_BCKSTP_Msk (0x00000200UL)
#define R_SSI_SSIOFR_BCKSTP_Pos (9UL)
#define R_SSI_SSISCR_RDFS_Msk (0x0000001FUL)
#define R_SSI_SSISCR_RDFS_Pos (0UL)
#define R_SSI_SSISCR_TDES_Msk (0x00001F00UL)
#define R_SSI_SSISCR_TDES_Pos (8UL)
#endif

View File

@ -0,0 +1,663 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : sysc_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for sysc.
*********************************************************************************************************************/
#ifndef SYSC_IOBITMASK_H
#define SYSC_IOBITMASK_H
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_AWPU_Msk (0x00000001UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_AWPU_Pos (0UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_AWNS_Msk (0x00000002UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_AWNS_Pos (1UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_AWSEL_Msk (0x00000008UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_AWSEL_Pos (3UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_ARPU_Msk (0x00000010UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_ARPU_Pos (4UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_ARNS_Msk (0x00000020UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_ARNS_Pos (5UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_ARSEL_Msk (0x00000080UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC0_ARSEL_Pos (7UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_AWPU_Msk (0x00000100UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_AWPU_Pos (8UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_AWNS_Msk (0x00000200UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_AWNS_Pos (9UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_AWSEL_Msk (0x00000800UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_AWSEL_Pos (11UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_ARPU_Msk (0x00001000UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_ARPU_Pos (12UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_ARNS_Msk (0x00002000UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_ARNS_Pos (13UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_ARSEL_Msk (0x00008000UL)
#define R_SYSC_SYS_MSTACCCTL0_DMAC1_ARSEL_Pos (15UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_AWPU_Msk (0x00000001UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_AWPU_Pos (0UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_AWNS_Msk (0x00000002UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_AWNS_Pos (1UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_AWSEL_Msk (0x00000008UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_AWSEL_Pos (3UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_ARPU_Msk (0x00000010UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_ARPU_Pos (4UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_ARNS_Msk (0x00000020UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_ARNS_Pos (5UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_ARSEL_Msk (0x00000080UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI0_ARSEL_Pos (7UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_AWPU_Msk (0x00000100UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_AWPU_Pos (8UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_AWNS_Msk (0x00000200UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_AWNS_Pos (9UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_AWSEL_Msk (0x00000800UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_AWSEL_Pos (11UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_ARPU_Msk (0x00001000UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_ARPU_Pos (12UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_ARNS_Msk (0x00002000UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_ARNS_Pos (13UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_ARSEL_Msk (0x00008000UL)
#define R_SYSC_SYS_MSTACCCTL1_SDHI1_ARSEL_Pos (15UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_AWPU_Msk (0x00010000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_AWPU_Pos (16UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_AWNS_Msk (0x00020000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_AWNS_Pos (17UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_AWSEL_Msk (0x00080000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_AWSEL_Pos (19UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_ARPU_Msk (0x00100000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_ARPU_Pos (20UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_ARNS_Msk (0x00200000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_ARNS_Pos (21UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_ARSEL_Msk (0x00800000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther0_ARSEL_Pos (23UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_AWPU_Msk (0x01000000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_AWPU_Pos (24UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_AWNS_Msk (0x02000000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_AWNS_Pos (25UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_AWSEL_Msk (0x08000000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_AWSEL_Pos (27UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_ARPU_Msk (0x10000000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_ARPU_Pos (28UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_ARNS_Msk (0x20000000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_ARNS_Pos (29UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_ARSEL_Msk (0x80000000UL)
#define R_SYSC_SYS_MSTACCCTL1_GEther1_ARSEL_Pos (31UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_AWPU_Msk (0x00000001UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_AWPU_Pos (0UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_AWNS_Msk (0x00000002UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_AWNS_Pos (1UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_AWSEL_Msk (0x00000008UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_AWSEL_Pos (3UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_ARPU_Msk (0x00000010UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_ARPU_Pos (4UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_ARNS_Msk (0x00000020UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_ARNS_Pos (5UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_ARSEL_Msk (0x00000080UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20H_ARSEL_Pos (7UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_AWPU_Msk (0x00000100UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_AWPU_Pos (8UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_AWNS_Msk (0x00000200UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_AWNS_Pos (9UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_AWSEL_Msk (0x00000800UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_AWSEL_Pos (11UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_ARPU_Msk (0x00001000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_ARPU_Pos (12UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_ARNS_Msk (0x00002000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_ARNS_Pos (13UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_ARSEL_Msk (0x00008000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB21H_ARSEL_Pos (15UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_AWPU_Msk (0x00010000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_AWPU_Pos (16UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_AWNS_Msk (0x00020000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_AWNS_Pos (17UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_AWSEL_Msk (0x00080000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_AWSEL_Pos (19UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_ARPU_Msk (0x00100000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_ARPU_Pos (20UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_ARNS_Msk (0x00200000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_ARNS_Pos (21UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_ARSEL_Msk (0x00800000UL)
#define R_SYSC_SYS_MSTACCCTL2_USB20D_ARSEL_Pos (23UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_AWPU_Msk (0x00000100UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_AWPU_Pos (8UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_AWNS_Msk (0x00000200UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_AWNS_Pos (9UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_AWSEL_Msk (0x00000800UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_AWSEL_Pos (11UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_ARPU_Msk (0x00001000UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_ARPU_Pos (12UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_ARNS_Msk (0x00002000UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_ARNS_Pos (13UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_ARSEL_Msk (0x00008000UL)
#define R_SYSC_SYS_MSTACCCTL3_LCDC_ARSEL_Pos (15UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_AWPU_Msk (0x00000001UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_AWPU_Pos (0UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_AWNS_Msk (0x00000002UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_AWNS_Pos (1UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_AWSEL_Msk (0x00000008UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_AWSEL_Pos (3UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_ARPU_Msk (0x00000010UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_ARPU_Pos (4UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_ARNS_Msk (0x00000020UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_ARNS_Pos (5UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_ARSEL_Msk (0x00000080UL)
#define R_SYSC_SYS_MSTACCCTL4_ISU_ARSEL_Pos (7UL)
#define R_SYSC_SYS_MSTACCCTL4_CRU_AWPU_Msk (0x00010000UL)
#define R_SYSC_SYS_MSTACCCTL4_CRU_AWPU_Pos (16UL)
#define R_SYSC_SYS_MSTACCCTL4_CRU_AWNS_Msk (0x00020000UL)
#define R_SYSC_SYS_MSTACCCTL4_CRU_AWNS_Pos (17UL)
#define R_SYSC_SYS_MSTACCCTL4_CRU_AWSEL_Msk (0x00080000UL)
#define R_SYSC_SYS_MSTACCCTL4_CRU_AWSEL_Pos (19UL)
#define R_SYSC_SYS_SLVACCCTL0_SRAM0_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL0_SRAM0_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL0_SRAM1_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL0_SRAM1_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC0_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC0_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC1_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL1_TZC1_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC2_SL_Msk (0x00000030UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC2_SL_Pos (4UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC3_SL_Msk (0x000000C0UL)
#define R_SYSC_SYS_SLVACCCTL1_TZC3_SL_Pos (6UL)
#define R_SYSC_SYS_SLVACCCTL1_CST_SL_Msk (0x00000C00UL)
#define R_SYSC_SYS_SLVACCCTL1_CST_SL_Pos (10UL)
#define R_SYSC_SYS_SLVACCCTL1_CPG_SL_Msk (0x00003000UL)
#define R_SYSC_SYS_SLVACCCTL1_CPG_SL_Pos (12UL)
#define R_SYSC_SYS_SLVACCCTL1_SYSC_SL_Msk (0x0000C000UL)
#define R_SYSC_SYS_SLVACCCTL1_SYSC_SL_Pos (14UL)
#define R_SYSC_SYS_SLVACCCTL1_SYS_SL_Msk (0x00030000UL)
#define R_SYSC_SYS_SLVACCCTL1_SYS_SL_Pos (16UL)
#define R_SYSC_SYS_SLVACCCTL1_GIC_SL_Msk (0x000C0000UL)
#define R_SYSC_SYS_SLVACCCTL1_GIC_SL_Pos (18UL)
#define R_SYSC_SYS_SLVACCCTL1_IA55_IM33_SL_Msk (0x00300000UL)
#define R_SYSC_SYS_SLVACCCTL1_IA55_IM33_SL_Pos (20UL)
#define R_SYSC_SYS_SLVACCCTL1_GPIO_SL_Msk (0x00C00000UL)
#define R_SYSC_SYS_SLVACCCTL1_GPIO_SL_Pos (22UL)
#define R_SYSC_SYS_SLVACCCTL1_MHU_SL_Msk (0x03000000UL)
#define R_SYSC_SYS_SLVACCCTL1_MHU_SL_Pos (24UL)
#define R_SYSC_SYS_SLVACCCTL1_DMAC0_SL_Msk (0x0C000000UL)
#define R_SYSC_SYS_SLVACCCTL1_DMAC0_SL_Pos (26UL)
#define R_SYSC_SYS_SLVACCCTL1_DMAC1_SL_Msk (0x30000000UL)
#define R_SYSC_SYS_SLVACCCTL1_DMAC1_SL_Pos (28UL)
#define R_SYSC_SYS_SLVACCCTL2_OSTM0_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL2_OSTM0_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL2_OSTM1_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL2_OSTM1_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL2_OSTM2_SL_Msk (0x00000030UL)
#define R_SYSC_SYS_SLVACCCTL2_OSTM2_SL_Pos (4UL)
#define R_SYSC_SYS_SLVACCCTL2_WDT0_SL_Msk (0x000000C0UL)
#define R_SYSC_SYS_SLVACCCTL2_WDT0_SL_Pos (6UL)
#define R_SYSC_SYS_SLVACCCTL2_WDT2_SL_Msk (0x00000C00UL)
#define R_SYSC_SYS_SLVACCCTL2_WDT2_SL_Pos (10UL)
#define R_SYSC_SYS_SLVACCCTL2_MTU3A_SL_Msk (0x0000C000UL)
#define R_SYSC_SYS_SLVACCCTL2_MTU3A_SL_Pos (14UL)
#define R_SYSC_SYS_SLVACCCTL2_POE3_SL_Msk (0x00030000UL)
#define R_SYSC_SYS_SLVACCCTL2_POE3_SL_Pos (16UL)
#define R_SYSC_SYS_SLVACCCTL2_DDR_SL_Msk (0x00C00000UL)
#define R_SYSC_SYS_SLVACCCTL2_DDR_SL_Pos (22UL)
#define R_SYSC_SYS_SLVACCCTL3_CRU_SL_Msk (0x00000030UL)
#define R_SYSC_SYS_SLVACCCTL3_CRU_SL_Pos (4UL)
#define R_SYSC_SYS_SLVACCCTL3_ISU_SL_Msk (0x000000C0UL)
#define R_SYSC_SYS_SLVACCCTL3_ISU_SL_Pos (6UL)
#define R_SYSC_SYS_SLVACCCTL3_LCDC_SL_Msk (0x00003000UL)
#define R_SYSC_SYS_SLVACCCTL3_LCDC_SL_Pos (12UL)
#define R_SYSC_SYS_SLVACCCTL3_USBT_SL_Msk (0x00030000UL)
#define R_SYSC_SYS_SLVACCCTL3_USBT_SL_Pos (16UL)
#define R_SYSC_SYS_SLVACCCTL3_USB20_SL_Msk (0x000C0000UL)
#define R_SYSC_SYS_SLVACCCTL3_USB20_SL_Pos (18UL)
#define R_SYSC_SYS_SLVACCCTL3_USB21_SL_Msk (0x00300000UL)
#define R_SYSC_SYS_SLVACCCTL3_USB21_SL_Pos (20UL)
#define R_SYSC_SYS_SLVACCCTL3_SDHI0_SL_Msk (0x00C00000UL)
#define R_SYSC_SYS_SLVACCCTL3_SDHI0_SL_Pos (22UL)
#define R_SYSC_SYS_SLVACCCTL3_SDHI1_SL_Msk (0x03000000UL)
#define R_SYSC_SYS_SLVACCCTL3_SDHI1_SL_Pos (24UL)
#define R_SYSC_SYS_SLVACCCTL3_ETH0_SL_Msk (0x0C000000UL)
#define R_SYSC_SYS_SLVACCCTL3_ETH0_SL_Pos (26UL)
#define R_SYSC_SYS_SLVACCCTL3_ETH1_SL_Msk (0x30000000UL)
#define R_SYSC_SYS_SLVACCCTL3_ETH1_SL_Pos (28UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C0_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C0_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C1_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL4_I2C1_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C2_SL_Msk (0x00000030UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C2_SL_Pos (4UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C3_SL_Msk (0x000000C0UL)
#define R_SYSC_SYS_SLVACCCTL4_I2C3_SL_Pos (6UL)
#define R_SYSC_SYS_SLVACCCTL4_CANFD_SL_Msk (0x00000300UL)
#define R_SYSC_SYS_SLVACCCTL4_CANFD_SL_Pos (8UL)
#define R_SYSC_SYS_SLVACCCTL4_RSPI_SL_Msk (0x00000C00UL)
#define R_SYSC_SYS_SLVACCCTL4_RSPI_SL_Pos (10UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF0_SL_Msk (0x00030000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF0_SL_Pos (16UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF1_SL_Msk (0x000C0000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF1_SL_Pos (18UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF2_SL_Msk (0x00300000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF2_SL_Pos (20UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF3_SL_Msk (0x00C00000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF3_SL_Pos (22UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF4_SL_Msk (0x03000000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCIF4_SL_Pos (24UL)
#define R_SYSC_SYS_SLVACCCTL4_SCI0_SL_Msk (0x0C000000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCI0_SL_Pos (26UL)
#define R_SYSC_SYS_SLVACCCTL4_SCI1_SL_Msk (0x30000000UL)
#define R_SYSC_SYS_SLVACCCTL4_SCI1_SL_Pos (28UL)
#define R_SYSC_SYS_SLVACCCTL4_IRDA_SL_Msk (0xC0000000UL)
#define R_SYSC_SYS_SLVACCCTL4_IRDA_SL_Pos (30UL)
#define R_SYSC_SYS_SLVACCCTL5_SSIF_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL5_SSIF_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL5_SRC_SL_Msk (0x00000030UL)
#define R_SYSC_SYS_SLVACCCTL5_SRC_SL_Pos (4UL)
#define R_SYSC_SYS_SLVACCCTL6_ADC_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL6_ADC_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL6_TSU_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL6_TSU_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL7_OTP_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL7_OTP_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL8_CM33_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL8_CM33_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL8_CA55_SL_Msk (0x0000000CUL)
#define R_SYSC_SYS_SLVACCCTL8_CA55_SL_Pos (2UL)
#define R_SYSC_SYS_SLVACCCTL10_LSI_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL10_LSI_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL12_AOF_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL12_AOF_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL13_LP_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL13_LP_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL14_GPREG_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL14_GPREG_SL_Pos (0UL)
#define R_SYSC_SYS_SLVACCCTL16_IPCONT_SL_Msk (0x00000003UL)
#define R_SYSC_SYS_SLVACCCTL16_IPCONT_SL_Pos (0UL)
#define R_SYSC_SYS_RAM0_ECC_VECCEN_Msk (0x00000001UL)
#define R_SYSC_SYS_RAM0_ECC_VECCEN_Pos (0UL)
#define R_SYSC_SYS_RAM0_EN_VCEN_Msk (0x00000001UL)
#define R_SYSC_SYS_RAM0_EN_VCEN_Pos (0UL)
#define R_SYSC_SYS_RAM0_EN_VLWEN_Msk (0x00000002UL)
#define R_SYSC_SYS_RAM0_EN_VLWEN_Pos (1UL)
#define R_SYSC_SYS_RAM1_ECC_VECCEN_Msk (0x00000001UL)
#define R_SYSC_SYS_RAM1_ECC_VECCEN_Pos (0UL)
#define R_SYSC_SYS_RAM1_EN_VCEN_Msk (0x00000001UL)
#define R_SYSC_SYS_RAM1_EN_VCEN_Pos (0UL)
#define R_SYSC_SYS_RAM1_EN_VLWEN_Msk (0x00000002UL)
#define R_SYSC_SYS_RAM1_EN_VLWEN_Pos (1UL)
#define R_SYSC_SYS_WDT0_CTRL_WDTSTOP_Msk (0x00000001UL)
#define R_SYSC_SYS_WDT0_CTRL_WDTSTOP_Pos (0UL)
#define R_SYSC_SYS_WDT0_CTRL_WDTSTOPMASK_Msk (0x00010000UL)
#define R_SYSC_SYS_WDT0_CTRL_WDTSTOPMASK_Pos (16UL)
#define R_SYSC_SYS_WDT1_CTRL_WDTSTOP_Msk (0x00000001UL)
#define R_SYSC_SYS_WDT1_CTRL_WDTSTOP_Pos (0UL)
#define R_SYSC_SYS_WDT1_CTRL_WDTSTOPMASK_Msk (0x00010000UL)
#define R_SYSC_SYS_WDT1_CTRL_WDTSTOPMASK_Pos (16UL)
#define R_SYSC_SYS_WDT2_CTRL_WDTSTOP_Msk (0x00000001UL)
#define R_SYSC_SYS_WDT2_CTRL_WDTSTOP_Pos (0UL)
#define R_SYSC_SYS_WDT2_CTRL_WDTSTOPMASK_Msk (0x00010000UL)
#define R_SYSC_SYS_WDT2_CTRL_WDTSTOPMASK_Pos (16UL)
#define R_SYSC_SYS_GETH0_CFG_FEC_GIGA_ENABLE_Msk (0x01000000UL)
#define R_SYSC_SYS_GETH0_CFG_FEC_GIGA_ENABLE_Pos (24UL)
#define R_SYSC_SYS_GETH1_CFG_FEC_GIGA_ENABLE_Msk (0x01000000UL)
#define R_SYSC_SYS_GETH1_CFG_FEC_GIGA_ENABLE_Pos (24UL)
#define R_SYSC_SYS_I2C0_CFG_af_bypass_Msk (0x00000001UL)
#define R_SYSC_SYS_I2C0_CFG_af_bypass_Pos (0UL)
#define R_SYSC_SYS_I2C1_CFG_af_bypass_Msk (0x00000001UL)
#define R_SYSC_SYS_I2C1_CFG_af_bypass_Pos (0UL)
#define R_SYSC_SYS_I2C2_CFG_af_bypass_Msk (0x00000001UL)
#define R_SYSC_SYS_I2C2_CFG_af_bypass_Pos (0UL)
#define R_SYSC_SYS_I2C3_CFG_af_bypass_Msk (0x00000001UL)
#define R_SYSC_SYS_I2C3_CFG_af_bypass_Pos (0UL)
#define R_SYSC_SYS_CM33_CFG0_CONFIGSSYSTICK_Msk (0x03FFFFFFUL)
#define R_SYSC_SYS_CM33_CFG0_CONFIGSSYSTICK_Pos (0UL)
#define R_SYSC_SYS_CM33_CFG1_CONFIGNSSYSTICK_Msk (0x03FFFFFFUL)
#define R_SYSC_SYS_CM33_CFG1_CONFIGNSSYSTICK_Pos (0UL)
#define R_SYSC_SYS_CM33_CFG2_INITSVTOR_Msk (0xFFFFFF80UL)
#define R_SYSC_SYS_CM33_CFG2_INITSVTOR_Pos (7UL)
#define R_SYSC_SYS_CM33_CFG3_INITNSVTOR_Msk (0xFFFFFF80UL)
#define R_SYSC_SYS_CM33_CFG3_INITNSVTOR_Pos (7UL)
#define R_SYSC_SYS_CM33_LOCK_LOCKSVTAIRCR_Msk (0x00000001UL)
#define R_SYSC_SYS_CM33_LOCK_LOCKSVTAIRCR_Pos (0UL)
#define R_SYSC_SYS_CM33_LOCK_LOCKNSVTOR_Msk (0x00000002UL)
#define R_SYSC_SYS_CM33_LOCK_LOCKNSVTOR_Pos (1UL)
#define R_SYSC_SYS_CA55_CFG_RVAL0_RVBARADDRL0_Msk (0xFFFFFFFCUL)
#define R_SYSC_SYS_CA55_CFG_RVAL0_RVBARADDRL0_Pos (2UL)
#define R_SYSC_SYS_CA55_CFG_RVAH0_RVBARADDRH0_Msk (0x000000FFUL)
#define R_SYSC_SYS_CA55_CFG_RVAH0_RVBARADDRH0_Pos (0UL)
#define R_SYSC_SYS_CA55_CFG_RVAL1_RVBARADDRL1_Msk (0xFFFFFFFCUL)
#define R_SYSC_SYS_CA55_CFG_RVAL1_RVBARADDRL1_Pos (2UL)
#define R_SYSC_SYS_CA55_CFG_RVAH1_RVBARADDRH1_Msk (0x000000FFUL)
#define R_SYSC_SYS_CA55_CFG_RVAH1_RVBARADDRH1_Pos (0UL)
#define R_SYSC_SYS_LSI_MODE_STAT_MD_BOOT_Msk (0x00000007UL)
#define R_SYSC_SYS_LSI_MODE_STAT_MD_BOOT_Pos (0UL)
#define R_SYSC_SYS_LSI_MODE_STAT_DEBUGEN_Msk (0x00000200UL)
#define R_SYSC_SYS_LSI_MODE_STAT_DEBUGEN_Pos (9UL)
#define R_SYSC_SYS_LSI_MODE_STAT_MD_CLKS_Msk (0x00001000UL)
#define R_SYSC_SYS_LSI_MODE_STAT_MD_CLKS_Pos (12UL)
#define R_SYSC_SYS_LSI_MODE_STAT_MD_OSCDRV_Msk (0x0000C000UL)
#define R_SYSC_SYS_LSI_MODE_STAT_MD_OSCDRV_Pos (14UL)
#define R_SYSC_SYS_AOF0_OFS00_SXSDHI_0_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF0_OFS00_SXSDHI_0_Pos (0UL)
#define R_SYSC_SYS_AOF0_OFS01_SXSDHI_0_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF0_OFS01_SXSDHI_0_Pos (4UL)
#define R_SYSC_SYS_AOF0_OFS10_SXSDHI_0_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF0_OFS10_SXSDHI_0_Pos (8UL)
#define R_SYSC_SYS_AOF0_OFS11_SXSDHI_0_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF0_OFS11_SXSDHI_0_Pos (12UL)
#define R_SYSC_SYS_AOF0_OFS00_SXSDHI_1_Msk (0x000F0000UL)
#define R_SYSC_SYS_AOF0_OFS00_SXSDHI_1_Pos (16UL)
#define R_SYSC_SYS_AOF0_OFS01_SXSDHI_1_Msk (0x00F00000UL)
#define R_SYSC_SYS_AOF0_OFS01_SXSDHI_1_Pos (20UL)
#define R_SYSC_SYS_AOF0_OFS10_SXSDHI_1_Msk (0x0F000000UL)
#define R_SYSC_SYS_AOF0_OFS10_SXSDHI_1_Pos (24UL)
#define R_SYSC_SYS_AOF0_OFS11_SXSDHI_1_Msk (0xF0000000UL)
#define R_SYSC_SYS_AOF0_OFS11_SXSDHI_1_Pos (28UL)
#define R_SYSC_SYS_AOF1_OFS00_SXGIGE_0_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF1_OFS00_SXGIGE_0_Pos (0UL)
#define R_SYSC_SYS_AOF1_OFS01_SXGIGE_0_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF1_OFS01_SXGIGE_0_Pos (4UL)
#define R_SYSC_SYS_AOF1_OFS10_SXGIGE_0_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF1_OFS10_SXGIGE_0_Pos (8UL)
#define R_SYSC_SYS_AOF1_OFS11_SXGIGE_0_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF1_OFS11_SXGIGE_0_Pos (12UL)
#define R_SYSC_SYS_AOF1_OFS00_SXGIGE_1_Msk (0x000F0000UL)
#define R_SYSC_SYS_AOF1_OFS00_SXGIGE_1_Pos (16UL)
#define R_SYSC_SYS_AOF1_OFS01_SXGIGE_1_Msk (0x00F00000UL)
#define R_SYSC_SYS_AOF1_OFS01_SXGIGE_1_Pos (20UL)
#define R_SYSC_SYS_AOF1_OFS10_SXGIGE_1_Msk (0x0F000000UL)
#define R_SYSC_SYS_AOF1_OFS10_SXGIGE_1_Pos (24UL)
#define R_SYSC_SYS_AOF1_OFS11_SXGIGE_1_Msk (0xF0000000UL)
#define R_SYSC_SYS_AOF1_OFS11_SXGIGE_1_Pos (28UL)
#define R_SYSC_SYS_AOF2_OFS00_SXUSB2_0_H_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF2_OFS00_SXUSB2_0_H_Pos (0UL)
#define R_SYSC_SYS_AOF2_OFS01_SXUSB2_0_H_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF2_OFS01_SXUSB2_0_H_Pos (4UL)
#define R_SYSC_SYS_AOF2_OFS10_SXUSB2_0_H_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF2_OFS10_SXUSB2_0_H_Pos (8UL)
#define R_SYSC_SYS_AOF2_OFS11_SXUSB2_0_H_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF2_OFS11_SXUSB2_0_H_Pos (12UL)
#define R_SYSC_SYS_AOF2_OFS00_SXUSB2_1_Msk (0x000F0000UL)
#define R_SYSC_SYS_AOF2_OFS00_SXUSB2_1_Pos (16UL)
#define R_SYSC_SYS_AOF2_OFS01_SXUSB2_1_Msk (0x00F00000UL)
#define R_SYSC_SYS_AOF2_OFS01_SXUSB2_1_Pos (20UL)
#define R_SYSC_SYS_AOF2_OFS10_SXUSB2_1_Msk (0x0F000000UL)
#define R_SYSC_SYS_AOF2_OFS10_SXUSB2_1_Pos (24UL)
#define R_SYSC_SYS_AOF2_OFS11_SXUSB2_1_Msk (0xF0000000UL)
#define R_SYSC_SYS_AOF2_OFS11_SXUSB2_1_Pos (28UL)
#define R_SYSC_SYS_AOF3_OFS00_SXUSB2_0_F_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF3_OFS00_SXUSB2_0_F_Pos (0UL)
#define R_SYSC_SYS_AOF3_OFS01_SXUSB2_0_F_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF3_OFS01_SXUSB2_0_F_Pos (4UL)
#define R_SYSC_SYS_AOF3_OFS10_SXUSB2_0_F_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF3_OFS10_SXUSB2_0_F_Pos (8UL)
#define R_SYSC_SYS_AOF3_OFS11_SXUSB2_0_F_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF3_OFS11_SXUSB2_0_F_Pos (12UL)
#define R_SYSC_SYS_AOF4_OFS00_SXLCDC_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF4_OFS00_SXLCDC_Pos (0UL)
#define R_SYSC_SYS_AOF4_OFS01_SXLCDC_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF4_OFS01_SXLCDC_Pos (4UL)
#define R_SYSC_SYS_AOF4_OFS10_SXLCDC_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF4_OFS10_SXLCDC_Pos (8UL)
#define R_SYSC_SYS_AOF4_OFS11_SXLCDC_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF4_OFS11_SXLCDC_Pos (12UL)
#define R_SYSC_SYS_AOF4_OFS00_SXDSIL_Msk (0x000F0000UL)
#define R_SYSC_SYS_AOF4_OFS00_SXDSIL_Pos (16UL)
#define R_SYSC_SYS_AOF4_OFS01_SXDSIL_Msk (0x00F00000UL)
#define R_SYSC_SYS_AOF4_OFS01_SXDSIL_Pos (20UL)
#define R_SYSC_SYS_AOF4_OFS10_SXDSIL_Msk (0x0F000000UL)
#define R_SYSC_SYS_AOF4_OFS10_SXDSIL_Pos (24UL)
#define R_SYSC_SYS_AOF4_OFS11_SXDSIL_Msk (0xF0000000UL)
#define R_SYSC_SYS_AOF4_OFS11_SXDSIL_Pos (28UL)
#define R_SYSC_SYS_AOF5_OFS00_SXH264_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF5_OFS00_SXH264_Pos (0UL)
#define R_SYSC_SYS_AOF5_OFS01_SXH264_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF5_OFS01_SXH264_Pos (4UL)
#define R_SYSC_SYS_AOF5_OFS10_SXH264_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF5_OFS10_SXH264_Pos (8UL)
#define R_SYSC_SYS_AOF5_OFS11_SXH264_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF5_OFS11_SXH264_Pos (12UL)
#define R_SYSC_SYS_AOF6_OFS00_SXDMAC_S_Msk (0x0000000FUL)
#define R_SYSC_SYS_AOF6_OFS00_SXDMAC_S_Pos (0UL)
#define R_SYSC_SYS_AOF6_OFS01_SXDMAC_S_Msk (0x000000F0UL)
#define R_SYSC_SYS_AOF6_OFS01_SXDMAC_S_Pos (4UL)
#define R_SYSC_SYS_AOF6_OFS10_SXDMAC_S_Msk (0x00000F00UL)
#define R_SYSC_SYS_AOF6_OFS10_SXDMAC_S_Pos (8UL)
#define R_SYSC_SYS_AOF6_OFS11_SXDMAC_S_Msk (0x0000F000UL)
#define R_SYSC_SYS_AOF6_OFS11_SXDMAC_S_Pos (12UL)
#define R_SYSC_SYS_AOF6_OFS00_SXDMAC_NS_Msk (0x000F0000UL)
#define R_SYSC_SYS_AOF6_OFS00_SXDMAC_NS_Pos (16UL)
#define R_SYSC_SYS_AOF6_OFS01_SXDMAC_NS_Msk (0x00F00000UL)
#define R_SYSC_SYS_AOF6_OFS01_SXDMAC_NS_Pos (20UL)
#define R_SYSC_SYS_AOF6_OFS10_SXDMAC_NS_Msk (0x0F000000UL)
#define R_SYSC_SYS_AOF6_OFS10_SXDMAC_NS_Pos (24UL)
#define R_SYSC_SYS_AOF6_OFS11_SXDMAC_NS_Msk (0xF0000000UL)
#define R_SYSC_SYS_AOF6_OFS11_SXDMAC_NS_Pos (28UL)
#define R_SYSC_SYS_LP_CTL0_MAIN_CPU_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL0_MAIN_CPU_Pos (0UL)
#define R_SYSC_SYS_LP_CTL1_STBY_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL1_STBY_Pos (0UL)
#define R_SYSC_SYS_LP_CTL1_CA55SLEEP_REQ_Msk (0x00000300UL)
#define R_SYSC_SYS_LP_CTL1_CA55SLEEP_REQ_Pos (8UL)
#define R_SYSC_SYS_LP_CTL1_CM33SLEEP_REQ_Msk (0x00001000UL)
#define R_SYSC_SYS_LP_CTL1_CM33SLEEP_REQ_Pos (12UL)
#define R_SYSC_SYS_LP_CTL1_STBY_CA55ST_Msk (0x00010000UL)
#define R_SYSC_SYS_LP_CTL1_STBY_CA55ST_Pos (16UL)
#define R_SYSC_SYS_LP_CTL1_STBY_CM33ST_Msk (0x00020000UL)
#define R_SYSC_SYS_LP_CTL1_STBY_CM33ST_Pos (17UL)
#define R_SYSC_SYS_LP_CTL1_CA55SLEEP_ACK_Msk (0x03000000UL)
#define R_SYSC_SYS_LP_CTL1_CA55SLEEP_ACK_Pos (24UL)
#define R_SYSC_SYS_LP_CTL1_CM33SLEEP_ACK_Msk (0x10000000UL)
#define R_SYSC_SYS_LP_CTL1_CM33SLEEP_ACK_Pos (28UL)
#define R_SYSC_SYS_LP_CTL2_CA55_STBYCTL_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL2_CA55_STBYCTL_Pos (0UL)
#define R_SYSC_SYS_LP_CTL3_U0DP_F_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL3_U0DP_F_Pos (0UL)
#define R_SYSC_SYS_LP_CTL3_U0DM_F_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CTL3_U0DM_F_Pos (1UL)
#define R_SYSC_SYS_LP_CTL3_U0VBUSIN_F_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CTL3_U0VBUSIN_F_Pos (2UL)
#define R_SYSC_SYS_LP_CTL3_U0OVRCLR_F_Msk (0x00000008UL)
#define R_SYSC_SYS_LP_CTL3_U0OVRCLR_F_Pos (3UL)
#define R_SYSC_SYS_LP_CTL3_U1DP_F_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CTL3_U1DP_F_Pos (8UL)
#define R_SYSC_SYS_LP_CTL3_U1DM_F_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CTL3_U1DM_F_Pos (9UL)
#define R_SYSC_SYS_LP_CTL3_U1OVRCLR_F_Msk (0x00000800UL)
#define R_SYSC_SYS_LP_CTL3_U1OVRCLR_F_Pos (11UL)
#define R_SYSC_SYS_LP_CTL3_IRQ_F70_Msk (0x00FF0000UL)
#define R_SYSC_SYS_LP_CTL3_IRQ_F70_Pos (16UL)
#define R_SYSC_SYS_LP_CTL3_NMI_F_Msk (0x01000000UL)
#define R_SYSC_SYS_LP_CTL3_NMI_F_Pos (24UL)
#define R_SYSC_SYS_LP_CTL4_U0DP_E_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL4_U0DP_E_Pos (0UL)
#define R_SYSC_SYS_LP_CTL4_U0DM_E_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CTL4_U0DM_E_Pos (1UL)
#define R_SYSC_SYS_LP_CTL4_U0VBUSIN_E_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CTL4_U0VBUSIN_E_Pos (2UL)
#define R_SYSC_SYS_LP_CTL4_U0OVRCLR_E_Msk (0x00000008UL)
#define R_SYSC_SYS_LP_CTL4_U0OVRCLR_E_Pos (3UL)
#define R_SYSC_SYS_LP_CTL4_U1DP_E_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CTL4_U1DP_E_Pos (8UL)
#define R_SYSC_SYS_LP_CTL4_U1DM_E_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CTL4_U1DM_E_Pos (9UL)
#define R_SYSC_SYS_LP_CTL4_U1OVRCLR_E_Msk (0x00000800UL)
#define R_SYSC_SYS_LP_CTL4_U1OVRCLR_E_Pos (11UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E0_Msk (0x00010000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E0_Pos (16UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E1_Msk (0x00020000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E1_Pos (17UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E2_Msk (0x00040000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E2_Pos (18UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E3_Msk (0x00080000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E3_Pos (19UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E4_Msk (0x00100000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E4_Pos (20UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E5_Msk (0x00200000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E5_Pos (21UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E6_Msk (0x00400000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E6_Pos (22UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E7_Msk (0x00800000UL)
#define R_SYSC_SYS_LP_CTL4_IRQ_E7_Pos (23UL)
#define R_SYSC_SYS_LP_CTL4_NMI_E_Msk (0x01000000UL)
#define R_SYSC_SYS_LP_CTL4_NMI_E_Pos (24UL)
#define R_SYSC_SYS_LP_CTL5_ASCLKQDENY_F_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CTL5_ASCLKQDENY_F_Pos (1UL)
#define R_SYSC_SYS_LP_CTL5_AMCLKQDENY_F_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CTL5_AMCLKQDENY_F_Pos (2UL)
#define R_SYSC_SYS_LP_CTL5_STBY_F_Msk (0x00000010UL)
#define R_SYSC_SYS_LP_CTL5_STBY_F_Pos (4UL)
#define R_SYSC_SYS_LP_CTL5_CA55SLEEP0_F_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CTL5_CA55SLEEP0_F_Pos (8UL)
#define R_SYSC_SYS_LP_CTL5_CA55SLEEP1_F_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CTL5_CA55SLEEP1_F_Pos (9UL)
#define R_SYSC_SYS_LP_CTL5_CM33SLEEP_F_Msk (0x00000400UL)
#define R_SYSC_SYS_LP_CTL5_CM33SLEEP_F_Pos (10UL)
#define R_SYSC_SYS_LP_CTL5_CA55STBYDONE_F_Msk (0x00010000UL)
#define R_SYSC_SYS_LP_CTL5_CA55STBYDONE_F_Pos (16UL)
#define R_SYSC_SYS_LP_CTL5_CM33STBYR_F_Msk (0x00100000UL)
#define R_SYSC_SYS_LP_CTL5_CM33STBYR_F_Pos (20UL)
#define R_SYSC_SYS_LP_CTL6_ASCLKQDENY_E_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CTL6_ASCLKQDENY_E_Pos (1UL)
#define R_SYSC_SYS_LP_CTL6_AMCLKQDENY_E_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CTL6_AMCLKQDENY_E_Pos (2UL)
#define R_SYSC_SYS_LP_CTL6_STBY_E_Msk (0x00000010UL)
#define R_SYSC_SYS_LP_CTL6_STBY_E_Pos (4UL)
#define R_SYSC_SYS_LP_CTL6_CA55STBYDONE_E_Msk (0x00000020UL)
#define R_SYSC_SYS_LP_CTL6_CA55STBYDONE_E_Pos (5UL)
#define R_SYSC_SYS_LP_CTL6_CM33STBYR_E_Msk (0x00000040UL)
#define R_SYSC_SYS_LP_CTL6_CM33STBYR_E_Pos (6UL)
#define R_SYSC_SYS_LP_CTL6_CA55SLEEP0_E_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CTL6_CA55SLEEP0_E_Pos (8UL)
#define R_SYSC_SYS_LP_CTL6_CA55SLEEP1_E_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CTL6_CA55SLEEP1_E_Pos (9UL)
#define R_SYSC_SYS_LP_CTL6_CM33SLEEP_E_Msk (0x00000400UL)
#define R_SYSC_SYS_LP_CTL6_CM33SLEEP_E_Pos (10UL)
#define R_SYSC_SYS_LP_CTL7_IM33_MASK_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL7_IM33_MASK_Pos (0UL)
#define R_SYSC_SYS_LP_CTL8_SUBCPU_RTRIG_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CTL8_SUBCPU_RTRIG_Pos (0UL)
#define R_SYSC_SYS_LP_CM33CTL0_SLEEPMODE_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CM33CTL0_SLEEPMODE_Pos (0UL)
#define R_SYSC_SYS_LP_CM33CTL0_SLEEPDEEP_Msk (0x00000010UL)
#define R_SYSC_SYS_LP_CM33CTL0_SLEEPDEEP_Pos (4UL)
#define R_SYSC_SYS_LP_CM33CTL0_SYSRESETREQ_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CM33CTL0_SYSRESETREQ_Pos (9UL)
#define R_SYSC_SYS_LP_CM33CTL0_WICENABLEREQ_Msk (0x01000000UL)
#define R_SYSC_SYS_LP_CM33CTL0_WICENABLEREQ_Pos (24UL)
#define R_SYSC_SYS_LP_CM33CTL0_WICENABLEACK_Msk (0x02000000UL)
#define R_SYSC_SYS_LP_CM33CTL0_WICENABLEACK_Pos (25UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_ASCLKQACTIVE_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_ASCLKQACTIVE_Pos (1UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_AMCLKQACTIVE_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_AMCLKQACTIVE_Pos (2UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_PCLKQACTIVE_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_PCLKQACTIVE_Pos (8UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_ATCLKQACTIVE_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_ATCLKQACTIVE_Pos (9UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_GICCLKQACTIVE_Msk (0x00000400UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_GICCLKQACTIVE_Pos (10UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_PDBGCLKQACTIVE_Msk (0x00000800UL)
#define R_SYSC_SYS_LP_CA55CK_CTL1_PDBGCLKQACTIVE_Pos (11UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_ASCLKQREQn_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_ASCLKQREQn_Pos (1UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_AMCLKQREQn_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_AMCLKQREQn_Pos (2UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_PCLKQREQn_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_PCLKQREQn_Pos (8UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_ATCLKQREQn_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_ATCLKQREQn_Pos (9UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_GICCLKQREQn_Msk (0x00000400UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_GICCLKQREQn_Pos (10UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_PDBGCLKQREQn_Msk (0x00000800UL)
#define R_SYSC_SYS_LP_CA55CK_CTL2_PDBGCLKQREQn_Pos (11UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_CA55_COREINSTRRUN0_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_CA55_COREINSTRRUN0_Pos (0UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ASCLKQACCEPTn_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ASCLKQACCEPTn_Pos (1UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_AMCLKQACCEPTn_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_AMCLKQACCEPTn_Pos (2UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PCLKQACCEPTn_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PCLKQACCEPTn_Pos (8UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ATCLKQACCEPTn_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ATCLKQACCEPTn_Pos (9UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_GICCLKQACCEPTn_Msk (0x00000400UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_GICCLKQACCEPTn_Pos (10UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PDBGCLKQACCEPTn_Msk (0x00000800UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PDBGCLKQACCEPTn_Pos (11UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_CA55_COREINSTRRUN1_Msk (0x00010000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_CA55_COREINSTRRUN1_Pos (16UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ASCLKQDENY_Msk (0x00020000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ASCLKQDENY_Pos (17UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_AMCLKQDENY_Msk (0x00040000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_AMCLKQDENY_Pos (18UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PCLKQDENY_Msk (0x01000000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PCLKQDENY_Pos (24UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ATCLKQDENY_Msk (0x02000000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_ATCLKQDENY_Pos (25UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_GICCLKQDENY_Msk (0x04000000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_GICCLKQDENY_Pos (26UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PDBGCLKQDENY_Msk (0x08000000UL)
#define R_SYSC_SYS_LP_CA55CK_CTL3_PDBGCLKQDENY_Pos (27UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_GPU_Msk (0x00000001UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_GPU_Pos (0UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_AXI_SLV_Msk (0x00000002UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_AXI_SLV_Pos (1UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_AXI_MST_Msk (0x00000004UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_AXI_MST_Pos (2UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_ACE_SLV_Msk (0x00000008UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_ACE_SLV_Pos (3UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_ACE_MST_Msk (0x00000010UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACTIVE_ACE_MST_Pos (4UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_GPU_Msk (0x00000100UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_GPU_Pos (8UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_AXI_SLV_Msk (0x00000200UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_AXI_SLV_Pos (9UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_AXI_MST_Msk (0x00000400UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_AXI_MST_Pos (10UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_ACE_SLV_Msk (0x00000800UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_ACE_SLV_Pos (11UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_ACE_MST_Msk (0x00001000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QREQn_ACE_MST_Pos (12UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_GPU_Msk (0x00010000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_GPU_Pos (16UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_AXI_SLV_Msk (0x00020000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_AXI_SLV_Pos (17UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_AXI_MST_Msk (0x00040000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_AXI_MST_Pos (18UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_ACE_SLV_Msk (0x00080000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_ACE_SLV_Pos (19UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_ACE_MST_Msk (0x00100000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QACCEPTn_ACE_MST_Pos (20UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_GPU_Msk (0x01000000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_GPU_Pos (24UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_AXI_SLV_Msk (0x02000000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_AXI_SLV_Pos (25UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_AXI_MST_Msk (0x04000000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_AXI_MST_Pos (26UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_ACE_SLV_Msk (0x08000000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_ACE_SLV_Pos (27UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_ACE_MST_Msk (0x10000000UL)
#define R_SYSC_SYS_LP_GPU_CTL_QDENY_ACE_MST_Pos (28UL)
#define R_SYSC_SYS_GPREG_0_GPREG0_Msk (0xFFFFFFFFUL)
#define R_SYSC_SYS_GPREG_0_GPREG0_Pos (0UL)
#define R_SYSC_SYS_GPREG_1_GPREG1_Msk (0xFFFFFFFFUL)
#define R_SYSC_SYS_GPREG_1_GPREG1_Pos (0UL)
#define R_SYSC_SYS_GPREG_2_GPREG2_Msk (0xFFFFFFFFUL)
#define R_SYSC_SYS_GPREG_2_GPREG2_Pos (0UL)
#define R_SYSC_SYS_GPREG_3_GPREG3_Msk (0xFFFFFFFFUL)
#define R_SYSC_SYS_GPREG_3_GPREG3_Pos (0UL)
#endif

View File

@ -0,0 +1,30 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : tsu_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for tsu.
*********************************************************************************************************************/
#ifndef TSU_IOBITMASK_H
#define TSU_IOBITMASK_H
#endif /* TSU_IOBITMASK_H */

View File

@ -0,0 +1,49 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : wdt_iobitmask.h
* Version : 1.00
* Description : IO bit mask file for wdt.
*********************************************************************************************************************/
#ifndef WDT_IOBITMASK_H
#define WDT_IOBITMASK_H
#define R_WDT0_WDTCNT_WDTEN_Msk (0x00000001UL)
#define R_WDT0_WDTCNT_WDTEN_Pos (0UL)
#define R_WDT0_WDTSET_WDTTIME_Msk (0xFFF00000UL)
#define R_WDT0_WDTSET_WDTTIME_Pos (20UL)
#define R_WDT0_WDTTIM_CRTTIME_Msk (0xFFFFFFFFUL)
#define R_WDT0_WDTTIM_CRTTIME_Pos (0UL)
#define R_WDT0_WDTINT_INTDISP_Msk (0x00000001UL)
#define R_WDT0_WDTINT_INTDISP_Pos (0UL)
#define R_WDT0_PECR_PECR_Msk (0xFFFFFFFFUL)
#define R_WDT0_PECR_PECR_Pos (0UL)
#define R_WDT0_PEEN_PEEN_Msk (0x00000001UL)
#define R_WDT0_PEEN_PEEN_Pos (0UL)
#define R_WDT0_PESR_PESR_Msk (0xFFFFFFFFUL)
#define R_WDT0_PESR_PESR_Pos (0UL)
#define R_WDT0_PEER_PEER_Msk (0xFFFFFFFFUL)
#define R_WDT0_PEER_PEER_Pos (0UL)
#define R_WDT0_PEPO_PEPO_Msk (0xFFFFFFFFUL)
#define R_WDT0_PEPO_PEPO_Pos (0UL)
#endif /* WDT_IOBITMASK_H */

View File

@ -0,0 +1,54 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : iodefine.h
* Version : 1.00
* Description : iodefine header
*********************************************************************************************************************/
#ifndef __IODEFINE_HEADER__
#define __IODEFINE_HEADER__
#include "iodefines/adc_c_iodefine.h"
#include "iodefines/canfd_iodefine.h"
#include "iodefines/cpg_iodefine.h"
#include "iodefines/dmac_b_iodefine.h"
#include "iodefines/gpio_iodefine.h"
#include "iodefines/gpt_iodefine.h"
#include "iodefines/gtm_iodefine.h"
#include "iodefines/intc_im33_iodefine.h"
#include "iodefines/mhu_iodefine.h"
#include "iodefines/poeg_iodefine.h"
#include "iodefines/riic_iodefine.h"
#include "iodefines/rspi_iodefine.h"
#include "iodefines/scifa_iodefine.h"
#include "iodefines/spibsc_iodefine.h"
#include "iodefines/ssi_iodefine.h"
#include "iodefines/sysc_iodefine.h"
#include "iodefines/tsu_iodefine.h"
#include "iodefines/wdt_iodefine.h"
#include "iodefines/mtu_iodefine.h"
#ifdef BSP_OVERRIDE_REG_HEADER_IOPORT
#include BSP_OVERRIDE_REG_HEADER_IOPORT
#endif
#endif /* __IODEFINE_HEADER__ */

View File

@ -0,0 +1,309 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : adc_c_iodefine.h
* Version : 1.00
* Description : IO define file for adc_c.
*********************************************************************************************************************/
/* =========================================================================================================================== */
/* ================ Device Specific Cluster Section ================ */
/* =========================================================================================================================== */
/* =========================================================================================================================== */
/* ================ Device Specific Peripheral Section ================ */
/* =========================================================================================================================== */
#ifndef ADC_C_IODEFINE_H
#define ADC_C_IODEFINE_H
typedef struct
{
union
{
__IOM uint32_t ADM0;
struct
{
__IOM uint32_t ADCE : 1;
__IM uint32_t ADBSY : 1;
__IOM uint32_t PWDWNB : 1;
uint32_t : 12;
__IOM uint32_t SRESB : 1;
uint32_t : 16;
} ADM0_b;
};
union
{
__IOM uint32_t ADM1;
struct
{
__IOM uint32_t TRG : 1;
__IOM uint32_t TRGIN : 1;
__IOM uint32_t MS : 1;
__IOM uint32_t RPS : 1;
__IOM uint32_t BS : 1;
uint32_t : 7;
__IOM uint32_t EGA : 2;
uint32_t : 2;
__IM uint32_t TRGEN : 6;
uint32_t : 10;
} ADM1_b;
};
union
{
__IOM uint32_t ADM2;
struct
{
__IOM uint32_t CHSEL : 9;
uint32_t : 23;
} ADM2_b;
};
union
{
__IOM uint32_t ADM3;
struct
{
__IOM uint32_t ADSMP : 8;
uint32_t : 8;
__IOM uint32_t ADCMP : 8;
__IOM uint32_t ADIL : 8;
} ADM3_b;
};
__IM uint8_t RESERVED[16];
union
{
__IOM uint32_t ADINT;
struct
{
__IOM uint32_t INTEN : 12;
uint32_t : 4;
__IOM uint32_t CSEEN : 1;
uint32_t : 14;
__IM uint32_t INTS : 1;
} ADINT_b;
};
union
{
__IOM uint32_t ADSTS;
struct
{
__IOM uint32_t INTST : 9;
uint32_t : 7;
__IOM uint32_t CSEST : 1;
uint32_t : 14;
__IOM uint32_t TRGS : 1;
} ADSTS_b;
};
union
{
__IOM uint32_t ADIVC;
struct
{
__IOM uint32_t DIVADC : 9;
uint32_t : 23;
} ADIVC_b;
};
union
{
__IOM uint32_t ADFIL;
struct
{
__IOM uint32_t FILONOFF : 1;
uint32_t : 3;
__IOM uint32_t FILNUM : 2;
uint32_t : 26;
} ADFIL_b;
};
union
{
__IM uint32_t ADCR0;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR0_b;
};
union
{
__IM uint32_t ADCR1;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR1_b;
};
union
{
__IM uint32_t ADCR2;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR2_b;
};
union
{
__IM uint32_t ADCR3;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR3_b;
};
union
{
__IM uint32_t ADCR4;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR4_b;
};
union
{
__IM uint32_t ADCR5;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR5_b;
};
union
{
__IM uint32_t ADCR6;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR6_b;
};
union
{
__IM uint32_t ADCR7;
struct
{
__IM uint32_t AD0 : 1;
__IM uint32_t AD1 : 1;
__IM uint32_t AD2 : 1;
__IM uint32_t AD3 : 1;
__IM uint32_t AD4 : 1;
__IM uint32_t AD5 : 1;
__IM uint32_t AD6 : 1;
__IM uint32_t AD7 : 1;
__IM uint32_t AD8 : 1;
__IM uint32_t AD9 : 1;
__IM uint32_t AD10 : 1;
__IM uint32_t AD11 : 1;
uint32_t : 20;
} ADCR7_b;
};
} R_ADC_C_Type;
/* =========================================================================================================================== */
/* ================ Device Specific Peripheral Address Map ================ */
/* =========================================================================================================================== */
#define R_ADC_C_BASE 0x40059000
/* =========================================================================================================================== */
/* ================ Peripheral declaration ================ */
/* =========================================================================================================================== */
#define R_ADC_C ((R_ADC_C_Type *) R_ADC_C_BASE)
#endif

View File

@ -0,0 +1,295 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : dmac_b_iodefine.h
* Version : 1.00
* Description : IO define file for dmac.
*********************************************************************************************************************/
/* =========================================================================================================================== */
/* ================ Device Specific Cluster Section ================ */
/* =========================================================================================================================== */
/* =========================================================================================================================== */
/* ================ Device Specific Peripheral Section ================ */
/* =========================================================================================================================== */
#ifndef DMAC_B_IODEFINE_H
#define DMAC_B_IODEFINE_H
typedef struct
{
__IOM uint32_t SA;
__IOM uint32_t DA;
__IOM uint32_t TB;
} R_DMAC_B0_GRP_CH_N_Type;
typedef struct
{
__IOM R_DMAC_B0_GRP_CH_N_Type N[2];
__IM uint32_t CRSA;
__IM uint32_t CRDA;
__IM uint32_t CRTB;
union
{
__IM uint32_t CHSTAT;
struct
{
__IM uint32_t EN : 1;
__IM uint32_t RQST : 1;
__IM uint32_t TACT : 1;
__IM uint32_t SUS : 1;
__IM uint32_t ER : 1;
__IM uint32_t END : 1;
__IM uint32_t TC : 1;
__IM uint32_t SR : 1;
__IM uint32_t DL : 1;
__IM uint32_t DW : 1;
__IM uint32_t DER : 1;
__IM uint32_t MODE : 1;
uint32_t : 4;
__IM uint32_t INTMSK : 1;
uint32_t : 15;
} CHSTAT_b;
};
union
{
__IOM uint32_t CHCTRL;
struct
{
__IOM uint32_t SETEN : 1;
__IOM uint32_t CLREN : 1;
__IOM uint32_t STG : 1;
__IOM uint32_t SWRST : 1;
__IOM uint32_t CLRRQ : 1;
__IOM uint32_t CLREND : 1;
__IOM uint32_t CLRTC : 1;
uint32_t : 1;
__IOM uint32_t SETSUS : 1;
__IOM uint32_t CLRSUS : 1;
uint32_t : 6;
__IOM uint32_t SETINTMSK : 1;
__IOM uint32_t CLRINTMSK : 1;
uint32_t : 14;
} CHCTRL_b;
};
union
{
__IOM uint32_t CHCFG;
struct
{
__IOM uint32_t SEL : 3;
__IOM uint32_t REQD : 1;
__IOM uint32_t LOEN : 1;
__IOM uint32_t HIEN : 1;
__IOM uint32_t LVL : 1;
uint32_t : 1;
__IOM uint32_t AM : 3;
uint32_t : 1;
__IOM uint32_t SDS : 4;
__IOM uint32_t DDS : 4;
__IOM uint32_t SAD : 1;
__IOM uint32_t DAD : 1;
__IOM uint32_t TM : 1;
uint32_t : 1;
__IOM uint32_t DEM : 1;
__IOM uint32_t TCM : 1;
uint32_t : 1;
__IOM uint32_t SBE : 1;
__IOM uint32_t RSEL : 1;
__IOM uint32_t RSW : 1;
__IOM uint32_t REN : 1;
__IOM uint32_t DMS : 1;
} CHCFG_b;
};
union
{
__IOM uint32_t CHITVL;
struct
{
__IOM uint32_t ITVL : 16;
uint32_t : 16;
} CHITVL_b;
};
union
{
__IOM uint32_t CHEXT;
struct
{
__IOM uint32_t SPR : 3;
uint32_t : 1;
__IOM uint32_t SCA : 4;
__IOM uint32_t DPR : 3;
uint32_t : 1;
__IOM uint32_t DCA : 4;
uint32_t : 16;
} CHEXT_b;
};
__IOM uint32_t NXLA;
__IM uint32_t CRLA;
} R_DMAC_B0_GRP_CH_Type;
typedef struct
{
__IOM R_DMAC_B0_GRP_CH_Type CH[8];
__IM uint32_t RESERVED[64];
union
{
__IOM uint32_t DCTRL;
struct
{
__IOM uint32_t PR : 1;
__IOM uint32_t LVINT : 1;
uint32_t : 14;
__IOM uint32_t LDPR : 3;
uint32_t : 1;
__IOM uint32_t LDCA : 4;
__IOM uint32_t LWPR : 3;
uint32_t : 1;
__IOM uint32_t LWCA : 4;
} DCTRL_b;
};
__IM uint32_t RESERVED1[3];
union
{
__IM uint32_t DSTAT_EN;
struct
{
__IM uint32_t EN0 : 1;
__IM uint32_t EN1 : 1;
__IM uint32_t EN2 : 1;
__IM uint32_t EN3 : 1;
__IM uint32_t EN4 : 1;
__IM uint32_t EN5 : 1;
__IM uint32_t EN6 : 1;
__IM uint32_t EN7 : 1;
uint32_t : 24;
} DSTAT_EN_b;
};
union
{
__IM uint32_t DSTAT_ER;
struct
{
__IM uint32_t ER0 : 1;
__IM uint32_t ER1 : 1;
__IM uint32_t ER2 : 1;
__IM uint32_t ER3 : 1;
__IM uint32_t ER4 : 1;
__IM uint32_t ER5 : 1;
__IM uint32_t ER6 : 1;
__IM uint32_t ER7 : 1;
uint32_t : 24;
} DSTAT_ER_b;
};
union
{
__IM uint32_t DSTAT_END;
struct
{
__IM uint32_t END0 : 1;
__IM uint32_t END1 : 1;
__IM uint32_t END2 : 1;
__IM uint32_t END3 : 1;
__IM uint32_t END4 : 1;
__IM uint32_t END5 : 1;
__IM uint32_t END6 : 1;
__IM uint32_t END7 : 1;
uint32_t : 24;
} DSTAT_END_b;
};
union
{
__IM uint32_t DST_TC;
struct
{
__IM uint32_t TC0 : 1;
__IM uint32_t TC1 : 1;
__IM uint32_t TC2 : 1;
__IM uint32_t TC3 : 1;
__IM uint32_t TC4 : 1;
__IM uint32_t TC5 : 1;
__IM uint32_t TC6 : 1;
__IM uint32_t TC7 : 1;
uint32_t : 24;
} DST_TC_b;
};
union
{
__IM uint32_t DSTAT_SUS;
struct
{
__IM uint32_t SUS0 : 1;
__IM uint32_t SUS1 : 1;
__IM uint32_t SUS2 : 1;
__IM uint32_t SUS3 : 1;
__IM uint32_t SUS4 : 1;
__IM uint32_t SUS5 : 1;
__IM uint32_t SUS6 : 1;
__IM uint32_t SUS7 : 1;
uint32_t : 24;
} DSTAT_SUS_b;
};
__IM uint32_t RESERVED3[55];
} R_DMAC_B0_GRP_Type;
typedef struct
{
__IOM R_DMAC_B0_GRP_Type GRP[2];
} R_DMAC_B0_Type;
/* =========================================================================================================================== */
/* ================ Device Specific Peripheral Address Map ================ */
/* =========================================================================================================================== */
#define R_DMAC_B0_BASE 0x41800000
#define R_DMAC_B1_BASE 0x41820000
/* =========================================================================================================================== */
/* ================ Peripheral declaration ================ */
/* =========================================================================================================================== */
#define R_DMAC_B0 ((R_DMAC_B0_Type *) R_DMAC_B0_BASE)
#define R_DMAC_B1 ((R_DMAC_B0_Type *) R_DMAC_B1_BASE)
#endif

View File

@ -0,0 +1,681 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : gpt_iodefine.h
* Version : 1.00
* Description : IO define file for gpt.
*********************************************************************************************************************/
/* ================================================================================================================= */
/* ================ Device Specific Cluster Section ====== */
/* ================================================================================================================= */
/* ================================================================================================================= */
/* ================ Device Specific Peripheral Section ====== */
/* ================================================================================================================= */
#ifndef GPT_IODEFINE_H
#define GPT_IODEFINE_H
typedef struct
{
union
{
__IOM uint32_t GTWP;
struct
{
__IOM uint32_t WP : 1;
uint32_t : 7;
__IOM uint32_t PRKEY : 8;
uint32_t : 16;
} GTWP_b;
};
union
{
__IOM uint32_t GTSTR;
struct
{
__IOM uint32_t CSTRT0 : 1;
__IOM uint32_t CSTRT1 : 1;
__IOM uint32_t CSTRT2 : 1;
__IOM uint32_t CSTRT3 : 1;
__IOM uint32_t CSTRT4 : 1;
__IOM uint32_t CSTRT5 : 1;
__IOM uint32_t CSTRT6 : 1;
__IOM uint32_t CSTRT7 : 1;
uint32_t : 24;
} GTSTR_b;
};
union
{
__IOM uint32_t GTSTP;
struct
{
__IOM uint32_t CSTOP0 : 1;
__IOM uint32_t CSTOP1 : 1;
__IOM uint32_t CSTOP2 : 1;
__IOM uint32_t CSTOP3 : 1;
__IOM uint32_t CSTOP4 : 1;
__IOM uint32_t CSTOP5 : 1;
__IOM uint32_t CSTOP6 : 1;
__IOM uint32_t CSTOP7 : 1;
uint32_t : 24;
} GTSTP_b;
};
union
{
__IOM uint32_t GTCLR;
struct
{
__IOM uint32_t CCLR0 : 1;
__IOM uint32_t CCLR1 : 1;
__IOM uint32_t CCLR2 : 1;
__IOM uint32_t CCLR3 : 1;
__IOM uint32_t CCLR4 : 1;
__IOM uint32_t CCLR5 : 1;
__IOM uint32_t CCLR6 : 1;
__IOM uint32_t CCLR7 : 1;
uint32_t : 24;
} GTCLR_b;
};
union
{
__IOM uint32_t GTSSR;
struct
{
__IOM uint32_t SSGTRGAR : 1;
__IOM uint32_t SSGTRGAF : 1;
__IOM uint32_t SSGTRGBR : 1;
__IOM uint32_t SSGTRGBF : 1;
__IOM uint32_t SSGTRGCR : 1;
__IOM uint32_t SSGTRGCF : 1;
__IOM uint32_t SSGTRGDR : 1;
__IOM uint32_t SSGTRGDF : 1;
__IOM uint32_t SSCARBL : 1;
__IOM uint32_t SSCARBH : 1;
__IOM uint32_t SSCAFBL : 1;
__IOM uint32_t SSCAFBH : 1;
__IOM uint32_t SSCBRAL : 1;
__IOM uint32_t SSCBRAH : 1;
__IOM uint32_t SSCBFAL : 1;
__IOM uint32_t SSCBFAH : 1;
uint32_t : 15;
__IOM uint32_t CSTRT : 1;
} GTSSR_b;
};
union
{
__IOM uint32_t GTPSR;
struct
{
__IOM uint32_t PSGTRGAR : 1;
__IOM uint32_t PSGTRGAF : 1;
__IOM uint32_t PSGTRGBR : 1;
__IOM uint32_t PSGTRGBF : 1;
__IOM uint32_t PSGTRGCR : 1;
__IOM uint32_t PSGTRGCF : 1;
__IOM uint32_t PSGTRGDR : 1;
__IOM uint32_t PSGTRGDF : 1;
__IOM uint32_t PSCARBL : 1;
__IOM uint32_t PSCARBH : 1;
__IOM uint32_t PSCAFBL : 1;
__IOM uint32_t PSCAFBH : 1;
__IOM uint32_t PSCBRAL : 1;
__IOM uint32_t PSCBRAH : 1;
__IOM uint32_t PSCBFAL : 1;
__IOM uint32_t PSCBFAH : 1;
uint32_t : 15;
__IOM uint32_t CSTOP : 1;
} GTPSR_b;
};
union
{
__IOM uint32_t GTCSR;
struct
{
__IOM uint32_t CSGTRGAR : 1;
__IOM uint32_t CSGTRGAF : 1;
__IOM uint32_t CSGTRGBR : 1;
__IOM uint32_t CSGTRGBF : 1;
__IOM uint32_t CSGTRGCR : 1;
__IOM uint32_t CSGTRGCF : 1;
__IOM uint32_t CSGTRGDR : 1;
__IOM uint32_t CSGTRGDF : 1;
__IOM uint32_t CSCARBL : 1;
__IOM uint32_t CSCARBH : 1;
__IOM uint32_t CSCAFBL : 1;
__IOM uint32_t CSCAFBH : 1;
__IOM uint32_t CSCBRAL : 1;
__IOM uint32_t CSCBRAH : 1;
__IOM uint32_t CSCBFAL : 1;
__IOM uint32_t CSCBFAH : 1;
uint32_t : 15;
__IOM uint32_t CCLR : 1;
} GTCSR_b;
};
union
{
__IOM uint32_t GTUPSR;
struct
{
__IOM uint32_t USGTRGAR : 1;
__IOM uint32_t USGTRGAF : 1;
__IOM uint32_t USGTRGBR : 1;
__IOM uint32_t USGTRGBF : 1;
__IOM uint32_t USGTRGCR : 1;
__IOM uint32_t USGTRGCF : 1;
__IOM uint32_t USGTRGDR : 1;
__IOM uint32_t USGTRGDF : 1;
__IOM uint32_t USCARBL : 1;
__IOM uint32_t USCARBH : 1;
__IOM uint32_t USCAFBL : 1;
__IOM uint32_t USCAFBH : 1;
__IOM uint32_t USCBRAL : 1;
__IOM uint32_t USCBRAH : 1;
__IOM uint32_t USCBFAL : 1;
__IOM uint32_t USCBFAH : 1;
uint32_t : 16;
} GTUPSR_b;
};
union
{
__IOM uint32_t GTDNSR;
struct
{
__IOM uint32_t DSGTRGAR : 1;
__IOM uint32_t DSGTRGAF : 1;
__IOM uint32_t DSGTRGBR : 1;
__IOM uint32_t DSGTRGBF : 1;
__IOM uint32_t DSGTRGCR : 1;
__IOM uint32_t DSGTRGCF : 1;
__IOM uint32_t DSGTRGDR : 1;
__IOM uint32_t DSGTRGDF : 1;
__IOM uint32_t DSCARBL : 1;
__IOM uint32_t DSCARBH : 1;
__IOM uint32_t DSCAFBL : 1;
__IOM uint32_t DSCAFBH : 1;
__IOM uint32_t DSCBRAL : 1;
__IOM uint32_t DSCBRAH : 1;
__IOM uint32_t DSCBFAL : 1;
__IOM uint32_t DSCBFAH : 1;
uint32_t : 16;
} GTDNSR_b;
};
union
{
__IOM uint32_t GTICASR;
struct
{
__IOM uint32_t ASGTRGAR : 1;
__IOM uint32_t ASGTRGAF : 1;
__IOM uint32_t ASGTRGBR : 1;
__IOM uint32_t ASGTRGBF : 1;
__IOM uint32_t ASGTRGCR : 1;
__IOM uint32_t ASGTRGCF : 1;
__IOM uint32_t ASGTRGDR : 1;
__IOM uint32_t ASGTRGDF : 1;
__IOM uint32_t ASCARBL : 1;
__IOM uint32_t ASCARBH : 1;
__IOM uint32_t ASCAFBL : 1;
__IOM uint32_t ASCAFBH : 1;
__IOM uint32_t ASCBRAL : 1;
__IOM uint32_t ASCBRAH : 1;
__IOM uint32_t ASCBFAL : 1;
__IOM uint32_t ASCBFAH : 1;
uint32_t : 16;
} GTICASR_b;
};
union
{
__IOM uint32_t GTICBSR;
struct
{
__IOM uint32_t BSGTRGAR : 1;
__IOM uint32_t BSGTRGAF : 1;
__IOM uint32_t BSGTRGBR : 1;
__IOM uint32_t BSGTRGBF : 1;
__IOM uint32_t BSGTRGCR : 1;
__IOM uint32_t BSGTRGCF : 1;
__IOM uint32_t BSGTRGDR : 1;
__IOM uint32_t BSGTRGDF : 1;
__IOM uint32_t BSCARBL : 1;
__IOM uint32_t BSCARBH : 1;
__IOM uint32_t BSCAFBL : 1;
__IOM uint32_t BSCAFBH : 1;
__IOM uint32_t BSCBRAL : 1;
__IOM uint32_t BSCBRAH : 1;
__IOM uint32_t BSCBFAL : 1;
__IOM uint32_t BSCBFAH : 1;
uint32_t : 16;
} GTICBSR_b;
};
union
{
__IOM uint32_t GTCR;
struct
{
__IOM uint32_t CST : 1;
uint32_t : 15;
__IOM uint32_t MD : 3;
uint32_t : 5;
__IOM uint32_t TPCS : 3;
uint32_t : 5;
} GTCR_b;
};
union
{
__IOM uint32_t GTUDDTYC;
struct
{
__IOM uint32_t UD : 1;
__IOM uint32_t UDF : 1;
uint32_t : 14;
__IOM uint32_t OADTY : 2;
__IOM uint32_t OADTYF : 1;
__IOM uint32_t OADTYR : 1;
uint32_t : 4;
__IOM uint32_t OBDTY : 2;
__IOM uint32_t OBDTYF : 1;
__IOM uint32_t OBDTYR : 1;
uint32_t : 4;
} GTUDDTYC_b;
};
union
{
__IOM uint32_t GTIOR;
struct
{
__IOM uint32_t GTIOA : 5;
uint32_t : 1;
__IOM uint32_t OADFLT : 1;
__IOM uint32_t OAHLD : 1;
__IOM uint32_t OAE : 1;
__IOM uint32_t OADF : 2;
uint32_t : 2;
__IOM uint32_t NFAEN : 1;
__IOM uint32_t NFCSA : 2;
__IOM uint32_t GTIOB : 5;
uint32_t : 1;
__IOM uint32_t OBDFLT : 1;
__IOM uint32_t OBHLD : 1;
__IOM uint32_t OBE : 1;
__IOM uint32_t OBDF : 2;
uint32_t : 2;
__IOM uint32_t NFBEN : 1;
__IOM uint32_t NFCSB : 2;
} GTIOR_b;
};
union
{
__IOM uint32_t GTINTAD;
struct
{
__IOM uint32_t GTINTA : 1;
__IOM uint32_t GTINTB : 1;
__IOM uint32_t GTINTC : 1;
__IOM uint32_t GTINTD : 1;
__IOM uint32_t GTINTE : 1;
__IOM uint32_t GTINTF : 1;
__IOM uint32_t GTINTPR : 2;
uint32_t : 8;
__IOM uint32_t ADTRAUEN : 1;
__IOM uint32_t ADTRADEN : 1;
__IOM uint32_t ADTRBUEN : 1;
__IOM uint32_t ADTRBDEN : 1;
uint32_t : 4;
__IOM uint32_t GRP : 2;
uint32_t : 2;
__IOM uint32_t GRPDTE : 1;
__IOM uint32_t GRPABH : 1;
__IOM uint32_t GRPABL : 1;
uint32_t : 1;
} GTINTAD_b;
};
union
{
__IOM uint32_t GTST;
struct
{
__IOM uint32_t TCFA : 1;
__IOM uint32_t TCFB : 1;
__IOM uint32_t TCFC : 1;
__IOM uint32_t TCFD : 1;
__IOM uint32_t TCFE : 1;
__IOM uint32_t TCFF : 1;
__IOM uint32_t TCFPO : 1;
__IOM uint32_t TCFPU : 1;
__IM uint32_t ITCNT : 3;
uint32_t : 4;
__IM uint32_t TUCF : 1;
__IOM uint32_t ADTRAUF : 1;
__IOM uint32_t ADTRADF : 1;
__IOM uint32_t ADTRBUF : 1;
__IOM uint32_t ADTRBDF : 1;
uint32_t : 4;
__IM uint32_t ODF : 1;
uint32_t : 3;
__IM uint32_t DTEF : 1;
__IM uint32_t OABHF : 1;
__IM uint32_t OABLF : 1;
uint32_t : 1;
} GTST_b;
};
union
{
__IOM uint32_t GTBER;
struct
{
__IOM uint32_t BD : 4;
uint32_t : 12;
__IOM uint32_t CCRA : 2;
__IOM uint32_t CCRB : 2;
__IOM uint32_t PR : 2;
__IOM uint32_t CCRSWT : 1;
uint32_t : 1;
__IOM uint32_t ADTTA : 2;
__IOM uint32_t ADTDA : 1;
uint32_t : 1;
__IOM uint32_t ADTTB : 2;
__IOM uint32_t ADTDB : 1;
uint32_t : 1;
} GTBER_b;
};
union
{
__IOM uint32_t GTITC;
struct
{
__IOM uint32_t ITLA : 1;
__IOM uint32_t ITLB : 1;
__IOM uint32_t ITLC : 1;
__IOM uint32_t ITLD : 1;
__IOM uint32_t ITLE : 1;
__IOM uint32_t ITLF : 1;
__IOM uint32_t IVTC : 2;
__IOM uint32_t IVTT : 3;
uint32_t : 1;
__IOM uint32_t ADTAL : 1;
uint32_t : 1;
__IOM uint32_t ADTBL : 1;
uint32_t : 17;
} GTITC_b;
};
union
{
__IOM uint32_t GTCNT;
struct
{
__IOM uint32_t GTCNT : 32;
} GTCNT_b;
};
union
{
__IOM uint32_t GTCCRA;
struct
{
__IOM uint32_t GTCCRA : 32;
} GTCCRA_b;
};
union
{
__IOM uint32_t GTCCRB;
struct
{
__IOM uint32_t GTCCRB : 32;
} GTCCRB_b;
};
union
{
__IOM uint32_t GTCCRC;
struct
{
__IOM uint32_t GTCCRC : 32;
} GTCCRC_b;
};
union
{
__IOM uint32_t GTCCRE;
struct
{
__IOM uint32_t GTCCRE : 32;
} GTCCRE_b;
};
union
{
__IOM uint32_t GTCCRD;
struct
{
__IOM uint32_t GTCCRD : 32;
} GTCCRD_b;
};
union
{
__IOM uint32_t GTCCRF;
struct
{
__IOM uint32_t GTCCRF : 32;
} GTCCRF_b;
};
union
{
__IOM uint32_t GTPR;
struct
{
__IOM uint32_t GTPR : 32;
} GTPR_b;
};
union
{
__IOM uint32_t GTPBR;
struct
{
__IOM uint32_t GTPBR : 32;
} GTPBR_b;
};
union
{
__IOM uint32_t GTPDBR;
struct
{
__IOM uint32_t GTPDBR : 32;
} GTPDBR_b;
};
union
{
__IOM uint32_t GTADTRA;
struct
{
__IOM uint32_t GTADTRA : 32;
} GTADTRA_b;
};
union
{
__IOM uint32_t GTADTBRA;
struct
{
__IOM uint32_t GTADTBRA : 32;
} GTADTBRA_b;
};
union
{
__IOM uint32_t GTADTDBRA;
struct
{
__IOM uint32_t GTADTDBRA : 32;
} GTADTDBRA_b;
};
union
{
__IOM uint32_t GTADTRB;
struct
{
__IOM uint32_t GTADTRB : 32;
} GTADTRB_b;
};
union
{
__IOM uint32_t GTADTBRB;
struct
{
__IOM uint32_t GTADTBRB : 32;
} GTADTBRB_b;
};
union
{
__IOM uint32_t GTADTDBRB;
struct
{
__IOM uint32_t GTADTDBRB : 32;
} GTADTDBRB_b;
};
union
{
__IOM uint32_t GTDTCR;
struct
{
__IOM uint32_t TDE : 1;
uint32_t : 3;
__IOM uint32_t TDBUE : 1;
__IOM uint32_t TDBDE : 1;
uint32_t : 2;
__IOM uint32_t TDFER : 1;
uint32_t : 23;
} GTDTCR_b;
};
union
{
__IOM uint32_t GTDVU;
struct
{
__IOM uint32_t GTDVU : 32;
} GTDVU_b;
};
union
{
__IOM uint32_t GTDVD;
struct
{
__IOM uint32_t GTDVD : 32;
} GTDVD_b;
};
union
{
__IOM uint32_t GTDBU;
struct
{
__IOM uint32_t GTDBU : 32;
} GTDBU_b;
};
union
{
__IOM uint32_t GTDBD;
struct
{
__IOM uint32_t GTDBD : 32;
} GTDBD_b;
};
union
{
__IM uint32_t GTSOS;
struct
{
__IM uint32_t SOS : 2;
uint32_t : 30;
} GTSOS_b;
};
union
{
__IOM uint32_t GTSOTR;
struct
{
__IOM uint32_t SOTR : 1;
uint32_t : 31;
} GTSOTR_b;
};
} R_GPT0_Type;
/* ================================================================================================================= */
/* ================ Device Specific Peripheral Address Map ====== */
/* ================================================================================================================= */
#define R_GPT0_BASE 0x40048000
#define R_GPT1_BASE 0x40048100
#define R_GPT2_BASE 0x40048200
#define R_GPT3_BASE 0x40048300
#define R_GPT4_BASE 0x40048400
#define R_GPT5_BASE 0x40048500
#define R_GPT6_BASE 0x40048600
#define R_GPT7_BASE 0x40048700
/* ================================================================================================================= */
/* ================ Peripheral declaration ====== */
/* ================================================================================================================= */
#define R_GPT0 ((R_GPT0_Type *) R_GPT0_BASE)
#define R_GPT1 ((R_GPT0_Type *) R_GPT1_BASE)
#define R_GPT2 ((R_GPT0_Type *) R_GPT2_BASE)
#define R_GPT3 ((R_GPT0_Type *) R_GPT3_BASE)
#define R_GPT4 ((R_GPT0_Type *) R_GPT4_BASE)
#define R_GPT5 ((R_GPT0_Type *) R_GPT5_BASE)
#define R_GPT6 ((R_GPT0_Type *) R_GPT6_BASE)
#define R_GPT7 ((R_GPT0_Type *) R_GPT7_BASE)
#endif /* GPT_IODEFINE_H */

View File

@ -0,0 +1,120 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : gtm_iodefine.h
* Version : 1.00
* Description : IO define file for gtm.
*********************************************************************************************************************/
/* ================================================================================================================= */
/* ================ Device Specific Cluster Section ====== */
/* ================================================================================================================= */
/* ================================================================================================================= */
/* ================ Device Specific Peripheral Section ====== */
/* ================================================================================================================= */
#ifndef GTM_IODEFINE_H
#define GTM_IODEFINE_H
typedef struct
{
union
{
__IOM uint32_t OSTMnCMP;
struct
{
__IOM uint32_t OSTMnCMP : 32;
} OSTMnCMP_b;
};
union
{
__IM uint32_t OSTMnCNT;
struct
{
__IM uint32_t OSTMnCNT : 32;
} OSTMnCNT_b;
};
__IM uint8_t RESERVED[8];
union
{
__IM uint8_t OSTMnTE;
struct
{
__IM uint8_t OSTMnTE : 1;
uint8_t : 7;
} OSTMnTE_b;
};
__IM uint8_t RESERVED1[3];
union
{
__IOM uint8_t OSTMnTS;
struct
{
__OM uint8_t OSTMnTS : 1;
uint8_t : 7;
} OSTMnTS_b;
};
__IM uint8_t RESERVED2[3];
union
{
__IOM uint8_t OSTMnTT;
struct
{
__OM uint8_t OSTMnTT : 1;
uint8_t : 7;
} OSTMnTT_b;
};
__IM uint8_t RESERVED3[7];
union
{
__IOM uint8_t OSTMnCTL;
struct
{
__IOM uint8_t OSTMnMD0 : 1;
__IOM uint8_t OSTMnMD1 : 1;
uint8_t : 6;
} OSTMnCTL_b;
};
} R_GTM0_Type;
/* ================================================================================================================= */
/* ================ Device Specific Peripheral Address Map ====== */
/* ================================================================================================================= */
#define R_GTM0_BASE 0x42801000
#define R_GTM1_BASE 0x42801400
#define R_GTM2_BASE 0x42801800
/* ================================================================================================================= */
/* ================ Peripheral declaration ====== */
/* ================================================================================================================= */
#define R_GTM0 ((R_GTM0_Type *) R_GTM0_BASE)
#define R_GTM1 ((R_GTM0_Type *) R_GTM1_BASE)
#define R_GTM2 ((R_GTM0_Type *) R_GTM2_BASE)
#endif /* GTM_IODEFINE_H */

View File

@ -0,0 +1,457 @@
/***********************************************************************************************************************
* Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates. All Rights Reserved.
*
* This software and documentation are supplied by Renesas Electronics Corporation and/or its affiliates and may only
* be used with products of Renesas Electronics Corp. and its affiliates ("Renesas"). No other uses are authorized.
* Renesas products are sold pursuant to Renesas terms and conditions of sale. Purchasers are solely responsible for
* the selection and use of Renesas products and Renesas assumes no liability. No license, express or implied, to any
* intellectual property right is granted by Renesas. This software is protected under all applicable laws, including
* copyright laws. Renesas reserves the right to change or discontinue this software and/or this documentation.
* THE SOFTWARE AND DOCUMENTATION IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND
* TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY,
* INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE
* SOFTWARE OR DOCUMENTATION. RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.
* TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR
* DOCUMENTATION (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER,
* INCLUDING, WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY
* LOST PROFITS, OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
**********************************************************************************************************************/
/**********************************************************************************************************************
* File Name : intc_im33_iodefine.h
* Version : 1.00
* Description : IO define file for intc_im33.
*********************************************************************************************************************/
/* ================================================================================================================= */
/* ================ Device Specific Cluster Section ====== */
/* ================================================================================================================= */
/* ================================================================================================================= */
/* ================ Device Specific Peripheral Section ====== */
/* ================================================================================================================= */
#ifndef INTC_IM33_IODEFINE_H
#define INTC_IM33_IODEFINE_H
typedef struct
{
union
{
__IOM uint32_t NSCR;
struct
{
__IOM uint32_t NSTAT : 1;
uint32_t : 15;
__IM uint32_t NSMON : 1;
uint32_t : 15;
} NSCR_b;
};
union
{
__IOM uint32_t NITSR;
struct
{
__IOM uint32_t NTSEL : 1;
uint32_t : 31;
} NITSR_b;
};
__IM uint8_t RESERVED[8];
union
{
__IOM uint32_t ISCR;
struct
{
__IOM uint32_t ISTAT0 : 1;
__IOM uint32_t ISTAT1 : 1;
__IOM uint32_t ISTAT2 : 1;
__IOM uint32_t ISTAT3 : 1;
__IOM uint32_t ISTAT4 : 1;
__IOM uint32_t ISTAT5 : 1;
__IOM uint32_t ISTAT6 : 1;
__IOM uint32_t ISTAT7 : 1;
uint32_t : 24;
} ISCR_b;
};
union
{
__IOM uint32_t IITSR;
struct
{
__IOM uint32_t IITSEL0 : 2;
__IOM uint32_t IITSEL1 : 2;
__IOM uint32_t IITSEL2 : 2;
__IOM uint32_t IITSEL3 : 2;
__IOM uint32_t IITSEL4 : 2;
__IOM uint32_t IITSEL5 : 2;
__IOM uint32_t IITSEL6 : 2;
__IOM uint32_t IITSEL7 : 2;
uint32_t : 16;
} IITSR_b;
};
__IM uint8_t RESERVED1[8];
union
{
__IOM uint32_t TSCR;
struct
{
__IOM uint32_t TSTAT0 : 1;
__IOM uint32_t TSTAT1 : 1;
__IOM uint32_t TSTAT2 : 1;
__IOM uint32_t TSTAT3 : 1;
__IOM uint32_t TSTAT4 : 1;
__IOM uint32_t TSTAT5 : 1;
__IOM uint32_t TSTAT6 : 1;
__IOM uint32_t TSTAT7 : 1;
__IOM uint32_t TSTAT8 : 1;
__IOM uint32_t TSTAT9 : 1;
__IOM uint32_t TSTAT10 : 1;
__IOM uint32_t TSTAT11 : 1;
__IOM uint32_t TSTAT12 : 1;
__IOM uint32_t TSTAT13 : 1;
__IOM uint32_t TSTAT14 : 1;
__IOM uint32_t TSTAT15 : 1;
__IOM uint32_t TSTAT16 : 1;
__IOM uint32_t TSTAT17 : 1;
__IOM uint32_t TSTAT18 : 1;
__IOM uint32_t TSTAT19 : 1;
__IOM uint32_t TSTAT20 : 1;
__IOM uint32_t TSTAT21 : 1;
__IOM uint32_t TSTAT22 : 1;
__IOM uint32_t TSTAT23 : 1;
__IOM uint32_t TSTAT24 : 1;
__IOM uint32_t TSTAT25 : 1;
__IOM uint32_t TSTAT26 : 1;
__IOM uint32_t TSTAT27 : 1;
__IOM uint32_t TSTAT28 : 1;
__IOM uint32_t TSTAT29 : 1;
__IOM uint32_t TSTAT30 : 1;
__IOM uint32_t TSTAT31 : 1;
} TSCR_b;
};
union
{
__IOM uint32_t TITSR0;
struct
{
__IOM uint32_t TITSEL0 : 2;
__IOM uint32_t TITSEL1 : 2;
__IOM uint32_t TITSEL2 : 2;
__IOM uint32_t TITSEL3 : 2;
__IOM uint32_t TITSEL4 : 2;
__IOM uint32_t TITSEL5 : 2;
__IOM uint32_t TITSEL6 : 2;
__IOM uint32_t TITSEL7 : 2;
__IOM uint32_t TITSEL8 : 2;
__IOM uint32_t TITSEL9 : 2;
__IOM uint32_t TITSEL10 : 2;
__IOM uint32_t TITSEL11 : 2;
__IOM uint32_t TITSEL12 : 2;
__IOM uint32_t TITSEL13 : 2;
__IOM uint32_t TITSEL14 : 2;
__IOM uint32_t TITSEL15 : 2;
} TITSR0_b;
};
union
{
__IOM uint32_t TITSR1;
struct
{
__IOM uint32_t TITSEL16 : 2;
__IOM uint32_t TITSEL17 : 2;
__IOM uint32_t TITSEL18 : 2;
__IOM uint32_t TITSEL19 : 2;
__IOM uint32_t TITSEL20 : 2;
__IOM uint32_t TITSEL21 : 2;
__IOM uint32_t TITSEL22 : 2;
__IOM uint32_t TITSEL23 : 2;
__IOM uint32_t TITSEL24 : 2;
__IOM uint32_t TITSEL25 : 2;
__IOM uint32_t TITSEL26 : 2;
__IOM uint32_t TITSEL27 : 2;
__IOM uint32_t TITSEL28 : 2;
__IOM uint32_t TITSEL29 : 2;
__IOM uint32_t TITSEL30 : 2;
__IOM uint32_t TITSEL31 : 2;
} TITSR1_b;
};
__IM uint8_t RESERVED2[4];
union
{
__IOM uint32_t TSSR0;
struct
{
__IOM uint32_t TSSEL0 : 7;
__IOM uint32_t TIEN0 : 1;
__IOM uint32_t TSSEL1 : 7;
__IOM uint32_t TIEN1 : 1;
__IOM uint32_t TSSEL2 : 7;
__IOM uint32_t TIEN2 : 1;
__IOM uint32_t TSSEL3 : 7;
__IOM uint32_t TIEN3 : 1;
} TSSR0_b;
};
union
{
__IOM uint32_t TSSR1;
struct
{
__IOM uint32_t TSSEL4 : 7;
__IOM uint32_t TIEN4 : 1;
__IOM uint32_t TSSEL5 : 7;
__IOM uint32_t TIEN5 : 1;
__IOM uint32_t TSSEL6 : 7;
__IOM uint32_t TIEN6 : 1;
__IOM uint32_t TSSEL7 : 7;
__IOM uint32_t TIEN7 : 1;
} TSSR1_b;
};
union
{
__IOM uint32_t TSSR2;
struct
{
__IOM uint32_t TSSEL8 : 7;
__IOM uint32_t TIEN8 : 1;
__IOM uint32_t TSSEL9 : 7;
__IOM uint32_t TIEN9 : 1;
__IOM uint32_t TSSEL10 : 7;
__IOM uint32_t TIEN10 : 1;
__IOM uint32_t TSSEL11 : 7;
__IOM uint32_t TIEN11 : 1;
} TSSR2_b;
};
union
{
__IOM uint32_t TSSR3;
struct
{
__IOM uint32_t TSSEL12 : 7;
__IOM uint32_t TIEN12 : 1;
__IOM uint32_t TSSEL13 : 7;
__IOM uint32_t TIEN13 : 1;
__IOM uint32_t TSSEL14 : 7;
__IOM uint32_t TIEN14 : 1;
__IOM uint32_t TSSEL15 : 7;
__IOM uint32_t TIEN15 : 1;
} TSSR3_b;
};
union
{
__IOM uint32_t TSSR4;
struct
{
__IOM uint32_t TSSEL16 : 7;
__IOM uint32_t TIEN16 : 1;
__IOM uint32_t TSSEL17 : 7;
__IOM uint32_t TIEN17 : 1;
__IOM uint32_t TSSEL18 : 7;
__IOM uint32_t TIEN18 : 1;
__IOM uint32_t TSSEL19 : 7;
__IOM uint32_t TIEN19 : 1;
} TSSR4_b;
};
union
{
__IOM uint32_t TSSR5;
struct
{
__IOM uint32_t TSSEL20 : 7;
__IOM uint32_t TIEN20 : 1;
__IOM uint32_t TSSEL21 : 7;
__IOM uint32_t TIEN21 : 1;
__IOM uint32_t TSSEL22 : 7;
__IOM uint32_t TIEN22 : 1;
__IOM uint32_t TSSEL23 : 7;
__IOM uint32_t TIEN23 : 1;
} TSSR5_b;
};
union
{
__IOM uint32_t TSSR6;
struct
{
__IOM uint32_t TSSEL24 : 7;
__IOM uint32_t TIEN24 : 1;
__IOM uint32_t TSSEL25 : 7;
__IOM uint32_t TIEN25 : 1;
__IOM uint32_t TSSEL26 : 7;
__IOM uint32_t TIEN26 : 1;
__IOM uint32_t TSSEL27 : 7;
__IOM uint32_t TIEN27 : 1;
} TSSR6_b;
};
union
{
__IOM uint32_t TSSR7;
struct
{
__IOM uint32_t TSSEL28 : 7;
__IOM uint32_t TIEN28 : 1;
__IOM uint32_t TSSEL29 : 7;
__IOM uint32_t TIEN29 : 1;
__IOM uint32_t TSSEL30 : 7;
__IOM uint32_t TIEN30 : 1;
__IOM uint32_t TSSEL31 : 7;
__IOM uint32_t TIEN31 : 1;
} TSSR7_b;
};
union
{
__IOM uint32_t BEISR0;
struct
{
__IOM uint32_t BESTAT0 : 1;
__IOM uint32_t BESTAT1 : 1;
__IOM uint32_t BESTAT2 : 1;
__IOM uint32_t BESTAT3 : 1;
__IOM uint32_t BESTAT4 : 1;
__IOM uint32_t BESTAT5 : 1;
__IOM uint32_t BESTAT6 : 1;
__IOM uint32_t BESTAT7 : 1;
__IOM uint32_t BESTAT8 : 1;
__IOM uint32_t BESTAT9 : 1;
__IOM uint32_t BESTAT10 : 1;
__IOM uint32_t BESTAT11 : 1;
__IOM uint32_t BESTAT12 : 1;
__IOM uint32_t BESTAT13 : 1;
__IOM uint32_t BESTAT14 : 1;
__IOM uint32_t BESTAT15 : 1;
__IOM uint32_t BESTAT16 : 1;
__IOM uint32_t BESTAT17 : 1;
__IOM uint32_t BESTAT18 : 1;
__IOM uint32_t BESTAT19 : 1;
__IOM uint32_t BESTAT20 : 1;
__IOM uint32_t BESTAT21 : 1;
__IOM uint32_t BESTAT22 : 1;
__IOM uint32_t BESTAT23 : 1;
__IOM uint32_t BESTAT24 : 1;
__IOM uint32_t BESTAT25 : 1;
__IOM uint32_t BESTAT26 : 1;
__IOM uint32_t BESTAT27 : 1;
__IOM uint32_t BESTAT28 : 1;
__IOM uint32_t BESTAT29 : 1;
__IOM uint32_t BESTAT30 : 1;
__IOM uint32_t BESTAT31 : 1;
} BEISR0_b;
};
union
{
__IOM uint32_t BEISR1;
struct
{
__IOM uint32_t BESTAT32 : 1;
__IOM uint32_t BESTAT33 : 1;
__IOM uint32_t BESTAT34 : 1;
__IOM uint32_t BESTAT35 : 1;
__IOM uint32_t BESTAT36 : 1;
__IOM uint32_t BESTAT37 : 1;
__IOM uint32_t BESTAT38 : 1;
__IOM uint32_t BESTAT39 : 1;
__IOM uint32_t BESTAT40 : 1;
__IOM uint32_t BESTAT41 : 1;
__IOM uint32_t BESTAT42 : 1;
__IOM uint32_t BESTAT43 : 1;
__IOM uint32_t BESTAT44 : 1;
uint32_t : 19;
} BEISR1_b;
};
__IM uint8_t RESERVED3[8];
union
{
__IOM uint32_t EREISR0;
struct
{
__IOM uint32_t E1STAT0 : 1;
__IOM uint32_t E1STAT1 : 1;
__IOM uint32_t E1STAT2 : 1;
__IOM uint32_t E1STAT3 : 1;
__IOM uint32_t E1STAT4 : 1;
__IOM uint32_t E1STAT5 : 1;
__IOM uint32_t E1STAT6 : 1;
__IOM uint32_t E1STAT7 : 1;
__IOM uint32_t E2STAT0 : 1;
__IOM uint32_t E2STAT1 : 1;
__IOM uint32_t E2STAT2 : 1;
__IOM uint32_t E2STAT3 : 1;
__IOM uint32_t E2STAT4 : 1;
__IOM uint32_t E2STAT5 : 1;
__IOM uint32_t E2STAT6 : 1;
__IOM uint32_t E2STAT7 : 1;
__IOM uint32_t OFSTAT0 : 1;
__IOM uint32_t OFSTAT1 : 1;
__IOM uint32_t OFSTAT2 : 1;
__IOM uint32_t OFSTAT3 : 1;
__IOM uint32_t OFSTAT4 : 1;
__IOM uint32_t OFSTAT5 : 1;
__IOM uint32_t OFSTAT6 : 1;
__IOM uint32_t OFSTAT7 : 1;
uint32_t : 8;
} EREISR0_b;
};
union
{
__IOM uint32_t EREISR1;
struct
{
__IOM uint32_t E1STAT0 : 1;
__IOM uint32_t E1STAT1 : 1;
__IOM uint32_t E1STAT2 : 1;
__IOM uint32_t E1STAT3 : 1;
__IOM uint32_t E1STAT4 : 1;
__IOM uint32_t E1STAT5 : 1;
__IOM uint32_t E1STAT6 : 1;
__IOM uint32_t E1STAT7 : 1;
__IOM uint32_t E2STAT0 : 1;
__IOM uint32_t E2STAT1 : 1;
__IOM uint32_t E2STAT2 : 1;
__IOM uint32_t E2STAT3 : 1;
__IOM uint32_t E2STAT4 : 1;
__IOM uint32_t E2STAT5 : 1;
__IOM uint32_t E2STAT6 : 1;
__IOM uint32_t E2STAT7 : 1;
__IOM uint32_t OFSTAT0 : 1;
__IOM uint32_t OFSTAT1 : 1;
__IOM uint32_t OFSTAT2 : 1;
__IOM uint32_t OFSTAT3 : 1;
__IOM uint32_t OFSTAT4 : 1;
__IOM uint32_t OFSTAT5 : 1;
__IOM uint32_t OFSTAT6 : 1;
__IOM uint32_t OFSTAT7 : 1;
uint32_t : 8;
} EREISR1_b;
};
} R_INTC_IM33_Type;
/* ================================================================================================================= */
/* ================ Device Specific Peripheral Address Map ====== */
/* ================================================================================================================= */
#define R_INTC_IM33_BASE 0x410B0000
/* ================================================================================================================= */
/* ================ Peripheral declaration ====== */
/* ================================================================================================================= */
#define R_INTC_IM33 ((R_INTC_IM33_Type *) R_INTC_IM33_BASE)
#endif /* INTC_IM33_IODEFINE_H */

Some files were not shown because too many files have changed in this diff Show More