source: EcnlProtoTool/trunk/asp3_dcre/mbed/targets/hal/TARGET_RENESAS/TARGET_RZ_A1H/pinmap.c@ 270

Last change on this file since 270 was 270, checked in by coas-nagasima, 7 years ago

mruby版ECNLプロトタイピング・ツールを追加

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-csrc
File size: 6.2 KB
Line 
1/* mbed Microcontroller Library
2 * Copyright (c) 2006-2013 ARM Limited
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#include "pinmap.h"
17#include "mbed_error.h"
18#include "gpio_addrdefine.h"
19
20PinName gpio_multi_guard = (PinName)NC; /* If set pin name here, setting of the "pin" is just one time */
21
22typedef struct {
23 PinName pin;
24 int function;
25 int pm;
26} PinFunc;
27
28static const PinFunc PIPC_0_tbl[] = {
29// pin func pm
30 {P4_0 , 2 , -1}, /* TIOC0A */
31 {P5_0 , 6 , -1}, /* TIOC0A */
32 {P7_0 , 7 , -1}, /* TIOC0A */
33 {P10_4 , 2 , -1}, /* TIOC0A */
34 {P4_1 , 2 , -1}, /* TIOC0B */
35 {P5_1 , 6 , -1}, /* TIOC0B */
36 {P7_1 , 7 , -1}, /* TIOC0B */
37 {P10_5 , 2 , -1}, /* TIOC0B */
38 {P4_2 , 2 , -1}, /* TIOC0C */
39 {P5_5 , 6 , -1}, /* TIOC0C */
40 {P7_2 , 7 , -1}, /* TIOC0C */
41 {P10_6 , 2 , -1}, /* TIOC0C */
42 {P4_3 , 2 , -1}, /* TIOC0D */
43 {P5_7 , 6 , -1}, /* TIOC0D */
44 {P7_3 , 7 , -1}, /* TIOC0D */
45 {P10_7 , 2 , -1}, /* TIOC0D */
46 {P2_11 , 5 , -1}, /* TIOC1A */
47 {P6_0 , 5 , -1}, /* TIOC1A */
48 {P7_4 , 7 , -1}, /* TIOC1A */
49 {P8_8 , 5 , -1}, /* TIOC1A */
50 {P9_7 , 4 , -1}, /* TIOC1A */
51 {P10_8 , 2 , -1}, /* TIOC1A */
52 {P2_12 , 8 , -1}, /* TIOC1B */
53 {P5_2 , 6 , -1}, /* TIOC1B */
54 {P6_1 , 5 , -1}, /* TIOC1B */
55 {P7_5 , 7 , -1}, /* TIOC1B */
56 {P8_9 , 5 , -1}, /* TIOC1B */
57 {P10_9 , 2 , -1}, /* TIOC1B */
58 {P2_1 , 6 , -1}, /* TIOC2A */
59 {P6_2 , 6 , -1}, /* TIOC2A */
60 {P7_6 , 7 , -1}, /* TIOC2A */
61 {P8_14 , 4 , -1}, /* TIOC2A */
62 {P10_10 , 2 , -1}, /* TIOC2A */
63 {P2_2 , 6 , -1}, /* TIOC2B */
64 {P6_3 , 6 , -1}, /* TIOC2B */
65 {P7_7 , 7 , -1}, /* TIOC2B */
66 {P8_15 , 4 , -1}, /* TIOC2B */
67 {P10_11 , 2 , -1}, /* TIOC2B */
68 {P10_11 , 2 , -1}, /* TIOC2B */
69 {P3_4 , 6 , -1}, /* TIOC3A */
70 {P7_8 , 7 , -1}, /* TIOC3A */
71 {P8_10 , 4 , -1}, /* TIOC3A */
72 {P3_5 , 6 , -1}, /* TIOC3B */
73 {P7_9 , 7 , -1}, /* TIOC3B */
74 {P8_11 , 4 , -1}, /* TIOC3B */
75 {P3_6 , 6 , -1}, /* TIOC3C */
76 {P5_3 , 6 , -1}, /* TIOC3C */
77 {P7_10 , 7 , -1}, /* TIOC3C */
78 {P8_12 , 4 , -1}, /* TIOC3C */
79 {P3_7 , 6 , -1}, /* TIOC3D */
80 {P5_4 , 6 , -1}, /* TIOC3D */
81 {P7_11 , 7 , -1}, /* TIOC3D */
82 {P8_13 , 4 , -1}, /* TIOC3D */
83 {P3_8 , 6 , -1}, /* TIOC4A */
84 {P4_4 , 3 , -1}, /* TIOC4A */
85 {P7_12 , 7 , -1}, /* TIOC4A */
86 {P11_0 , 2 , -1}, /* TIOC4A */
87 {P3_9 , 6 , -1}, /* TIOC4B */
88 {P4_5 , 3 , -1}, /* TIOC4B */
89 {P7_13 , 7 , -1}, /* TIOC4B */
90 {P11_1 , 2 , -1}, /* TIOC4B */
91 {P3_10 , 6 , -1}, /* TIOC4C */
92 {P4_6 , 3 , -1}, /* TIOC4C */
93 {P7_14 , 7 , -1}, /* TIOC4C */
94 {P11_2 , 2 , -1}, /* TIOC4C */
95 {P3_11 , 6 , -1}, /* TIOC4D */
96 {P4_7 , 3 , -1}, /* TIOC4D */
97 {P7_15 , 7 , -1}, /* TIOC4D */
98 {P11_3 , 2 , -1}, /* TIOC4D */
99 {P5_7 , 1 , 1 }, /* TXOUT0M */
100 {P5_6 , 1 , 1 }, /* TXOUT0P */
101 {P5_5 , 1 , 1 }, /* TXOUT1M */
102 {P5_4 , 1 , 1 }, /* TXOUT1P */
103 {P5_3 , 1 , 1 }, /* TXOUT2M */
104 {P5_2 , 1 , 1 }, /* TXOUT2P */
105 {P5_1 , 1 , 1 }, /* TXCLKOUTM */
106 {P5_0 , 1 , 1 }, /* TXCLKOUTP */
107 {P2_11 , 4 , 0 }, /* SSITxD0 */
108 {P4_7 , 5 , 0 }, /* SSITxD0 */
109 {P7_4 , 6 , 0 }, /* SSITxD1 */
110 {P10_15 , 2 , 0 }, /* SSITxD1 */
111 {P4_15 , 6 , 0 }, /* SSITxD3 */
112 {P7_11 , 2 , 0 }, /* SSITxD3 */
113 {P2_7 , 4 , 0 }, /* SSITxD5 */
114 {P4_11 , 5 , 0 }, /* SSITxD5 */
115 {P8_10 , 8 , 0 }, /* SSITxD5 */
116 {P3_7 , 8 , 0 }, /* WDTOVF */
117 {NC , 0 , -1}
118};
119
120void pin_function(PinName pin, int function) {
121 if (pin == (PinName)NC) return;
122
123 int n = pin >> 4;
124 int bitmask = 1<<(pin & 0xf);
125 const PinFunc * Pipc_0_func = PIPC_0_tbl;
126 int pipc_data = 1;
127
128 if (gpio_multi_guard != pin) {
129 if (function == 0) {
130 // means GPIO mode
131 *PMC(n) &= ~bitmask;
132 } else {
133 // alt-function mode
134 --function;
135
136 if (function & (1 << 2)) { *PFCAE(n) |= bitmask;}else { *PFCAE(n) &= ~bitmask;}
137 if (function & (1 << 1)) { *PFCE(n) |= bitmask;}else { *PFCE(n) &= ~bitmask;}
138 if (function & (1 << 0)) { *PFC(n) |= bitmask;}else { *PFC(n) &= ~bitmask;}
139
140 while (Pipc_0_func->pin != NC) {
141 if ((Pipc_0_func->pin == pin) && ((Pipc_0_func->function - 1) == function)) {
142 pipc_data = 0;
143 if (Pipc_0_func->pm == 0) {
144 *PMSR(n) = (bitmask << 16) | 0;
145 } else if (Pipc_0_func->pm == 1) {
146 *PMSR(n) = (bitmask << 16) | bitmask;
147 } else {
148 // Do Nothing
149 }
150 break;
151 }
152 Pipc_0_func++;
153 }
154 if (pipc_data == 1) {
155 *PIPC(n) |= bitmask;
156 } else {
157 *PIPC(n) &= ~bitmask;
158 }
159
160 if (P1_0 <= pin && pin <= P1_7 && function == 0) {
161 *PBDC(n) |= bitmask;
162 }
163 *PMC(n) |= bitmask;
164 }
165 } else {
166 gpio_multi_guard = (PinName)NC;
167 }
168}
169
170void pin_mode(PinName pin, PinMode mode) {
171// if (pin == (PinName)NC) { return; }
172}
Note: See TracBrowser for help on using the repository browser.