source: EcnlProtoTool/trunk/asp3_dcre/mbed/targets/hal/TARGET_RENESAS/TARGET_RZ_A1H/pwmout_api.c@ 321

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

文字コードを設定

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-csrc;charset=UTF-8
File size: 16.8 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 "mbed_assert.h"
17#include "pwmout_api.h"
18#include "cmsis.h"
19#include "pinmap.h"
20#include "RZ_A1_Init.h"
21#include "cpg_iodefine.h"
22#include "pwm_iodefine.h"
23#include "gpio_addrdefine.h"
24
25#define MTU2_PWM_NUM 22
26#define MTU2_PWM_SIGNAL 2
27#define MTU2_PWM_OFFSET 0x20
28
29// PORT ID, PWM ID, Pin function
30static const PinMap PinMap_PWM[] = {
31 {P2_1 , MTU2_PWM0_PIN , 6},
32 {P2_11 , MTU2_PWM1_PIN , 5},
33 {P3_8 , MTU2_PWM2_PIN , 6},
34 {P3_10 , MTU2_PWM3_PIN , 6},
35 {P4_0 , MTU2_PWM4_PIN , 2},
36 {P4_4 , MTU2_PWM5_PIN , 3},
37 {P4_6 , MTU2_PWM6_PIN , 3},
38 {P5_0 , MTU2_PWM7_PIN , 6},
39 {P5_3 , MTU2_PWM8_PIN , 6},
40 {P5_5 , MTU2_PWM9_PIN , 6},
41 {P7_2 , MTU2_PWM10_PIN , 7},
42 {P7_4 , MTU2_PWM11_PIN , 7},
43 {P7_6 , MTU2_PWM12_PIN , 7},
44 {P7_10 , MTU2_PWM13_PIN , 7},
45 {P7_12 , MTU2_PWM14_PIN , 7},
46 {P7_14 , MTU2_PWM15_PIN , 7},
47 {P8_8 , MTU2_PWM16_PIN , 5},
48 {P8_10 , MTU2_PWM17_PIN , 4},
49 {P8_12 , MTU2_PWM18_PIN , 4},
50 {P8_14 , MTU2_PWM19_PIN , 4},
51 {P11_0 , MTU2_PWM20_PIN , 2},
52 {P11_2 , MTU2_PWM21_PIN , 2},
53 {P4_4 , PWM0_PIN , 4},
54 {P3_2 , PWM1_PIN , 7},
55 {P4_6 , PWM2_PIN , 4},
56 {P4_7 , PWM3_PIN , 4},
57 {P8_14 , PWM4_PIN , 6},
58 {P8_15 , PWM5_PIN , 6},
59 {P8_13 , PWM6_PIN , 6},
60 {P8_11 , PWM7_PIN , 6},
61 {P8_8 , PWM8_PIN , 6},
62 {P10_0 , PWM9_PIN , 3},
63 {P8_12 , PWM10_PIN , 6},
64 {P8_9 , PWM11_PIN , 6},
65 {P8_10 , PWM12_PIN , 6},
66 {P4_5 , PWM13_PIN , 4},
67 {NC , NC , 0}
68};
69
70static const PWMType PORT[] = {
71 PWM2E, // PWM0_PIN
72 PWM2C, // PWM1_PIN
73 PWM2G, // PWM2_PIN
74 PWM2H, // PWM3_PIN
75 PWM1G, // PWM4_PIN
76 PWM1H, // PWM5_PIN
77 PWM1F, // PWM6_PIN
78 PWM1D, // PWM7_PIN
79 PWM1A, // PWM8_PIN
80 PWM2A, // PWM9_PIN
81 PWM1E, // PWM10_PIN
82 PWM1B, // PWM11_PIN
83 PWM1C, // PWM12_PIN
84 PWM2F, // PWM13_PIN
85};
86
87static const MTU2_PWMType MTU2_PORT[] = {
88 TIOC2A, // MTU2_PWM0_PIN
89 TIOC1A, // MTU2_PWM1_PIN
90 TIOC4A, // MTU2_PWM2_PIN
91 TIOC4C, // MTU2_PWM3_PIN
92 TIOC0A, // MTU2_PWM4_PIN
93 TIOC4A, // MTU2_PWM5_PIN
94 TIOC4C, // MTU2_PWM6_PIN
95 TIOC0A, // MTU2_PWM7_PIN
96 TIOC3C, // MTU2_PWM8_PIN
97 TIOC0C, // MTU2_PWM9_PIN
98 TIOC0C, // MTU2_PWM10_PIN
99 TIOC1A, // MTU2_PWM11_PIN
100 TIOC2A, // MTU2_PWM12_PIN
101 TIOC3C, // MTU2_PWM13_PIN
102 TIOC4A, // MTU2_PWM14_PIN
103 TIOC4C, // MTU2_PWM15_PIN
104 TIOC1A, // MTU2_PWM16_PIN
105 TIOC3A, // MTU2_PWM17_PIN
106 TIOC3C, // MTU2_PWM18_PIN
107 TIOC2A, // MTU2_PWM19_PIN
108 TIOC4A, // MTU2_PWM20_PIN
109 TIOC4C, // MTU2_PWM21_PIN
110};
111
112static __IO uint16_t *PWM_MATCH[] = {
113 &PWMPWBFR_2E, // PWM0_PIN
114 &PWMPWBFR_2C, // PWM1_PIN
115 &PWMPWBFR_2G, // PWM2_PIN
116 &PWMPWBFR_2G, // PWM3_PIN
117 &PWMPWBFR_1G, // PWM4_PIN
118 &PWMPWBFR_1G, // PWM5_PIN
119 &PWMPWBFR_1E, // PWM6_PIN
120 &PWMPWBFR_1C, // PWM7_PIN
121 &PWMPWBFR_1A, // PWM8_PIN
122 &PWMPWBFR_2A, // PWM9_PIN
123 &PWMPWBFR_1E, // PWM10_PIN
124 &PWMPWBFR_1A, // PWM11_PIN
125 &PWMPWBFR_1C, // PWM12_PIN
126 &PWMPWBFR_2E, // PWM13_PIN
127};
128
129static __IO uint16_t *MTU2_PWM_MATCH[MTU2_PWM_NUM][MTU2_PWM_SIGNAL] = {
130 { &MTU2TGRA_2, &MTU2TGRB_2 }, // MTU2_PWM0_PIN
131 { &MTU2TGRA_1, &MTU2TGRB_1 }, // MTU2_PWM1_PIN
132 { &MTU2TGRA_4, &MTU2TGRB_4 }, // MTU2_PWM2_PIN
133 { &MTU2TGRC_4, &MTU2TGRD_4 }, // MTU2_PWM3_PIN
134 { &MTU2TGRA_0, &MTU2TGRB_0 }, // MTU2_PWM4_PIN
135 { &MTU2TGRA_4, &MTU2TGRB_4 }, // MTU2_PWM5_PIN
136 { &MTU2TGRC_4, &MTU2TGRD_4 }, // MTU2_PWM6_PIN
137 { &MTU2TGRA_0, &MTU2TGRB_0 }, // MTU2_PWM7_PIN
138 { &MTU2TGRC_3, &MTU2TGRD_3 }, // MTU2_PWM8_PIN
139 { &MTU2TGRC_0, &MTU2TGRD_0 }, // MTU2_PWM9_PIN
140 { &MTU2TGRC_0, &MTU2TGRD_0 }, // MTU2_PWM10_PIN
141 { &MTU2TGRA_1, &MTU2TGRB_1 }, // MTU2_PWM11_PIN
142 { &MTU2TGRA_2, &MTU2TGRB_2 }, // MTU2_PWM12_PIN
143 { &MTU2TGRC_3, &MTU2TGRD_3 }, // MTU2_PWM13_PIN
144 { &MTU2TGRA_4, &MTU2TGRB_4 }, // MTU2_PWM14_PIN
145 { &MTU2TGRC_4, &MTU2TGRD_4 }, // MTU2_PWM15_PIN
146 { &MTU2TGRA_1, &MTU2TGRB_1 }, // MTU2_PWM16_PIN
147 { &MTU2TGRA_3, &MTU2TGRB_3 }, // MTU2_PWM17_PIN
148 { &MTU2TGRC_3, &MTU2TGRD_3 }, // MTU2_PWM18_PIN
149 { &MTU2TGRA_2, &MTU2TGRB_2 }, // MTU2_PWM19_PIN
150 { &MTU2TGRA_4, &MTU2TGRB_4 }, // MTU2_PWM20_PIN
151 { &MTU2TGRC_4, &MTU2TGRD_4 } // MTU2_PWM21_PIN
152};
153
154static __IO uint8_t *TCR_MATCH[] = {
155 &MTU2TCR_0,
156 &MTU2TCR_1,
157 &MTU2TCR_2,
158 &MTU2TCR_3,
159 &MTU2TCR_4,
160};
161
162static __IO uint8_t *TIORH_MATCH[] = {
163 &MTU2TIORH_0,
164 &MTU2TIOR_1,
165 &MTU2TIOR_2,
166 &MTU2TIORH_3,
167 &MTU2TIORH_4,
168};
169
170static __IO uint8_t *TIORL_MATCH[] = {
171 &MTU2TIORL_0,
172 NULL,
173 NULL,
174 &MTU2TIORL_3,
175 &MTU2TIORL_4,
176};
177
178static __IO uint16_t *TGRA_MATCH[] = {
179 &MTU2TGRA_0,
180 &MTU2TGRA_1,
181 &MTU2TGRA_2,
182 &MTU2TGRA_3,
183 &MTU2TGRA_4,
184};
185
186static __IO uint16_t *TGRC_MATCH[] = {
187 &MTU2TGRC_0,
188 NULL,
189 NULL,
190 &MTU2TGRC_3,
191 &MTU2TGRC_4,
192};
193
194static __IO uint8_t *TMDR_MATCH[] = {
195 &MTU2TMDR_0,
196 &MTU2TMDR_1,
197 &MTU2TMDR_2,
198 &MTU2TMDR_3,
199 &MTU2TMDR_4,
200};
201
202static int MAX_PERIOD[] = {
203 125000,
204 503000,
205 2000000,
206 2000000,
207 2000000,
208};
209
210typedef enum {
211 MODE_PWM = 0,
212 MODE_MTU2
213} PWMmode;
214
215typedef enum {
216 MTU2_PULSE = 0,
217 MTU2_PERIOD
218} MTU2Signal;
219
220static int pwm_mode = MODE_PWM;
221static uint16_t init_period_ch1 = 0;
222static uint16_t init_period_ch2 = 0;
223static uint16_t init_mtu2_period_ch[5] = {0};
224static int32_t period_ch1 = 1;
225static int32_t period_ch2 = 1;
226static int32_t mtu2_period_ch[5] = {1, 1, 1, 1, 1};
227
228void pwmout_init(pwmout_t* obj, PinName pin) {
229 // determine the channel
230 PWMName pwm = (PWMName)pinmap_peripheral(pin, PinMap_PWM);
231 MBED_ASSERT(pwm != (PWMName)NC);
232
233 if (pwm >= MTU2_PWM_OFFSET) {
234 /* PWM by MTU2 */
235 int tmp_pwm;
236
237 pwm_mode = MODE_MTU2;
238 // power on
239 CPGSTBCR3 &= ~(CPG_STBCR3_BIT_MSTP33);
240
241 obj->pwm = pwm;
242 tmp_pwm = (int)(obj->pwm - MTU2_PWM_OFFSET);
243 if (((uint32_t)MTU2_PORT[tmp_pwm] & 0x00000040) == 0x00000040) {
244 obj->ch = 4;
245 MTU2TOER |= 0x36;
246 } else if (((uint32_t)MTU2_PORT[tmp_pwm] & 0x00000030) == 0x00000030) {
247 obj->ch = 3;
248 MTU2TOER |= 0x09;
249 } else if (((uint32_t)MTU2_PORT[tmp_pwm] & 0x00000020) == 0x00000020) {
250 obj->ch = 2;
251 } else if (((uint32_t)MTU2_PORT[tmp_pwm] & 0x00000010) == 0x00000010) {
252 obj->ch = 1;
253 } else {
254 obj->ch = 0;
255 }
256 // Wire pinout
257 pinmap_pinout(pin, PinMap_PWM);
258
259 int bitmask = 1 << (pin & 0xf);
260
261 *PMSR(PINGROUP(pin)) = (bitmask << 16) | 0;
262
263 // default duty 0.0f
264 pwmout_write(obj, 0);
265 if (init_mtu2_period_ch[obj->ch] == 0) {
266 // default period 1ms
267 pwmout_period_us(obj, 1000);
268 init_mtu2_period_ch[obj->ch] = 1;
269 }
270 } else {
271 /* PWM */
272 pwm_mode = MODE_PWM;
273 // power on
274 CPGSTBCR3 &= ~(CPG_STBCR3_BIT_MSTP30);
275
276 obj->pwm = pwm;
277 if (((uint32_t)PORT[obj->pwm] & 0x00000010) == 0x00000010) {
278 obj->ch = 2;
279 PWMPWPR_2_BYTE_L = 0x00;
280 } else {
281 obj->ch = 1;
282 PWMPWPR_1_BYTE_L = 0x00;
283 }
284
285 // Wire pinout
286 pinmap_pinout(pin, PinMap_PWM);
287
288 // default to 491us: standard for servos, and fine for e.g. brightness control
289 pwmout_write(obj, 0);
290 if ((obj->ch == 2) && (init_period_ch2 == 0)) {
291 pwmout_period_us(obj, 491);
292 init_period_ch2 = 1;
293 }
294 if ((obj->ch == 1) && (init_period_ch1 == 0)) {
295 pwmout_period_us(obj, 491);
296 init_period_ch1 = 1;
297 }
298 }
299}
300
301void pwmout_free(pwmout_t* obj) {
302 pwmout_write(obj, 0);
303}
304
305void pwmout_write(pwmout_t* obj, float value) {
306 uint32_t wk_cycle;
307 uint16_t v;
308
309 if (pwm_mode == MODE_MTU2) {
310 /* PWM by MTU2 */
311 int tmp_pwm;
312
313 if (value < 0.0f) {
314 value = 0.0f;
315 } else if (value > 1.0f) {
316 value = 1.0f;
317 } else {
318 // Do Nothing
319 }
320 tmp_pwm = (int)(obj->pwm - MTU2_PWM_OFFSET);
321 wk_cycle = *MTU2_PWM_MATCH[tmp_pwm][MTU2_PERIOD] & 0xffff;
322 // set channel match to percentage
323 *MTU2_PWM_MATCH[tmp_pwm][MTU2_PULSE] = (uint16_t)((float)wk_cycle * value);
324 } else {
325 /* PWM */
326 if (value < 0.0f) {
327 value = 0.0f;
328 } else if (value > 1.0f) {
329 value = 1.0f;
330 } else {
331 // Do Nothing
332 }
333
334 if (obj->ch == 2) {
335 wk_cycle = PWMPWCYR_2 & 0x03ff;
336 } else {
337 wk_cycle = PWMPWCYR_1 & 0x03ff;
338 }
339
340 // set channel match to percentage
341 v = (uint16_t)((float)wk_cycle * value);
342 *PWM_MATCH[obj->pwm] = (v | ((PORT[obj->pwm] & 1) << 12));
343 }
344}
345
346float pwmout_read(pwmout_t* obj) {
347 uint32_t wk_cycle;
348 float value;
349
350 if (pwm_mode == MODE_MTU2) {
351 /* PWM by MTU2 */
352 uint32_t wk_pulse;
353 int tmp_pwm;
354
355 tmp_pwm = (int)(obj->pwm - MTU2_PWM_OFFSET);
356 wk_cycle = *MTU2_PWM_MATCH[tmp_pwm][MTU2_PERIOD] & 0xffff;
357 wk_pulse = *MTU2_PWM_MATCH[tmp_pwm][MTU2_PULSE] & 0xffff;
358 value = ((float)wk_pulse / (float)wk_cycle);
359 } else {
360 /* PWM */
361 if (obj->ch == 2) {
362 wk_cycle = PWMPWCYR_2 & 0x03ff;
363 } else {
364 wk_cycle = PWMPWCYR_1 & 0x03ff;
365 }
366 value = ((float)(*PWM_MATCH[obj->pwm] & 0x03ff) / (float)wk_cycle);
367 }
368
369 return (value > 1.0f) ? (1.0f) : (value);
370}
371
372void pwmout_period(pwmout_t* obj, float seconds) {
373 pwmout_period_us(obj, seconds * 1000000.0f);
374}
375
376void pwmout_period_ms(pwmout_t* obj, int ms) {
377 pwmout_period_us(obj, ms * 1000);
378}
379
380static void set_duty_again(__IO uint16_t *p_pwmpbfr, uint16_t last_cycle, uint16_t new_cycle){
381 uint16_t wk_pwmpbfr;
382 float value;
383 uint16_t v;
384
385 wk_pwmpbfr = *p_pwmpbfr;
386 value = ((float)(wk_pwmpbfr & 0x03ff) / (float)last_cycle);
387 v = (uint16_t)((float)new_cycle * value);
388 *p_pwmpbfr = (v | (wk_pwmpbfr & 0x1000));
389}
390
391static void set_mtu2_duty_again(__IO uint16_t *p_pwmpbfr, uint16_t last_cycle, uint16_t new_cycle){
392 uint16_t wk_pwmpbfr;
393 float value;
394
395 wk_pwmpbfr = *p_pwmpbfr;
396 value = ((float)(wk_pwmpbfr & 0xffff) / (float)last_cycle);
397 *p_pwmpbfr = (uint16_t)((float)new_cycle * value);
398}
399
400// Set the PWM period, keeping the duty cycle the same.
401void pwmout_period_us(pwmout_t* obj, int us) {
402 uint64_t wk_cycle_mtu2;
403 uint32_t pclk_base;
404 uint32_t wk_cycle;
405 uint32_t wk_cks = 0;
406 uint16_t wk_last_cycle;
407 int max_us = 0;
408
409 if (pwm_mode == MODE_MTU2) {
410 /* PWM by MTU2 */
411 int tmp_pwm;
412 uint16_t tmp_tgra;
413 uint16_t tmp_tgrc;
414 uint8_t tmp_tcr_up;
415 uint8_t tmp_tstr_sp;
416 uint8_t tmp_tstr_st;
417
418 max_us = MAX_PERIOD[obj->ch];
419 if (us > max_us) {
420 us = max_us;
421 } else if (us < 1) {
422 us = 1;
423 } else {
424 // Do Nothing
425 }
426
427 if (RZ_A1_IsClockMode0() == false) {
428 pclk_base = (uint32_t)CM1_RENESAS_RZ_A1_P0_CLK;
429 } else {
430 pclk_base = (uint32_t)CM0_RENESAS_RZ_A1_P0_CLK;
431 }
432
433 wk_cycle_mtu2 = (uint64_t)pclk_base * us;
434 while (wk_cycle_mtu2 >= 65535000000) {
435 if ((obj->ch == 1) && (wk_cks == 3)) {
436 wk_cks+=2;
437 } else if ((obj->ch == 2) && (wk_cks == 3)) {
438 wk_cycle_mtu2 >>= 2;
439 wk_cks+=3;
440 }
441 wk_cycle_mtu2 >>= 2;
442 wk_cks++;
443 }
444 wk_cycle = (uint32_t)(wk_cycle_mtu2 / 1000000);
445
446 tmp_pwm = (int)(obj->pwm - MTU2_PWM_OFFSET);
447 if (((uint8_t)MTU2_PORT[tmp_pwm] & 0x02) == 0x02) {
448 tmp_tcr_up = 0xC0;
449 } else {
450 tmp_tcr_up = 0x40;
451 }
452 if ((obj->ch == 4) || (obj->ch == 3)) {
453 tmp_tstr_sp = ~(0x38 | (1 << (obj->ch + 3)));
454 tmp_tstr_st = (1 << (obj->ch + 3));
455 } else {
456 tmp_tstr_sp = ~(0x38 | (1 << obj->ch));
457 tmp_tstr_st = (1 << obj->ch);
458 }
459 // Counter Stop
460 MTU2TSTR &= tmp_tstr_sp;
461 wk_last_cycle = *MTU2_PWM_MATCH[tmp_pwm][MTU2_PERIOD] & 0xffff;
462 *TCR_MATCH[obj->ch] = tmp_tcr_up | wk_cks;
463 *TIORH_MATCH[obj->ch] = 0x21;
464 if ((obj->ch == 0) || (obj->ch == 3) || (obj->ch == 4)) {
465 *TIORL_MATCH[obj->ch] = 0x21;
466 }
467 *MTU2_PWM_MATCH[tmp_pwm][MTU2_PERIOD] = (uint16_t)wk_cycle; // Set period
468
469 // Set duty again(TGRA)
470 tmp_tgra = *TGRA_MATCH[obj->ch];
471 set_mtu2_duty_again(&tmp_tgra, wk_last_cycle, wk_cycle);
472 if ((obj->ch == 0) || (obj->ch == 3) || (obj->ch == 4)) {
473 // Set duty again(TGRC)
474 tmp_tgrc = *TGRC_MATCH[obj->ch];
475 set_mtu2_duty_again(&tmp_tgrc, wk_last_cycle, wk_cycle);
476 }
477 *TMDR_MATCH[obj->ch] = 0x02; // PWM mode 1
478
479 // Counter Start
480 MTU2TSTR |= tmp_tstr_st;
481 // Save for future use
482 mtu2_period_ch[obj->ch] = us;
483 } else {
484 /* PWM */
485 if (us > 491) {
486 us = 491;
487 } else if (us < 1) {
488 us = 1;
489 } else {
490 // Do Nothing
491 }
492
493 if (RZ_A1_IsClockMode0() == false) {
494 pclk_base = (uint32_t)CM1_RENESAS_RZ_A1_P0_CLK / 10000;
495 } else {
496 pclk_base = (uint32_t)CM0_RENESAS_RZ_A1_P0_CLK / 10000;
497 }
498
499 wk_cycle = pclk_base * us;
500 while (wk_cycle >= 102350) {
501 wk_cycle >>= 1;
502 wk_cks++;
503 }
504 wk_cycle = (wk_cycle + 50) / 100;
505
506 if (obj->ch == 2) {
507 wk_last_cycle = PWMPWCYR_2 & 0x03ff;
508 PWMPWCR_2_BYTE_L = 0xc0 | wk_cks;
509 PWMPWCYR_2 = (uint16_t)wk_cycle;
510
511 // Set duty again
512 set_duty_again(&PWMPWBFR_2A, wk_last_cycle, wk_cycle);
513 set_duty_again(&PWMPWBFR_2C, wk_last_cycle, wk_cycle);
514 set_duty_again(&PWMPWBFR_2E, wk_last_cycle, wk_cycle);
515 set_duty_again(&PWMPWBFR_2G, wk_last_cycle, wk_cycle);
516
517 // Counter Start
518 PWMPWCR_2_BYTE_L |= 0x08;
519
520 // Save for future use
521 period_ch2 = us;
522 } else {
523 wk_last_cycle = PWMPWCYR_1 & 0x03ff;
524 PWMPWCR_1_BYTE_L = 0xc0 | wk_cks;
525 PWMPWCYR_1 = (uint16_t)wk_cycle;
526
527 // Set duty again
528 set_duty_again(&PWMPWBFR_1A, wk_last_cycle, wk_cycle);
529 set_duty_again(&PWMPWBFR_1C, wk_last_cycle, wk_cycle);
530 set_duty_again(&PWMPWBFR_1E, wk_last_cycle, wk_cycle);
531 set_duty_again(&PWMPWBFR_1G, wk_last_cycle, wk_cycle);
532
533 // Counter Start
534 PWMPWCR_1_BYTE_L |= 0x08;
535
536 // Save for future use
537 period_ch1 = us;
538 }
539 }
540}
541
542void pwmout_pulsewidth(pwmout_t* obj, float seconds) {
543 pwmout_pulsewidth_us(obj, seconds * 1000000.0f);
544}
545
546void pwmout_pulsewidth_ms(pwmout_t* obj, int ms) {
547 pwmout_pulsewidth_us(obj, ms * 1000);
548}
549
550void pwmout_pulsewidth_us(pwmout_t* obj, int us) {
551 float value = 0;
552
553 if (pwm_mode == MODE_MTU2) {
554 /* PWM by MTU2 */
555 if (mtu2_period_ch[obj->ch] != 0) {
556 value = (float)us / (float)mtu2_period_ch[obj->ch];
557 }
558 } else {
559 /* PWM */
560 if (obj->ch == 2) {
561 if (period_ch2 != 0) {
562 value = (float)us / (float)period_ch2;
563 }
564 } else {
565 if (period_ch1 != 0) {
566 value = (float)us / (float)period_ch1;
567 }
568 }
569
570 pwmout_write(obj, value);
571 }
572}
Note: See TracBrowser for help on using the repository browser.