![]() |
MAX32650 Peripheral Driver API
Peripheral Driver API for the MAX32650
|
Modules | |
PT_Registers | |
Data Structures | |
struct | mxc_pt_cfg_t |
Enumerations | |
enum | mxc_clk_scale_t |
Functions | |
void | MXC_PT_Init (mxc_ptg_regs_t *ptg, mxc_clk_scale_t clk_scale) |
void | MXC_PT_Shutdown (mxc_ptg_regs_t *ptg, uint32_t pts) |
int | MXC_PT_Config (mxc_ptg_regs_t *ptg, mxc_pt_cfg_t *cfg) |
int | MXC_PT_SqrWaveConfig (mxc_ptg_regs_t *ptg, unsigned channel, uint32_t freq, uint8_t outputSelect) |
void | MXC_PT_Start (mxc_ptg_regs_t *ptg, unsigned pts) |
void | MXC_PT_Stop (mxc_ptg_regs_t *ptg, unsigned pts) |
uint32_t | MXC_PT_IsActive (mxc_ptg_regs_t *ptg, uint32_t pts) |
void | MXC_PT_SetPattern (unsigned pts, uint32_t pattern) |
void | MXC_PT_EnableInt (mxc_ptg_regs_t *ptg, uint32_t pts) |
void | MXC_PT_DisableInt (mxc_ptg_regs_t *ptg, uint32_t pts) |
uint32_t | MXC_PT_GetFlags (mxc_ptg_regs_t *ptg) |
void | MXC_PT_ClearFlags (mxc_ptg_regs_t *ptg, uint32_t flags) |
void | MXC_PT_EnableRestart (unsigned start, unsigned stop, uint8_t restartIndex) |
void | MXC_PT_DisableRestart (unsigned channel, uint8_t restartIndex) |
void | MXC_PT_Resync (mxc_ptg_regs_t *ptg, uint32_t pts) |
This is the high level API for the pulse train engine.
struct mxc_pt_cfg_t |
Structure type for pulse train mode configuration.
Data Fields | |
unsigned | channel |
uint32_t | bps |
uint32_t | pattern |
uint8_t | ptLength |
uint16_t | loop |
uint16_t | loopDelay |
uint8_t | outputSelect |
uint32_t bps |
pulse train bit rate
unsigned channel |
PT Channel to use
uint16_t loop |
Number of times to repeat the train, 0 = continuous
uint16_t loopDelay |
Delay between loops specified in multiples of bps
uint8_t outputSelect |
Select 0 or 1. See pins_me10.c for the pin selection for each channel. Note: not all selections valid depending on package type (See UG section 5.2).
uint32_t pattern |
Output pattern to shift out, starts at LSB
uint8_t ptLength |
Number of bits in pulse train, 0 = 32bits, 1 = non valid , 2 = 2 bits, ...
void MXC_PT_ClearFlags | ( | mxc_ptg_regs_t * | ptg, |
uint32_t | flags | ||
) |
Clears the pulse train's interrupt flag.
ptg | pointer to pulse train global bus to use. |
flags | bits to clear, see PTG_INTFL Register for details. |
int MXC_PT_Config | ( | mxc_ptg_regs_t * | ptg, |
mxc_pt_cfg_t * | cfg | ||
) |
Configures the pulse train in the specified mode.
The parameters in the config structure must be set before calling this function. This function should be used for configuring pulse train mode only.
ptg | Pointer to pulse train global bus to use. |
cfg | Pointer to pulse train configuration. |
void MXC_PT_DisableInt | ( | mxc_ptg_regs_t * | ptg, |
uint32_t | pts | ||
) |
Disable pulse train interrupt.
ptg | Pointer to pulse train global bus to use. |
pts | Bit mask of what pulse trains to disable. Set the bit position of each pulse train to disable it. Bit0->pt0, Bit1->pt1... etc, 1 will disable the interrupt, 0 to leave a PT channel in its current state. |
void MXC_PT_DisableRestart | ( | unsigned | channel, |
uint8_t | restartIndex | ||
) |
Disable the restart for the specified pulse train.
channel | Pulse train channel to disable restart for. |
restartIndex | selects which restart trigger to disable, 0 (x) or 1 (y). |
void MXC_PT_EnableInt | ( | mxc_ptg_regs_t * | ptg, |
uint32_t | pts | ||
) |
Enable pulse train interrupt.
ptg | Pointer to pulse train global bus to use. |
pts | Bit mask of which pulse trains to enable. Set the bit position of each pulse train to enable it. Bit0->pt0, Bit1->pt1... etc, 1 will enable the interrupt, 0 to leave a PT channel in its current state. |
void MXC_PT_EnableRestart | ( | unsigned | start, |
unsigned | stop, | ||
uint8_t | restartIndex | ||
) |
Setup and enables a pulse train to restart after another pulse train has exited its loop. Each pulse train can have up to two restart triggers.
start | Pulse train channel to start on the stop event. |
stop | Pulse train channel to trigger the stop event. |
restartIndex | selects which restart trigger to set, 0 (x) or 1 (y). |
uint32_t MXC_PT_GetFlags | ( | mxc_ptg_regs_t * | ptg | ) |
Gets the pulse trains's interrupt flags.
ptg | Pointer to pulse train global bus to use. |
void MXC_PT_Init | ( | mxc_ptg_regs_t * | ptg, |
mxc_clk_scale_t | clk_scale | ||
) |
This function initializes the pulse trains to a known stopped state and sets the global PT clock scale.
ptg | pointer to pulse train global bus to use. |
clk_scale | Scale the system clock for the global PT clock. |
uint32_t MXC_PT_IsActive | ( | mxc_ptg_regs_t * | ptg, |
uint32_t | pts | ||
) |
Determines if the pulse train is running.
ptg | Pointer to pulse train global bus to use. |
pts | Set the bits of pulse trains to check Bit0->pt0, Bit1->pt1... etc. |
void MXC_PT_Resync | ( | mxc_ptg_regs_t * | ptg, |
uint32_t | pts | ||
) |
Resynchronize individual pulse trains together. Resync will stop those resync_pts; others will be still running.
ptg | pointer to pulse train global bus to use. |
pts | pulse train modules that need to be re-synced by bit number. Bit0->pt0, Bit1->pt1... etc. |
void MXC_PT_SetPattern | ( | unsigned | pts, |
uint32_t | pattern | ||
) |
Sets the pattern of the pulse train.
pts | Pulse train pts to operate on. |
pattern | Output pattern. |
void MXC_PT_Shutdown | ( | mxc_ptg_regs_t * | ptg, |
uint32_t | pts | ||
) |
Shutdown the pulse train channel/channels.
Shutdown pulse train and if all pluse trains are shut down then turn off pulse train clock.
ptg | Pointer to pulse train global bus to use. |
pts | Pulse train channel to operate on. |
int MXC_PT_SqrWaveConfig | ( | mxc_ptg_regs_t * | ptg, |
unsigned | channel, | ||
uint32_t | freq, | ||
uint8_t | outputSelect | ||
) |
Configures the pulse train in the square wave mode.
This function should be used for configuring square wave mode only.
ptg | Pointer to pulse train global bus to use. |
channel | Pulse train channel to operate on |
freq | Square wave output frequency in Hz |
outputSelect | Select the output to route the pulse train channel to. 0 for output 0, non-zero for output 1. |
void MXC_PT_Start | ( | mxc_ptg_regs_t * | ptg, |
unsigned | pts | ||
) |
Starts the pulse train specified.
ptg | Pointer to pulse train global bus to use. |
pts | Pulse train pts to start. Set the bits of pulse trains to check Bit0->pt0, Bit1->pt1... etc. |
void MXC_PT_Stop | ( | mxc_ptg_regs_t * | ptg, |
unsigned | pts | ||
) |
Stops a pulse train.
ptg | Pointer to pulse train global bus to use. |
pts | Pulse train pts to stop. Set the bits of pulse trains to check Bit0->pt0, Bit1->pt1... etc. |