The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
AnnaBridge
Date:
Wed Feb 20 20:53:29 2019 +0000
Revision:
172:65be27845400
Parent:
171:3a7713b1edbc
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 161:aa5281ff4a02 1 /*******************************************************************************
AnnaBridge 161:aa5281ff4a02 2 * DISCLAIMER
AnnaBridge 161:aa5281ff4a02 3 * This software is supplied by Renesas Electronics Corporation and is only
AnnaBridge 161:aa5281ff4a02 4 * intended for use with Renesas products. No other uses are authorized. This
AnnaBridge 161:aa5281ff4a02 5 * software is owned by Renesas Electronics Corporation and is protected under
AnnaBridge 161:aa5281ff4a02 6 * all applicable laws, including copyright laws.
AnnaBridge 161:aa5281ff4a02 7 * THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES REGARDING
AnnaBridge 161:aa5281ff4a02 8 * THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING BUT NOT
AnnaBridge 161:aa5281ff4a02 9 * LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
AnnaBridge 161:aa5281ff4a02 10 * AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY DISCLAIMED.
AnnaBridge 161:aa5281ff4a02 11 * TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
AnnaBridge 161:aa5281ff4a02 12 * ELECTRONICS CORPORATION NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
AnnaBridge 161:aa5281ff4a02 13 * FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES FOR
AnnaBridge 161:aa5281ff4a02 14 * ANY REASON RELATED TO THIS SOFTWARE, EVEN IF RENESAS OR ITS AFFILIATES HAVE
AnnaBridge 161:aa5281ff4a02 15 * BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
AnnaBridge 161:aa5281ff4a02 16 * Renesas reserves the right, without notice, to make changes to this software
AnnaBridge 161:aa5281ff4a02 17 * and to discontinue the availability of this software. By using this software,
AnnaBridge 161:aa5281ff4a02 18 * you agree to the additional terms and conditions found by accessing the
AnnaBridge 161:aa5281ff4a02 19 * following link:
AnnaBridge 161:aa5281ff4a02 20 * http://www.renesas.com/disclaimer*
AnnaBridge 161:aa5281ff4a02 21 * Copyright (C) 2013-2016 Renesas Electronics Corporation. All rights reserved.
AnnaBridge 161:aa5281ff4a02 22 *******************************************************************************/
AnnaBridge 161:aa5281ff4a02 23 /*******************************************************************************
AnnaBridge 161:aa5281ff4a02 24 * File Name : rspi_iodefine.h
AnnaBridge 161:aa5281ff4a02 25 * $Rev: $
AnnaBridge 161:aa5281ff4a02 26 * $Date:: $
AnnaBridge 161:aa5281ff4a02 27 * Description : Definition of I/O Register for RZ/A1LU (V3.00l)
AnnaBridge 161:aa5281ff4a02 28 ******************************************************************************/
AnnaBridge 161:aa5281ff4a02 29 #ifndef RSPI_IODEFINE_H
AnnaBridge 161:aa5281ff4a02 30 #define RSPI_IODEFINE_H
AnnaBridge 161:aa5281ff4a02 31 /* ->QAC 0639 : Over 127 members (C90) */
AnnaBridge 161:aa5281ff4a02 32 /* ->QAC 0857 : Over 1024 #define (C90) */
AnnaBridge 161:aa5281ff4a02 33 /* ->MISRA 18.4 : Pack unpack union */ /* ->SEC M1.6.2 */
AnnaBridge 161:aa5281ff4a02 34 /* ->SEC M1.10.1 : Not magic number */
AnnaBridge 161:aa5281ff4a02 35
AnnaBridge 161:aa5281ff4a02 36 #define RSPI0 (*(struct st_rspi *)0xE800C800uL) /* RSPI0 */
AnnaBridge 161:aa5281ff4a02 37 #define RSPI1 (*(struct st_rspi *)0xE800D000uL) /* RSPI1 */
AnnaBridge 161:aa5281ff4a02 38 #define RSPI2 (*(struct st_rspi *)0xE800D800uL) /* RSPI2 */
AnnaBridge 161:aa5281ff4a02 39
AnnaBridge 161:aa5281ff4a02 40
AnnaBridge 161:aa5281ff4a02 41 /* Start of channel array defines of RSPI */
AnnaBridge 161:aa5281ff4a02 42
AnnaBridge 161:aa5281ff4a02 43 /* Channel array defines of RSPI */
AnnaBridge 161:aa5281ff4a02 44 /*(Sample) value = RSPI[ channel ]->SPCR; */
AnnaBridge 161:aa5281ff4a02 45 #define RSPI_COUNT (3)
AnnaBridge 161:aa5281ff4a02 46 #define RSPI_ADDRESS_LIST \
AnnaBridge 161:aa5281ff4a02 47 { /* ->MISRA 11.3 */ /* ->SEC R2.7.1 */ \
AnnaBridge 161:aa5281ff4a02 48 &RSPI0, &RSPI1, &RSPI2 \
AnnaBridge 161:aa5281ff4a02 49 } /* <-MISRA 11.3 */ /* <-SEC R2.7.1 */ /* { } is for MISRA 19.4 */
AnnaBridge 161:aa5281ff4a02 50
AnnaBridge 161:aa5281ff4a02 51 /* End of channel array defines of RSPI */
AnnaBridge 161:aa5281ff4a02 52
AnnaBridge 161:aa5281ff4a02 53
AnnaBridge 161:aa5281ff4a02 54 #define SPCR_0 (RSPI0.SPCR)
AnnaBridge 161:aa5281ff4a02 55 #define SSLP_0 (RSPI0.SSLP)
AnnaBridge 161:aa5281ff4a02 56 #define SPPCR_0 (RSPI0.SPPCR)
AnnaBridge 161:aa5281ff4a02 57 #define SPSR_0 (RSPI0.SPSR)
AnnaBridge 161:aa5281ff4a02 58 #define SPDR_0 (RSPI0.SPDR.UINT32)
AnnaBridge 161:aa5281ff4a02 59 #define SPDR_0L (RSPI0.SPDR.UINT16[R_IO_L])
AnnaBridge 161:aa5281ff4a02 60 #define SPDR_0H (RSPI0.SPDR.UINT16[R_IO_H])
AnnaBridge 161:aa5281ff4a02 61 #define SPDR_0LL (RSPI0.SPDR.UINT8[R_IO_LL])
AnnaBridge 161:aa5281ff4a02 62 #define SPDR_0LH (RSPI0.SPDR.UINT8[R_IO_LH])
AnnaBridge 161:aa5281ff4a02 63 #define SPDR_0HL (RSPI0.SPDR.UINT8[R_IO_HL])
AnnaBridge 161:aa5281ff4a02 64 #define SPDR_0HH (RSPI0.SPDR.UINT8[R_IO_HH])
AnnaBridge 161:aa5281ff4a02 65 #define SPSCR_0 (RSPI0.SPSCR)
AnnaBridge 161:aa5281ff4a02 66 #define SPSSR_0 (RSPI0.SPSSR)
AnnaBridge 161:aa5281ff4a02 67 #define SPBR_0 (RSPI0.SPBR)
AnnaBridge 161:aa5281ff4a02 68 #define SPDCR_0 (RSPI0.SPDCR)
AnnaBridge 161:aa5281ff4a02 69 #define SPCKD_0 (RSPI0.SPCKD)
AnnaBridge 161:aa5281ff4a02 70 #define SSLND_0 (RSPI0.SSLND)
AnnaBridge 161:aa5281ff4a02 71 #define SPND_0 (RSPI0.SPND)
AnnaBridge 161:aa5281ff4a02 72 #define SPCMD0_0 (RSPI0.SPCMD0)
AnnaBridge 161:aa5281ff4a02 73 #define SPCMD1_0 (RSPI0.SPCMD1)
AnnaBridge 161:aa5281ff4a02 74 #define SPCMD2_0 (RSPI0.SPCMD2)
AnnaBridge 161:aa5281ff4a02 75 #define SPCMD3_0 (RSPI0.SPCMD3)
AnnaBridge 161:aa5281ff4a02 76 #define SPBFCR_0 (RSPI0.SPBFCR)
AnnaBridge 161:aa5281ff4a02 77 #define SPBFDR_0 (RSPI0.SPBFDR)
AnnaBridge 161:aa5281ff4a02 78 #define SPCR_1 (RSPI1.SPCR)
AnnaBridge 161:aa5281ff4a02 79 #define SSLP_1 (RSPI1.SSLP)
AnnaBridge 161:aa5281ff4a02 80 #define SPPCR_1 (RSPI1.SPPCR)
AnnaBridge 161:aa5281ff4a02 81 #define SPSR_1 (RSPI1.SPSR)
AnnaBridge 161:aa5281ff4a02 82 #define SPDR_1 (RSPI1.SPDR.UINT32)
AnnaBridge 161:aa5281ff4a02 83 #define SPDR_1L (RSPI1.SPDR.UINT16[R_IO_L])
AnnaBridge 161:aa5281ff4a02 84 #define SPDR_1H (RSPI1.SPDR.UINT16[R_IO_H])
AnnaBridge 161:aa5281ff4a02 85 #define SPDR_1LL (RSPI1.SPDR.UINT8[R_IO_LL])
AnnaBridge 161:aa5281ff4a02 86 #define SPDR_1LH (RSPI1.SPDR.UINT8[R_IO_LH])
AnnaBridge 161:aa5281ff4a02 87 #define SPDR_1HL (RSPI1.SPDR.UINT8[R_IO_HL])
AnnaBridge 161:aa5281ff4a02 88 #define SPDR_1HH (RSPI1.SPDR.UINT8[R_IO_HH])
AnnaBridge 161:aa5281ff4a02 89 #define SPSCR_1 (RSPI1.SPSCR)
AnnaBridge 161:aa5281ff4a02 90 #define SPSSR_1 (RSPI1.SPSSR)
AnnaBridge 161:aa5281ff4a02 91 #define SPBR_1 (RSPI1.SPBR)
AnnaBridge 161:aa5281ff4a02 92 #define SPDCR_1 (RSPI1.SPDCR)
AnnaBridge 161:aa5281ff4a02 93 #define SPCKD_1 (RSPI1.SPCKD)
AnnaBridge 161:aa5281ff4a02 94 #define SSLND_1 (RSPI1.SSLND)
AnnaBridge 161:aa5281ff4a02 95 #define SPND_1 (RSPI1.SPND)
AnnaBridge 161:aa5281ff4a02 96 #define SPCMD0_1 (RSPI1.SPCMD0)
AnnaBridge 161:aa5281ff4a02 97 #define SPCMD1_1 (RSPI1.SPCMD1)
AnnaBridge 161:aa5281ff4a02 98 #define SPCMD2_1 (RSPI1.SPCMD2)
AnnaBridge 161:aa5281ff4a02 99 #define SPCMD3_1 (RSPI1.SPCMD3)
AnnaBridge 161:aa5281ff4a02 100 #define SPBFCR_1 (RSPI1.SPBFCR)
AnnaBridge 161:aa5281ff4a02 101 #define SPBFDR_1 (RSPI1.SPBFDR)
AnnaBridge 161:aa5281ff4a02 102 #define SPCR_2 (RSPI2.SPCR)
AnnaBridge 161:aa5281ff4a02 103 #define SSLP_2 (RSPI2.SSLP)
AnnaBridge 161:aa5281ff4a02 104 #define SPPCR_2 (RSPI2.SPPCR)
AnnaBridge 161:aa5281ff4a02 105 #define SPSR_2 (RSPI2.SPSR)
AnnaBridge 161:aa5281ff4a02 106 #define SPDR_2 (RSPI2.SPDR.UINT32)
AnnaBridge 161:aa5281ff4a02 107 #define SPDR_2L (RSPI2.SPDR.UINT16[R_IO_L])
AnnaBridge 161:aa5281ff4a02 108 #define SPDR_2H (RSPI2.SPDR.UINT16[R_IO_H])
AnnaBridge 161:aa5281ff4a02 109 #define SPDR_2LL (RSPI2.SPDR.UINT8[R_IO_LL])
AnnaBridge 161:aa5281ff4a02 110 #define SPDR_2LH (RSPI2.SPDR.UINT8[R_IO_LH])
AnnaBridge 161:aa5281ff4a02 111 #define SPDR_2HL (RSPI2.SPDR.UINT8[R_IO_HL])
AnnaBridge 161:aa5281ff4a02 112 #define SPDR_2HH (RSPI2.SPDR.UINT8[R_IO_HH])
AnnaBridge 161:aa5281ff4a02 113 #define SPSCR_2 (RSPI2.SPSCR)
AnnaBridge 161:aa5281ff4a02 114 #define SPSSR_2 (RSPI2.SPSSR)
AnnaBridge 161:aa5281ff4a02 115 #define SPBR_2 (RSPI2.SPBR)
AnnaBridge 161:aa5281ff4a02 116 #define SPDCR_2 (RSPI2.SPDCR)
AnnaBridge 161:aa5281ff4a02 117 #define SPCKD_2 (RSPI2.SPCKD)
AnnaBridge 161:aa5281ff4a02 118 #define SSLND_2 (RSPI2.SSLND)
AnnaBridge 161:aa5281ff4a02 119 #define SPND_2 (RSPI2.SPND)
AnnaBridge 161:aa5281ff4a02 120 #define SPCMD0_2 (RSPI2.SPCMD0)
AnnaBridge 161:aa5281ff4a02 121 #define SPCMD1_2 (RSPI2.SPCMD1)
AnnaBridge 161:aa5281ff4a02 122 #define SPCMD2_2 (RSPI2.SPCMD2)
AnnaBridge 161:aa5281ff4a02 123 #define SPCMD3_2 (RSPI2.SPCMD3)
AnnaBridge 161:aa5281ff4a02 124 #define SPBFCR_2 (RSPI2.SPBFCR)
AnnaBridge 161:aa5281ff4a02 125 #define SPBFDR_2 (RSPI2.SPBFDR)
AnnaBridge 161:aa5281ff4a02 126
AnnaBridge 161:aa5281ff4a02 127 #define SPCMD_COUNT (4)
AnnaBridge 161:aa5281ff4a02 128
AnnaBridge 161:aa5281ff4a02 129
AnnaBridge 161:aa5281ff4a02 130 typedef struct st_rspi
AnnaBridge 161:aa5281ff4a02 131 {
AnnaBridge 161:aa5281ff4a02 132 /* RSPI */
AnnaBridge 161:aa5281ff4a02 133 volatile uint8_t SPCR; /* SPCR */
AnnaBridge 161:aa5281ff4a02 134 volatile uint8_t SSLP; /* SSLP */
AnnaBridge 161:aa5281ff4a02 135 volatile uint8_t SPPCR; /* SPPCR */
AnnaBridge 161:aa5281ff4a02 136 volatile uint8_t SPSR; /* SPSR */
AnnaBridge 161:aa5281ff4a02 137 union iodefine_reg32_t SPDR; /* SPDR */
AnnaBridge 161:aa5281ff4a02 138
AnnaBridge 161:aa5281ff4a02 139 volatile uint8_t SPSCR; /* SPSCR */
AnnaBridge 161:aa5281ff4a02 140 volatile uint8_t SPSSR; /* SPSSR */
AnnaBridge 161:aa5281ff4a02 141 volatile uint8_t SPBR; /* SPBR */
AnnaBridge 161:aa5281ff4a02 142 volatile uint8_t SPDCR; /* SPDCR */
AnnaBridge 161:aa5281ff4a02 143 volatile uint8_t SPCKD; /* SPCKD */
AnnaBridge 161:aa5281ff4a02 144 volatile uint8_t SSLND; /* SSLND */
AnnaBridge 161:aa5281ff4a02 145 volatile uint8_t SPND; /* SPND */
AnnaBridge 161:aa5281ff4a02 146 volatile uint8_t dummy1[1]; /* */
AnnaBridge 161:aa5281ff4a02 147
AnnaBridge 161:aa5281ff4a02 148 /* #define SPCMD_COUNT (4) */
AnnaBridge 161:aa5281ff4a02 149 volatile uint16_t SPCMD0; /* SPCMD0 */
AnnaBridge 161:aa5281ff4a02 150 volatile uint16_t SPCMD1; /* SPCMD1 */
AnnaBridge 161:aa5281ff4a02 151 volatile uint16_t SPCMD2; /* SPCMD2 */
AnnaBridge 161:aa5281ff4a02 152 volatile uint16_t SPCMD3; /* SPCMD3 */
AnnaBridge 161:aa5281ff4a02 153 volatile uint8_t dummy2[8]; /* */
AnnaBridge 161:aa5281ff4a02 154 volatile uint8_t SPBFCR; /* SPBFCR */
AnnaBridge 161:aa5281ff4a02 155 volatile uint8_t dummy3[1]; /* */
AnnaBridge 161:aa5281ff4a02 156 volatile uint16_t SPBFDR; /* SPBFDR */
AnnaBridge 161:aa5281ff4a02 157 } r_io_rspi_t;
AnnaBridge 161:aa5281ff4a02 158
AnnaBridge 161:aa5281ff4a02 159
AnnaBridge 161:aa5281ff4a02 160 /* Channel array defines of RSPI (2)*/
AnnaBridge 161:aa5281ff4a02 161 #ifdef DECLARE_RSPI_CHANNELS
AnnaBridge 161:aa5281ff4a02 162 volatile struct st_rspi* RSPI[ RSPI_COUNT ] =
AnnaBridge 161:aa5281ff4a02 163 /* ->MISRA 11.3 */ /* ->SEC R2.7.1 */
AnnaBridge 161:aa5281ff4a02 164 RSPI_ADDRESS_LIST;
AnnaBridge 161:aa5281ff4a02 165 /* <-MISRA 11.3 */ /* <-SEC R2.7.1 */
AnnaBridge 161:aa5281ff4a02 166 #endif /* DECLARE_RSPI_CHANNELS */
AnnaBridge 161:aa5281ff4a02 167 /* End of channel array defines of RSPI (2)*/
AnnaBridge 161:aa5281ff4a02 168
AnnaBridge 161:aa5281ff4a02 169
AnnaBridge 161:aa5281ff4a02 170 /* <-SEC M1.10.1 */
AnnaBridge 161:aa5281ff4a02 171 /* <-MISRA 18.4 */ /* <-SEC M1.6.2 */
AnnaBridge 161:aa5281ff4a02 172 /* <-QAC 0857 */
AnnaBridge 161:aa5281ff4a02 173 /* <-QAC 0639 */
AnnaBridge 161:aa5281ff4a02 174 #endif