mikrokontrollersystemer-pro.../prosjekt.X/fan_speeeed.c

108 lines
3.1 KiB
C
Raw Normal View History

2024-04-25 12:06:51 +00:00
//#include <avr/ioavr128db48.h>
2024-04-25 10:29:10 +00:00
2024-03-20 14:27:59 +00:00
#include "fan_speeeed.h"
2024-04-09 13:39:11 +00:00
#include "uart.h"
uint16_t timer_period_ms = 1;
uint16_t fan_speed;
volatile uint16_t falling_edge_counter = 0;
2024-04-21 10:43:51 +00:00
#define MAX_PER 0x50
2024-04-26 15:00:04 +00:00
2024-04-24 12:24:40 +00:00
void init_TCA0() {
2024-04-21 10:43:51 +00:00
//code
2024-04-26 15:00:04 +00:00
// PORTMUX.TCAROUTEA = PORTMUX_TCA0_PORTD_gc;
2024-04-21 10:43:51 +00:00
// port d ??? why
2024-04-26 15:00:04 +00:00
//PORTD.DIR = PIN0_bm;
2024-04-21 10:43:51 +00:00
//code
//TCA0.SINGLE.PERBUF = MAX_PER;
2024-04-26 15:00:04 +00:00
//TCA0.SINGLE.PERBUF = (F_CPU * (1 / timer_period_ms) / 1024); /* F_CPU * F_IRQ / TCA_prescaler */
//TCA0.SINGLE.CMP0BUF = MAX_PER/2;
//TCA0.SINGLE.CTRLB = TCA_SINGLE_CMP0EN_bm | 0x03;
//TCA0.SINGLE.CTRLA = TCA_SINGLE_CLKSEL_DIV1_gc | TCA_SINGLE_ENABLE_bm;
2024-04-21 10:43:51 +00:00
//TCA0.SINGLE.INTCTRL = TCA_SINGLE_OVF_bm;
//TCA0.SINGLE.CTRLA = TCA_SINGLE_ENABLE_bm | TCA_SINGLE_CLKSEL_DIV1024_gc; /* Sysclk /1024 */
//TCA0_update_period_ms();
2024-04-26 15:00:04 +00:00
TCA0.SINGLE.INTCTRL = TCA_SINGLE_OVF_bm ;
TCA0.SINGLE.CTRLA = TCA_SINGLE_ENABLE_bm | TCA_SINGLE_CLKSEL_DIV1024_gc ; /* Sysclk /1024 */
TCA0.SINGLE.PERBUF = 3906;
//TCA0_update_period_ms();
2024-04-09 12:53:32 +00:00
}
2024-03-20 11:33:03 +00:00
2024-04-09 12:53:32 +00:00
void TCA0_update_period_ms() {
2024-04-21 10:43:51 +00:00
TCA0.SINGLE.PERBUF = (F_CPU * (1 / timer_period_ms) / 1024); /* F_CPU * F_IRQ / TCA_prescaler */
2024-03-20 11:33:03 +00:00
}
2024-04-09 12:53:32 +00:00
2024-04-26 15:00:04 +00:00
uint16_t RPM_calculation(uint16_t time) {
printf("time: %u", time);
fan_speed = (falling_edge_counter / time);
fan_speed = fan_speed/2;
fan_speed = fan_speed * 60/5;
printf("falling edge: %u", falling_edge_counter);
2024-04-21 10:43:51 +00:00
falling_edge_counter = 0;
2024-04-26 15:00:04 +00:00
printf("falling edge: ", falling_edge_counter);
printf("fanspeed %u \n", fan_speed);
2024-03-20 11:33:03 +00:00
return fan_speed;
}
2024-04-21 10:43:51 +00:00
void PORTB_init() {
PORTA.OUTSET |= PIN5_bm;
PORTA.DIRSET |= PIN5_bm;
2024-04-16 11:25:51 +00:00
}
2024-04-25 10:29:10 +00:00
2024-04-25 12:06:51 +00:00
void init_ac0(){
2024-04-25 10:29:10 +00:00
// CONFIGURE PINS AS ANALOG INPUTS
2024-04-26 15:00:04 +00:00
PORTD.DIRSET &= ~PIN6_bm;
2024-04-26 13:13:45 +00:00
PORTD.PIN6CTRL &= ~ PORT_ISC_gm;
2024-04-25 12:06:51 +00:00
PORTD.PIN6CTRL = PORT_ISC_INPUT_DISABLE_gc;
2024-04-25 10:29:10 +00:00
2024-04-26 15:00:04 +00:00
PORTD.DIRSET &= ~PIN7_bm;
2024-04-25 12:06:51 +00:00
PORTD.PIN7CTRL &= ~ PORT_ISC_gm ;
PORTD.PIN7CTRL = PORT_ISC_INPUT_DISABLE_gc;
2024-04-25 10:29:10 +00:00
2024-04-26 15:00:04 +00:00
PORTD.DIRSET &= PIN3_bm;
2024-04-26 13:13:45 +00:00
PORTD.PIN3CTRL &= ~ PORT_ISC_gm ;
PORTD.PIN3CTRL = PORT_ISC_INPUT_DISABLE_gc;
2024-04-25 12:06:51 +00:00
//Wincontroll disabled
AC0.CTRLB = 0x00;
2024-04-25 10:29:10 +00:00
2024-04-25 12:06:51 +00:00
//SELECT POSITIVE AND NEGATIVE INPUTS FOR COMPARRISON
// FAN USE PD6 & PD7, COMPARE WITH PD3
2024-04-26 13:13:45 +00:00
AC0.MUXCTRL = AC_MUXPOS_AINP3_gc | AC_MUXNEG_AINN0_gc;
2024-04-26 15:00:04 +00:00
//AC_MUXPOS_AINP1_gc
2024-04-25 10:29:10 +00:00
// OPTIONAL: ENABLE INNPUT PIN BY WRITING "1" TO OUTEN
2024-04-25 12:06:51 +00:00
//AC0.CTRLA = 0x40; // 0b01000000
2024-04-25 10:29:10 +00:00
// ENABLE AC BY WRITING 1 TO ENABLE BIT IN ACN.CTRLA
2024-04-26 15:00:04 +00:00
//AC0.CTRLA |= PIN0_bm; // 0b00000001
AC0.CTRLA = AC_ENABLE_bm | AC_INTMODE_NORMAL_POSEDGE_gc | AC_OUTEN_bm;
2024-04-25 10:29:10 +00:00
2024-04-26 15:00:04 +00:00
// TURN ON INTERUPT
2024-04-25 10:29:10 +00:00
AC0.INTCTRL = 0x01;
}
2024-04-26 13:13:45 +00:00
2024-04-25 10:29:10 +00:00
ISR(AC0_AC_vect){ // AC0 vec flag
2024-04-26 13:47:02 +00:00
cli();
2024-04-26 13:20:28 +00:00
falling_edge_counter++;
2024-04-26 15:00:04 +00:00
AC0.STATUS |= 0x10; //CMP flag to 0.
2024-04-26 13:13:45 +00:00
//printf("yo");
2024-04-26 13:47:02 +00:00
sei();
2024-04-25 10:29:10 +00:00
}
2024-04-24 12:24:40 +00:00
2024-04-26 13:47:02 +00:00
ISR (TCA0_OVF_vect) {
cli();
2024-04-26 15:00:04 +00:00
RPM_calculation(1);
2024-04-26 13:47:02 +00:00
TCA0.SINGLE.INTFLAGS = TCA_SINGLE_OVF_bm ;
sei();
}
2024-04-26 13:20:28 +00:00
2024-04-16 11:25:51 +00:00
//-----------------------------------------------------------------------------------------------------
//-------------------------------------- S E T U P-----------------------------------------------------
2024-03-20 11:33:03 +00:00