Estoy aprendiendo a usar un Attiny84. He generado una señal pwm rápida. Me las arreglé para entender cómo hacer esto:
#include <avr/io.h>
int main(void)
{
// setup timer0
TCCR0B |= _BV(CS00); // use clk_i/O without prescalers as clock source.
// also enables TIMER0
// set fast PWM mode
TCCR0A |= _BV(WGM01) | _BV(WGM00); // Mode 3
TCCR0A |= _BV(COM0A1) | _BV(COM0A0); // set OC0A on compare match, clear on BOTTOM
OCR0A = 0xff / 2; // 50% PWM
// set PB2 as output. This should enable OC0A
DDRB |= _BV(PB2);
for (;;) {
}
}
Sin embargo, no entiendo por qué solo obtuve ~30kHz en el osciloscopio. Deshabilité el fusible CKDIV8 y configuré mi CKSEL en "Oscilador RC interno calibrado de 8 MHz".
Pensé que podría tener al menos una frecuencia PWM de 8MHz. No puedo encontrar en la documentación cómo se relacionan clk_i/o y clk_cpu. ¿Hay alguna forma de obtener una frecuencia PWM más alta?
NB: no necesito tener una frecuencia PWM en particular, solo estoy probando el chip y tratando de comprender sus límites.
Tienes un reloj de 8 MHz, pero PWM de 8 bits. Esto da como resultado una frecuencia de salida de 8 MHz/256 = 31,25 kHz. Si necesita una frecuencia de salida más alta, puede usar el modo 7 en su lugar, a costa de la profundidad de la señal PWM.