ATY_LIB V2_102_230218
ATY_LIB for general devices or ALGO
 
Loading...
Searching...
No Matches
fw_pca.h File Reference
#include "fw_conf.h"
#include "fw_types.h"

Go to the source code of this file.

Macros

#define PCA_SetCounterState(__STATE__)   SBIT_ASSIGN(CR, __STATE__)
 
#define PCA_ClearCounterOverflowInterrupt()   SBIT_RESET(CF)
 
#define PCA_PCA0_ClearInterrupt()   SBIT_RESET(CCF0)
 
#define PCA_PCA1_ClearInterrupt()   SBIT_RESET(CCF1)
 
#define PCA_PCA2_ClearInterrupt()   SBIT_RESET(CCF2)
 
#define PCA_SetStopCounterInIdle(__STATE__)   SFR_ASSIGN(CMOD, 7, __STATE__)
 
#define PCA_SetClockSource(__SOURCE___)   (CMOD = CMOD & ~(0x07 << 1) | ((__SOURCE___) << 1))
 
#define PCA_EnableCounterOverflowInterrupt(__STATE__)   SFR_ASSIGN(CMOD, 0, __STATE__)
 
#define PCA_PCA0_SetWorkMode(__MODE__)   (CCAPM0 = (__MODE__))
 
#define PCA_PCA1_SetWorkMode(__MODE__)   (CCAPM1 = (__MODE__))
 
#define PCA_PCA2_SetWorkMode(__MODE__)   (CCAPM2 = (__MODE__))
 
#define PCA_PWM0_SetBitWidth(__BIT_WIDTH__)   (PCA_PWM0 = PCA_PWM0 & ~(0x03 << 6) | ((__BIT_WIDTH__) << 6))
 
#define PCA_PWM1_SetBitWidth(__BIT_WIDTH__)   (PCA_PWM1 = PCA_PWM1 & ~(0x03 << 6) | ((__BIT_WIDTH__) << 6))
 
#define PCA_PWM2_SetBitWidth(__BIT_WIDTH__)   (PCA_PWM2 = PCA_PWM2 & ~(0x03 << 6) | ((__BIT_WIDTH__) << 6))
 
#define PCA_PCA0_SetCompareValue(__VALUE__)   do{CCAP0H = (__VALUE__); CCAP0L = (__VALUE__);}while(0)
 
#define PCA_PCA1_SetCompareValue(__VALUE__)   do{CCAP1H = (__VALUE__); CCAP1L = (__VALUE__);}while(0)
 
#define PCA_PCA2_SetCompareValue(__VALUE__)   do{CCAP2H = (__VALUE__); CCAP2L = (__VALUE__);}while(0)
 
#define PCA_PCA0_ChangeCompareValue(__VALUE__)   (CCAP0H = (__VALUE__))
 
#define PCA_PCA1_ChangeCompareValue(__VALUE__)   (CCAP1H = (__VALUE__))
 
#define PCA_PCA2_ChangeCompareValue(__VALUE__)   (CCAP2H = (__VALUE__))
 
#define PCA_PCA0_SetCompareValue10bit(__VALUE__)
 
#define PCA_PCA1_SetCompareValue10bit(__VALUE__)
 
#define PCA_PCA2_SetCompareValue10bit(__VALUE__)
 
#define PCA_PCA0_ChangeCompareValue10bit(__VALUE__)
 
#define PCA_PCA1_ChangeCompareValue10bit(__VALUE__)
 
#define PCA_PCA2_ChangeCompareValue10bit(__VALUE__)
 
#define PCA_SetPort(__ALTER_PORT__)   (P_SW1 = P_SW1 & ~(0x03 << 4) | ((__ALTER_PORT__) << 4))
 

Enumerations

enum  PCA_ClockSource_t {
  PCA_ClockSource_SysClkDiv12 = 0x00 , PCA_ClockSource_SysClkDiv2 = 0x01 , PCA_ClockSource_Timer0Overflow = 0x02 , PCA_ClockSource_ExtClock = 0x03 ,
  PCA_ClockSource_SysClk = 0x04 , PCA_ClockSource_SysClkDiv4 = 0x05 , PCA_ClockSource_SysClkDiv6 = 0x06 , PCA_ClockSource_SysClkDiv8 = 0x07
}
 
enum  PCA_WorkMode_t {
  PCA_WorkMode_None = 0x00 , PCA_WorkMode_PWM_NonInterrupt = 0x42 , PCA_WorkMode_PWM_RiseInterrupt = 0x63 , PCA_WorkMode_PWM_FallInterrupt = 0x53 ,
  PCA_WorkMode_PWM_EdgeInterrupt = 0x73 , PCA_WorkMode_CAP_16bitRising = 0x20 , PCA_WorkMode_CAP_16bitFalling = 0x10 , PCA_WorkMode_CAP_16bitEdge = 0x30 ,
  PCA_WorkMode_CAP_16bitTimer = 0x48 , PCA_WorkMode_CAP_16bitPulseOut = 0x4C
}
 
enum  PCA_PWM_Bitwidth_t { PCA_PWM_BitWidth_8 = 0x00 , PCA_PWM_BitWidth_7 = 0x01 , PCA_PWM_BitWidth_6 = 0x02 , PCA_PWM_BitWidth_10 = 0x03 }
 
enum  PCA_AlterPort_t { PCA_AlterPort_P12_P11_P10_P37 = 0x00 , PCA_AlterPort_P34_P35_P36_P37 = 0x01 , PCA_AlterPort_P24_P25_P26_P27 = 0x10 }
 
enum  PCA_AlterPort_G1K08A_t { PCA_AlterPort_G1K08A_P55_P32_P33_P54 = 0x00 , PCA_AlterPort_G1K08A_P55_P31_P33_P54 = 0x01 , PCA_AlterPort_G1K08A_P31_P32_P33_P55 = 0x10 }
 
enum  PCA_AlterPort_G1K08T_t { PCA_AlterPort_G1K08T_P13_P11_P10_P37 = 0x00 , PCA_AlterPort_G1K08T_P34_P35_P36_P37 = 0x01 , PCA_AlterPort_G1K08T_P54_P13_P14_P15 = 0x10 }
 

Macro Definition Documentation

◆ PCA_ClearCounterOverflowInterrupt

#define PCA_ClearCounterOverflowInterrupt ( )    SBIT_RESET(CF)

Definition at line 81 of file fw_pca.h.

◆ PCA_EnableCounterOverflowInterrupt

#define PCA_EnableCounterOverflowInterrupt (   __STATE__)    SFR_ASSIGN(CMOD, 0, __STATE__)

Definition at line 88 of file fw_pca.h.

◆ PCA_PCA0_ChangeCompareValue

#define PCA_PCA0_ChangeCompareValue (   __VALUE__)    (CCAP0H = (__VALUE__))

Change comparison value when running

Definition at line 106 of file fw_pca.h.

◆ PCA_PCA0_ChangeCompareValue10bit

#define PCA_PCA0_ChangeCompareValue10bit (   __VALUE__)
Value:
do{ \
PCA_PWM0 = PCA_PWM0 & ~(0x03 << 4) | (((__VALUE__) >> 4) & 0x30); \
CCAP0H = ((__VALUE__) & 0xFF); \
}while(0)

Change comparison value in running mode Note: set high 2bit first, then low 8bit, the hardware will make sure new 10bit be loaded as a whole number. If you write low bits first, it will introduce glitchnoise.

Definition at line 131 of file fw_pca.h.

◆ PCA_PCA0_ClearInterrupt

#define PCA_PCA0_ClearInterrupt ( )    SBIT_RESET(CCF0)

Definition at line 82 of file fw_pca.h.

◆ PCA_PCA0_SetCompareValue

#define PCA_PCA0_SetCompareValue (   __VALUE__)    do{CCAP0H = (__VALUE__); CCAP0L = (__VALUE__);}while(0)

Set initiale comparison value

Definition at line 100 of file fw_pca.h.

◆ PCA_PCA0_SetCompareValue10bit

#define PCA_PCA0_SetCompareValue10bit (   __VALUE__)
Value:
do{ \
PCA_PWM0 = PCA_PWM0 & ~(0x0F << 2) | (((__VALUE__) >> 4) & 0x30) | (((__VALUE__) >> 6) & 0x0C); \
CCAP0H = ((__VALUE__) & 0xFF); CCAP0L = ((__VALUE__) & 0xFF); \
}while(0)

Set initiale comparison value

Definition at line 113 of file fw_pca.h.

◆ PCA_PCA0_SetWorkMode

#define PCA_PCA0_SetWorkMode (   __MODE__)    (CCAPM0 = (__MODE__))

Definition at line 90 of file fw_pca.h.

◆ PCA_PCA1_ChangeCompareValue

#define PCA_PCA1_ChangeCompareValue (   __VALUE__)    (CCAP1H = (__VALUE__))

Definition at line 107 of file fw_pca.h.

◆ PCA_PCA1_ChangeCompareValue10bit

#define PCA_PCA1_ChangeCompareValue10bit (   __VALUE__)
Value:
do{ \
PCA_PWM1 = PCA_PWM1 & ~(0x03 << 4) | (((__VALUE__) >> 4) & 0x30); \
CCAP1H = ((__VALUE__) & 0xFF); \
}while(0)

Definition at line 135 of file fw_pca.h.

◆ PCA_PCA1_ClearInterrupt

#define PCA_PCA1_ClearInterrupt ( )    SBIT_RESET(CCF1)

Definition at line 83 of file fw_pca.h.

◆ PCA_PCA1_SetCompareValue

#define PCA_PCA1_SetCompareValue (   __VALUE__)    do{CCAP1H = (__VALUE__); CCAP1L = (__VALUE__);}while(0)

Definition at line 101 of file fw_pca.h.

◆ PCA_PCA1_SetCompareValue10bit

#define PCA_PCA1_SetCompareValue10bit (   __VALUE__)
Value:
do{ \
PCA_PWM1 = PCA_PWM1 & ~(0x0F << 2) | (((__VALUE__) >> 4) & 0x30) | (((__VALUE__) >> 6) & 0x0C); \
CCAP1H = ((__VALUE__) & 0xFF); CCAP1L = ((__VALUE__) & 0xFF); \
}while(0)

Definition at line 117 of file fw_pca.h.

◆ PCA_PCA1_SetWorkMode

#define PCA_PCA1_SetWorkMode (   __MODE__)    (CCAPM1 = (__MODE__))

Definition at line 91 of file fw_pca.h.

◆ PCA_PCA2_ChangeCompareValue

#define PCA_PCA2_ChangeCompareValue (   __VALUE__)    (CCAP2H = (__VALUE__))

Definition at line 108 of file fw_pca.h.

◆ PCA_PCA2_ChangeCompareValue10bit

#define PCA_PCA2_ChangeCompareValue10bit (   __VALUE__)
Value:
do{ \
PCA_PWM2 = PCA_PWM2 & ~(0x03 << 4) | (((__VALUE__) >> 4) & 0x30); \
CCAP2H = ((__VALUE__) & 0xFF); \
}while(0)

Definition at line 139 of file fw_pca.h.

◆ PCA_PCA2_ClearInterrupt

#define PCA_PCA2_ClearInterrupt ( )    SBIT_RESET(CCF2)

Definition at line 84 of file fw_pca.h.

◆ PCA_PCA2_SetCompareValue

#define PCA_PCA2_SetCompareValue (   __VALUE__)    do{CCAP2H = (__VALUE__); CCAP2L = (__VALUE__);}while(0)

Definition at line 102 of file fw_pca.h.

◆ PCA_PCA2_SetCompareValue10bit

#define PCA_PCA2_SetCompareValue10bit (   __VALUE__)
Value:
do{ \
PCA_PWM2 = PCA_PWM2 & ~(0x0F << 2) | (((__VALUE__) >> 4) & 0x30) | (((__VALUE__) >> 6) & 0x0C); \
CCAP2H = ((__VALUE__) & 0xFF); CCAP2L = ((__VALUE__) & 0xFF); \
}while(0)

Definition at line 121 of file fw_pca.h.

◆ PCA_PCA2_SetWorkMode

#define PCA_PCA2_SetWorkMode (   __MODE__)    (CCAPM2 = (__MODE__))

Definition at line 92 of file fw_pca.h.

◆ PCA_PWM0_SetBitWidth

#define PCA_PWM0_SetBitWidth (   __BIT_WIDTH__)    (PCA_PWM0 = PCA_PWM0 & ~(0x03 << 6) | ((__BIT_WIDTH__) << 6))

Definition at line 94 of file fw_pca.h.

◆ PCA_PWM1_SetBitWidth

#define PCA_PWM1_SetBitWidth (   __BIT_WIDTH__)    (PCA_PWM1 = PCA_PWM1 & ~(0x03 << 6) | ((__BIT_WIDTH__) << 6))

Definition at line 95 of file fw_pca.h.

◆ PCA_PWM2_SetBitWidth

#define PCA_PWM2_SetBitWidth (   __BIT_WIDTH__)    (PCA_PWM2 = PCA_PWM2 & ~(0x03 << 6) | ((__BIT_WIDTH__) << 6))

Definition at line 96 of file fw_pca.h.

◆ PCA_SetClockSource

#define PCA_SetClockSource (   __SOURCE___)    (CMOD = CMOD & ~(0x07 << 1) | ((__SOURCE___) << 1))

Definition at line 87 of file fw_pca.h.

◆ PCA_SetCounterState

#define PCA_SetCounterState (   __STATE__)    SBIT_ASSIGN(CR, __STATE__)

Definition at line 80 of file fw_pca.h.

◆ PCA_SetPort

#define PCA_SetPort (   __ALTER_PORT__)    (P_SW1 = P_SW1 & ~(0x03 << 4) | ((__ALTER_PORT__) << 4))

Alternative port selection

Definition at line 147 of file fw_pca.h.

◆ PCA_SetStopCounterInIdle

#define PCA_SetStopCounterInIdle (   __STATE__)    SFR_ASSIGN(CMOD, 7, __STATE__)

Definition at line 86 of file fw_pca.h.

Enumeration Type Documentation

◆ PCA_AlterPort_G1K08A_t

Enumerator
PCA_AlterPort_G1K08A_P55_P32_P33_P54 
PCA_AlterPort_G1K08A_P55_P31_P33_P54 
PCA_AlterPort_G1K08A_P31_P32_P33_P55 

Definition at line 63 of file fw_pca.h.

64{
65 // ECI CCP0 CCP1 CCP2
PCA_AlterPort_G1K08A_t
Definition: fw_pca.h:64
@ PCA_AlterPort_G1K08A_P55_P32_P33_P54
Definition: fw_pca.h:66
@ PCA_AlterPort_G1K08A_P31_P32_P33_P55
Definition: fw_pca.h:68
@ PCA_AlterPort_G1K08A_P55_P31_P33_P54
Definition: fw_pca.h:67

◆ PCA_AlterPort_G1K08T_t

Enumerator
PCA_AlterPort_G1K08T_P13_P11_P10_P37 
PCA_AlterPort_G1K08T_P34_P35_P36_P37 
PCA_AlterPort_G1K08T_P54_P13_P14_P15 

Definition at line 71 of file fw_pca.h.

72{
73 // ECI CCP0 CCP1 CCP2
PCA_AlterPort_G1K08T_t
Definition: fw_pca.h:72
@ PCA_AlterPort_G1K08T_P34_P35_P36_P37
Definition: fw_pca.h:75
@ PCA_AlterPort_G1K08T_P54_P13_P14_P15
Definition: fw_pca.h:76
@ PCA_AlterPort_G1K08T_P13_P11_P10_P37
Definition: fw_pca.h:74

◆ PCA_AlterPort_t

Enumerator
PCA_AlterPort_P12_P11_P10_P37 
PCA_AlterPort_P34_P35_P36_P37 
PCA_AlterPort_P24_P25_P26_P27 

Definition at line 55 of file fw_pca.h.

56{
57 // ECI CCP0 CCP1 CCP2
PCA_AlterPort_t
Definition: fw_pca.h:56
@ PCA_AlterPort_P12_P11_P10_P37
Definition: fw_pca.h:58
@ PCA_AlterPort_P34_P35_P36_P37
Definition: fw_pca.h:59
@ PCA_AlterPort_P24_P25_P26_P27
Definition: fw_pca.h:60

◆ PCA_ClockSource_t

Enumerator
PCA_ClockSource_SysClkDiv12 
PCA_ClockSource_SysClkDiv2 
PCA_ClockSource_Timer0Overflow 
PCA_ClockSource_ExtClock 
PCA_ClockSource_SysClk 
PCA_ClockSource_SysClkDiv4 
PCA_ClockSource_SysClkDiv6 
PCA_ClockSource_SysClkDiv8 

Definition at line 21 of file fw_pca.h.

22{
PCA_ClockSource_t
Definition: fw_pca.h:22
@ PCA_ClockSource_SysClk
Definition: fw_pca.h:27
@ PCA_ClockSource_SysClkDiv12
Definition: fw_pca.h:23
@ PCA_ClockSource_Timer0Overflow
Definition: fw_pca.h:25
@ PCA_ClockSource_SysClkDiv4
Definition: fw_pca.h:28
@ PCA_ClockSource_SysClkDiv8
Definition: fw_pca.h:30
@ PCA_ClockSource_ExtClock
Definition: fw_pca.h:26
@ PCA_ClockSource_SysClkDiv2
Definition: fw_pca.h:24
@ PCA_ClockSource_SysClkDiv6
Definition: fw_pca.h:29

◆ PCA_PWM_Bitwidth_t

Enumerator
PCA_PWM_BitWidth_8 
PCA_PWM_BitWidth_7 
PCA_PWM_BitWidth_6 
PCA_PWM_BitWidth_10 

Definition at line 47 of file fw_pca.h.

48{
49 PCA_PWM_BitWidth_8 = 0x00, // {EPCnH, CCAPnH[7:0]} {EPCnL, CCAPnL[7:0]}
50 PCA_PWM_BitWidth_7 = 0x01, // {EPCnH, CCAPnH[6:0]} {EPCnL, CCAPnL[6:0]}
51 PCA_PWM_BitWidth_6 = 0x02, // {EPCnH, CCAPnH[5:0]} {EPCnL, CCAPnL[5:0]}
52 PCA_PWM_BitWidth_10 = 0x03, // {EPCnH, XCCAPnH[1:0], CCAPnH[7:0]} {EPCnL, XCCAPnL[1:0], CCAPnL[7:0]}
PCA_PWM_Bitwidth_t
Definition: fw_pca.h:48
@ PCA_PWM_BitWidth_7
Definition: fw_pca.h:50
@ PCA_PWM_BitWidth_6
Definition: fw_pca.h:51
@ PCA_PWM_BitWidth_8
Definition: fw_pca.h:49
@ PCA_PWM_BitWidth_10
Definition: fw_pca.h:52

◆ PCA_WorkMode_t

Enumerator
PCA_WorkMode_None 
PCA_WorkMode_PWM_NonInterrupt 
PCA_WorkMode_PWM_RiseInterrupt 
PCA_WorkMode_PWM_FallInterrupt 
PCA_WorkMode_PWM_EdgeInterrupt 
PCA_WorkMode_CAP_16bitRising 
PCA_WorkMode_CAP_16bitFalling 
PCA_WorkMode_CAP_16bitEdge 
PCA_WorkMode_CAP_16bitTimer 
PCA_WorkMode_CAP_16bitPulseOut 

Definition at line 33 of file fw_pca.h.

34{
35 PCA_WorkMode_None = 0x00, // n/a
36 PCA_WorkMode_PWM_NonInterrupt = 0x42, // 6/7/8/10-bit PWM, no interrupt
37 PCA_WorkMode_PWM_RiseInterrupt = 0x63, // 6/7/8/10-bit PWM, rising interrupt
38 PCA_WorkMode_PWM_FallInterrupt = 0x53, // 6/7/8/10-bit PWM, falling interrupt
39 PCA_WorkMode_PWM_EdgeInterrupt = 0x73, // 6/7/8/10-bit PWM, both edge interrupt
40 PCA_WorkMode_CAP_16bitRising = 0x20, // 16-bit Capture Mode, capture triggered by rising edge on CCPn/PCAn
41 PCA_WorkMode_CAP_16bitFalling = 0x10, // 16-bit Capture Mode, capture triggered by falling edge on CCPn/PCAn
42 PCA_WorkMode_CAP_16bitEdge = 0x30, // 16-bit Capture Mode, capture triggered by both edge on CCPn/PCAn
43 PCA_WorkMode_CAP_16bitTimer = 0x48, // 16-bit software timer
44 PCA_WorkMode_CAP_16bitPulseOut = 0x4C, // 16-bit high-speed pulse output
PCA_WorkMode_t
Definition: fw_pca.h:34
@ PCA_WorkMode_None
Definition: fw_pca.h:35
@ PCA_WorkMode_CAP_16bitTimer
Definition: fw_pca.h:43
@ PCA_WorkMode_PWM_EdgeInterrupt
Definition: fw_pca.h:39
@ PCA_WorkMode_CAP_16bitPulseOut
Definition: fw_pca.h:44
@ PCA_WorkMode_CAP_16bitEdge
Definition: fw_pca.h:42
@ PCA_WorkMode_PWM_NonInterrupt
Definition: fw_pca.h:36
@ PCA_WorkMode_PWM_FallInterrupt
Definition: fw_pca.h:38
@ PCA_WorkMode_CAP_16bitRising
Definition: fw_pca.h:40
@ PCA_WorkMode_PWM_RiseInterrupt
Definition: fw_pca.h:37
@ PCA_WorkMode_CAP_16bitFalling
Definition: fw_pca.h:41