7 #ifndef __MSP430WARE_TIMER_A_H__
8 #define __MSP430WARE_TIMER_A_H__
10 #include "inc/hw_memmap.h"
12 #ifdef __MSP430_HAS_TxA7__
25 #include "inc/hw_memmap.h"
33 #define TIMER_A_THRESHOLD 50
370 #define TIMER_A_CLOCKSOURCE_DIVIDER_1 0x00
371 #define TIMER_A_CLOCKSOURCE_DIVIDER_2 0x08
372 #define TIMER_A_CLOCKSOURCE_DIVIDER_3 0x02
373 #define TIMER_A_CLOCKSOURCE_DIVIDER_4 0x10
374 #define TIMER_A_CLOCKSOURCE_DIVIDER_5 0x04
375 #define TIMER_A_CLOCKSOURCE_DIVIDER_6 0x05
376 #define TIMER_A_CLOCKSOURCE_DIVIDER_7 0x06
377 #define TIMER_A_CLOCKSOURCE_DIVIDER_8 0x18
378 #define TIMER_A_CLOCKSOURCE_DIVIDER_10 0x0C
379 #define TIMER_A_CLOCKSOURCE_DIVIDER_12 0x0D
380 #define TIMER_A_CLOCKSOURCE_DIVIDER_14 0x0E
381 #define TIMER_A_CLOCKSOURCE_DIVIDER_16 0x0F
382 #define TIMER_A_CLOCKSOURCE_DIVIDER_20 0x14
383 #define TIMER_A_CLOCKSOURCE_DIVIDER_24 0x15
384 #define TIMER_A_CLOCKSOURCE_DIVIDER_28 0x16
385 #define TIMER_A_CLOCKSOURCE_DIVIDER_32 0x17
386 #define TIMER_A_CLOCKSOURCE_DIVIDER_40 0x1C
387 #define TIMER_A_CLOCKSOURCE_DIVIDER_48 0x1D
388 #define TIMER_A_CLOCKSOURCE_DIVIDER_56 0x1E
389 #define TIMER_A_CLOCKSOURCE_DIVIDER_64 0x1F
397 #define TIMER_A_STOP_MODE MC_0
398 #define TIMER_A_UP_MODE MC_1
399 #define TIMER_A_CONTINUOUS_MODE MC_2
400 #define TIMER_A_UPDOWN_MODE MC_3
409 #define TIMER_A_DO_CLEAR TACLR
410 #define TIMER_A_SKIP_CLEAR 0x00
419 #define TIMER_A_CLOCKSOURCE_EXTERNAL_TXCLK TASSEL__TACLK
420 #define TIMER_A_CLOCKSOURCE_ACLK TASSEL__ACLK
421 #define TIMER_A_CLOCKSOURCE_SMCLK TASSEL__SMCLK
422 #define TIMER_A_CLOCKSOURCE_INVERTED_EXTERNAL_TXCLK TASSEL__INCLK
431 #define TIMER_A_TAIE_INTERRUPT_ENABLE TAIE
432 #define TIMER_A_TAIE_INTERRUPT_DISABLE 0x00
440 #define TIMER_A_CCIE_CCR0_INTERRUPT_ENABLE CCIE
441 #define TIMER_A_CCIE_CCR0_INTERRUPT_DISABLE 0x00
449 #define TIMER_A_CAPTURECOMPARE_INTERRUPT_DISABLE 0x00
450 #define TIMER_A_CAPTURECOMPARE_INTERRUPT_ENABLE CCIE
458 #define TIMER_A_CAPTURE_INPUTSELECT_CCIxA CCIS_0
459 #define TIMER_A_CAPTURE_INPUTSELECT_CCIxB CCIS_1
460 #define TIMER_A_CAPTURE_INPUTSELECT_GND CCIS_2
461 #define TIMER_A_CAPTURE_INPUTSELECT_Vcc CCIS_3
470 #define TIMER_A_OUTPUTMODE_OUTBITVALUE OUTMOD_0
471 #define TIMER_A_OUTPUTMODE_SET OUTMOD_1
472 #define TIMER_A_OUTPUTMODE_TOGGLE_RESET OUTMOD_2
473 #define TIMER_A_OUTPUTMODE_SET_RESET OUTMOD_3
474 #define TIMER_A_OUTPUTMODE_TOGGLE OUTMOD_4
475 #define TIMER_A_OUTPUTMODE_RESET OUTMOD_5
476 #define TIMER_A_OUTPUTMODE_TOGGLE_SET OUTMOD_6
477 #define TIMER_A_OUTPUTMODE_RESET_SET OUTMOD_7
495 #define TIMER_A_CAPTURECOMPARE_REGISTER_0 0x02
496 #define TIMER_A_CAPTURECOMPARE_REGISTER_1 0x04
497 #define TIMER_A_CAPTURECOMPARE_REGISTER_2 0x06
498 #define TIMER_A_CAPTURECOMPARE_REGISTER_3 0x08
499 #define TIMER_A_CAPTURECOMPARE_REGISTER_4 0x0A
500 #define TIMER_A_CAPTURECOMPARE_REGISTER_5 0x0C
501 #define TIMER_A_CAPTURECOMPARE_REGISTER_6 0x0E
509 #define TIMER_A_CAPTUREMODE_NO_CAPTURE CM_0
510 #define TIMER_A_CAPTUREMODE_RISING_EDGE CM_1
511 #define TIMER_A_CAPTUREMODE_FALLING_EDGE CM_2
512 #define TIMER_A_CAPTUREMODE_RISING_AND_FALLING_EDGE CM_3
520 #define TIMER_A_CAPTURE_ASYNCHRONOUS 0x00
521 #define TIMER_A_CAPTURE_SYNCHRONOUS SCS
530 #define TIMER_A_CAPTURE_OVERFLOW COV
531 #define TIMER_A_CAPTURECOMPARE_INTERRUPT_FLAG CCIFG
539 #define TIMER_A_READ_SYNCHRONIZED_CAPTURECOMPAREINPUT SCCI
540 #define TIMER_A_READ_CAPTURE_COMPARE_INPUT CCI
549 #define TIMER_A_CAPTURECOMPARE_INPUT_HIGH 0x01
550 #define TIMER_A_CAPTURECOMPARE_INPUT_LOW 0x00
559 #define TIMER_A_OUTPUTMODE_OUTBITVALUE_HIGH OUT
560 #define TIMER_A_OUTPUTMODE_OUTBITVALUE_LOW 0x00
568 #define TIMER_A_INTERRUPT_NOT_PENDING 0x00
569 #define TIMER_A_INTERRUPT_PENDING 0x01
742 uint16_t captureCompareRegister);
765 uint16_t captureCompareRegister);
793 uint16_t captureCompareRegister,
834 uint16_t captureCompareRegister,
835 uint16_t
synchronized);
858 uint16_t captureCompareRegister);
879 uint16_t captureCompareRegister);
906 uint16_t captureCompareRegister,
907 uint8_t outputModeOutBitValue);
962 uint16_t compareRegister,
963 uint16_t compareValue);
1000 uint16_t captureCompareRegister);
1028 #endif // __MSP430WARE_TIMER_A_H__
void Timer_A_initContinuousMode(uint16_t baseAddress, Timer_A_initContinuousModeParam *param)
Configures Timer_A in continuous mode.
Definition: timer_a.c:28
uint16_t captureOutputMode
Definition: timer_a.h:139
uint16_t timerClear
Definition: timer_a.h:82
uint16_t synchronizeCaptureSource
Definition: timer_a.h:123
bool startTimer
Whether to start the timer immediately.
Definition: timer_a.h:84
void Timer_A_disableCaptureCompareInterrupt(uint16_t baseAddress, uint16_t captureCompareRegister)
Disable capture compare interrupt.
Definition: timer_a.c:178
uint16_t captureRegister
Definition: timer_a.h:104
void Timer_A_startCounter(uint16_t baseAddress, uint16_t timerMode)
Starts Timer_A counter.
Definition: timer_a.c:21
uint16_t clockSourceDivider
Definition: timer_a.h:236
void Timer_A_stop(uint16_t baseAddress)
Stops the timer.
Definition: timer_a.c:268
void Timer_A_clearCaptureCompareInterrupt(uint16_t baseAddress, uint16_t captureCompareRegister)
Clears the capture-compare interrupt flag.
Definition: timer_a.c:286
uint16_t compareOutputMode
Definition: timer_a.h:260
uint16_t timerClear
Definition: timer_a.h:319
uint16_t timerPeriod
Is the specified Timer_A period.
Definition: timer_a.h:180
void Timer_A_enableInterrupt(uint16_t baseAddress)
Enable timer interrupt.
Definition: timer_a.c:156
void Timer_A_clearTimerInterrupt(uint16_t baseAddress)
Clears the Timer TAIFG interrupt flag.
Definition: timer_a.c:281
uint16_t Timer_A_getCaptureCompareCount(uint16_t baseAddress, uint16_t captureCompareRegister)
Get current capturecompare count.
Definition: timer_a.c:224
Used in the Timer_A_initUpDownMode() function as the param parameter.
Definition: timer_a.h:148
uint16_t clockSource
Definition: timer_a.h:48
uint8_t Timer_A_getSynchronizedCaptureCompareInput(uint16_t baseAddress, uint16_t captureCompareRegister, uint16_t synchronized)
Get synchronized capturecompare input.
Definition: timer_a.c:199
uint16_t compareOutputMode
Definition: timer_a.h:357
uint16_t timerInterruptEnable_TAIE
Definition: timer_a.h:185
void Timer_A_initCompareMode(uint16_t baseAddress, Timer_A_initCompareModeParam *param)
Initializes Compare Mode.
Definition: timer_a.c:139
uint16_t dutyCycle
Specifies the dutycycle for the generated waveform.
Definition: timer_a.h:262
bool startTimer
Whether to start the timer immediately.
Definition: timer_a.h:321
uint16_t timerClear
Definition: timer_a.h:196
uint16_t captureCompareInterruptEnable_CCR0_CCIE
Definition: timer_a.h:190
uint16_t compareInterruptEnable
Definition: timer_a.h:346
uint16_t timerPeriod
Definition: timer_a.h:303
void Timer_A_setOutputForOutputModeOutBitValue(uint16_t baseAddress, uint16_t captureCompareRegister, uint8_t outputModeOutBitValue)
Set output bit for output mode.
Definition: timer_a.c:232
uint16_t clockSourceDivider
Definition: timer_a.h:300
Used in the Timer_A_initCaptureMode() function as the param parameter.
Definition: timer_a.h:93
Used in the Timer_A_initUpMode() function as the param parameter.
Definition: timer_a.h:270
Used in the Timer_A_initCompareMode() function as the param parameter.
Definition: timer_a.h:330
void Timer_A_enableCaptureCompareInterrupt(uint16_t baseAddress, uint16_t captureCompareRegister)
Enable capture compare interrupt.
Definition: timer_a.c:171
uint16_t captureMode
Definition: timer_a.h:111
void Timer_A_disableInterrupt(uint16_t baseAddress)
Disable timer interrupt.
Definition: timer_a.c:161
void Timer_A_initUpDownMode(uint16_t baseAddress, Timer_A_initUpDownModeParam *param)
Configures Timer_A in up down mode.
Definition: timer_a.c:85
uint16_t clockSource
Definition: timer_a.h:213
uint16_t compareValue
Is the count to be compared with in compare mode.
Definition: timer_a.h:359
uint16_t captureInputSelect
Definition: timer_a.h:118
void Timer_A_setCompareValue(uint16_t baseAddress, uint16_t compareRegister, uint16_t compareValue)
Sets the value of the capture-compare register.
Definition: timer_a.c:273
void Timer_A_initCaptureMode(uint16_t baseAddress, Timer_A_initCaptureModeParam *param)
Initializes Capture Mode.
Definition: timer_a.c:117
uint16_t Timer_A_getCounterValue(uint16_t baseAddress)
Reads the current timer count value.
Definition: timer_a.c:293
uint32_t Timer_A_getInterruptStatus(uint16_t baseAddress)
Get timer interrupt status.
Definition: timer_a.c:166
Used in the Timer_A_outputPWM() function as the param parameter.
Definition: timer_a.h:206
void Timer_A_outputPWM(uint16_t baseAddress, Timer_A_outputPWMParam *param)
Generate a PWM with timer running in up mode.
Definition: timer_a.c:242
uint16_t compareRegister
Definition: timer_a.h:341
uint16_t timerInterruptEnable_TAIE
Definition: timer_a.h:308
void Timer_A_initUpMode(uint16_t baseAddress, Timer_A_initUpModeParam *param)
Configures Timer_A in up mode.
Definition: timer_a.c:52
bool startTimer
Whether to start the timer immediately.
Definition: timer_a.h:198
uint16_t clockSourceDivider
Definition: timer_a.h:71
uint32_t Timer_A_getCaptureCompareInterruptStatus(uint16_t baseAddress, uint16_t captureCompareRegister, uint16_t mask)
Return capture compare interrupt status.
Definition: timer_a.c:185
uint16_t clockSource
Definition: timer_a.h:155
uint8_t Timer_A_getOutputForOutputModeOutBitValue(uint16_t baseAddress, uint16_t captureCompareRegister)
Get output bit for output mode.
Definition: timer_a.c:212
uint16_t clockSourceDivider
Definition: timer_a.h:178
Used in the Timer_A_initContinuousMode() function as the param parameter.
Definition: timer_a.h:41
uint16_t compareRegister
Definition: timer_a.h:249
void Timer_A_clear(uint16_t baseAddress)
Reset/Clear the timer clock divider, count direction, count.
Definition: timer_a.c:193
uint16_t captureInterruptEnable
Definition: timer_a.h:128
uint16_t timerPeriod
Selects the desired timer period.
Definition: timer_a.h:238
uint16_t timerInterruptEnable_TAIE
Definition: timer_a.h:76
uint16_t captureCompareInterruptEnable_CCR0_CCIE
Definition: timer_a.h:313
uint16_t clockSource
Definition: timer_a.h:277