25.8.4.1.3 Workflow
- Create a module software instance structure for the TCC module to store the TCC driver state while it is in use.
structtcc_module tcc_instance;Note: This should never go out of scope as long as the module is in use. In most cases, this should be global. - Configure the TCC module.
- Create a TCC module configuration struct, which can be filled out to adjust the configuration of a physical TCC peripheral.
structtcc_config config_tcc; - Initialize the TCC configuration struct with the module's default values.
tcc_get_config_defaults(&config_tcc, CONF_PWM_MODULE);Note: This should always be performed before using the configuration struct to ensure that all values are initialized to known default settings. - Alter the TCC settings to configure the counter width, wave generation mode and the compare channel 0 value.
config_tcc.counter.period = 0xFFFF;config_tcc.compare.wave_generation = TCC_WAVE_GENERATION_SINGLE_SLOPE_PWM;config_tcc.compare.match[CONF_PWM_CHANNEL] = 0xFFFF; - Alter the TCC settings to configure the PWM output on a physical device pin.
config_tcc.pins.enable_wave_out_pin[CONF_PWM_OUTPUT] =true;config_tcc.pins.wave_out_pin[CONF_PWM_OUTPUT] = CONF_PWM_OUT_PIN;config_tcc.pins.wave_out_pin_mux[CONF_PWM_OUTPUT] = CONF_PWM_OUT_MUX; - Configure the TCC module with the desired settings.
tcc_init(&tcc_instance, CONF_PWM_MODULE, &config_tcc); - Enable the TCC module to start the timer and begin PWM signal generation.
tcc_enable(&tcc_instance);
- Configure the TCC callbacks.
- Register the Compare Channel 0 Match callback functions with the driver.
tcc_register_callback(&tcc_instance,tcc_callback_to_change_duty_cycle,(enumtcc_callback)(TCC_CALLBACK_CHANNEL_0 + CONF_PWM_CHANNEL)); - Enable the Compare Channel 0 Match callback so that it will be called by the driver when appropriate.
tcc_enable_callback(&tcc_instance,(enumtcc_callback)(TCC_CALLBACK_CHANNEL_0 + CONF_PWM_CHANNEL));
