Hello,
I need to output a clock signal in the range 8-20Mhz from the IO15 of an ESP32-S3. I had this function previously on ESP32-WROOM using ledc but now discover that ESP32-S3 does not support LEDC_HIGH_SPEED_MODE and the maximum output frequency I get is 16KHz.
However there are peripheral (such as LCD panels) which requires MHz clocks. Is there a way to drive such clock from the internal clock tree to a device pin?
High Frequency (MHz) clock output from ESP32-S3
-
- Posts: 9
- Joined: Thu Aug 31, 2023 1:01 pm
-
- Posts: 9764
- Joined: Thu Nov 26, 2015 4:08 am
Re: High Frequency (MHz) clock output from ESP32-S3
First of all, HIGH_SPEED_MODE refers to the capability to reload the value register automatically; there's no difference in frequency capabilities between the high-speed and low-speed channels of the LEDC in that respect. The -S3 loses that distinction entirely because the peripheral was re-architected a bit: in effect, all -S3 channels are LEDC_HIGH_SPEED_MODE ones.BinaryPoet wrote: ↑Wed May 22, 2024 11:38 amESP32-S3 does not support LEDC_HIGH_SPEED_MODE and the maximum output frequency I get is 16KHz.
Aside from that, the -S3 LEDC should be capable of generating up to at least 20MHz, possibly 40MHz. Can you post how you're configuring that peripheral?
-
- Posts: 9
- Joined: Thu Aug 31, 2023 1:01 pm
Re: High Frequency (MHz) clock output from ESP32-S3
Thank you for your reply, ESP_Sprite.
Here my code:
UPDATE: Now I am able to get 20MHz with the following changes:
and
20MHz should be OK. I tried to get 16MHz but I was not able go get a regular output since it looks impossible to set the duty cycle to 50% with only 1 bit resolution. Is there a way to output a regular 8MHz clock from LEDC_USE_RC_FAST_CLK?
This comforts me. Yesterday the frequency limit was 16KHz today I am not able to output more than 5KHz. The goal is 16MHz.ESP_Sprite wrote: Aside from that, the -S3 LEDC should be capable of generating up to at least 20MHz, possibly 40MHz. Can you post how you're configuring that peripheral?
Here my code:
Code: Select all
#define STEPPER_CLK_FREQUENCY (16000)
#define STEPPER_CLK_MODE LEDC_LOW_SPEED_MODE
#define STEPPER_CLK_TIMER LEDC_TIMER_0
#define STEPPER_CLK_RESOLUTION LEDC_TIMER_2_BIT
#define STEPPER_CLK_CHANNEL LEDC_CHANNEL_1
#define STEPPER_CLK_OUTPUT_IO (15)
#define STEPPER_DUTY (2)
static void stepperCLK_init(void)
{
// Prepare and then apply the LEDC PWM timer configuration
ledc_timer_config_t stepperCLK_timer = {
.speed_mode = STEPPER_CLK_MODE,
.timer_num = STEPPER_CLK_TIMER,
.duty_resolution = LEDC_TIMER_2_BIT,
.freq_hz = STEPPER_CLK_FREQUENCY,
.clk_cfg = LEDC_AUTO_CLK
};
ESP_ERROR_CHECK(ledc_timer_config(&stepperCLK_timer));
// Prepare and then apply the LEDC PWM channel configuration
ledc_channel_config_t ledc_channel_clkout = {
.speed_mode = STEPPER_CLK_MODE,
.channel = STEPPER_CLK_CHANNEL,
.timer_sel = STEPPER_CLK_TIMER,
.intr_type = LEDC_INTR_DISABLE,
.gpio_num = STEPPER_CLK_OUTPUT_IO,
.duty = 0, // Set duty to 0%
.hpoint = 0
};
ESP_ERROR_CHECK(ledc_channel_config(&ledc_channel_clkout));
}
void StepperClkEnable(bool en)
{
if (en)
{
ESP_ERROR_CHECK(ledc_set_duty(LEDC_MODE, STEPPER_CLK_CHANNEL, STEPPER_DUTY));
}
else
{
ESP_ERROR_CHECK(ledc_set_duty(LEDC_MODE, STEPPER_CLK_CHANNEL, 0));
}
}
Code: Select all
[b]#define STEPPER_CLK_FREQUENCY (20*1000*1000)[/b]
#define STEPPER_CLK_MODE LEDC_LOW_SPEED_MODE
#define STEPPER_CLK_TIMER LEDC_TIMER_0
[b]#define STEPPER_CLK_RESOLUTION LEDC_TIMER_1_BIT[/b]
#define STEPPER_CLK_CHANNEL LEDC_CHANNEL_1
#define STEPPER_CLK_OUTPUT_IO (15)
[b]#define STEPPER_DUTY (1)[/b]
Code: Select all
ledc_timer_config_t stepperCLK_timer = {
.speed_mode = STEPPER_CLK_MODE,
.timer_num = STEPPER_CLK_TIMER,
.duty_resolution = STEPPER_CLK_RESOLUTION,
.freq_hz = STEPPER_CLK_FREQUENCY,
[b] .clk_cfg = LEDC_USE_XTAL_CLK[/b]
};
-
- Posts: 9764
- Joined: Thu Nov 26, 2015 4:08 am
Re: High Frequency (MHz) clock output from ESP32-S3
No, I think the fast RTC clock is 17.something MHz, so that doesn't divide cleanly into 8MHz. If you use the APB or Xtal clock as a source, you should be able to get 8MHz as both are multiples of that.BinaryPoet wrote: ↑Thu May 23, 2024 7:10 am20MHz should be OK. I tried to get 16MHz but I was not able go get a regular output since it looks impossible to set the duty cycle to 50% with only 1 bit resolution. Is there a way to output a regular 8MHz clock from LEDC_USE_RC_FAST_CLK?
Who is online
Users browsing this forum: No registered users and 168 guests