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"
|
2024-03-20 14:25:59 +00:00
|
|
|
|
2024-04-09 14:17:34 +00:00
|
|
|
uint16_t timer_period_ms = 1;
|
|
|
|
|
uint16_t fan_speed;
|
2024-04-27 15:26:35 +00:00
|
|
|
volatile uint16_t falling_edge_counter_1 = 0;
|
|
|
|
|
volatile uint16_t falling_edge_counter_2 = 0;
|
2024-04-21 10:43:51 +00:00
|
|
|
#define MAX_PER 0x50
|
2024-04-09 14:17:34 +00:00
|
|
|
|
2024-04-26 15:00:04 +00:00
|
|
|
|
2024-04-24 12:24:40 +00:00
|
|
|
void init_TCA0() {
|
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-27 15:26:35 +00:00
|
|
|
uint16_t RPM_calculation(uint16_t fancounter, uint16_t time) {
|
2024-04-26 15:00:04 +00:00
|
|
|
printf("time: %u", time);
|
2024-04-27 15:26:35 +00:00
|
|
|
fan_speed = (fancounter / time);
|
2024-04-26 15:00:04 +00:00
|
|
|
fan_speed = fan_speed/2;
|
|
|
|
|
fan_speed = fan_speed * 60/5;
|
2024-04-27 15:26:35 +00:00
|
|
|
printf("falling edge: %u", fancounter);
|
|
|
|
|
fancounter = 0;
|
|
|
|
|
printf("falling edge: ", fancounter);
|
2024-04-26 15:00:04 +00:00
|
|
|
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
|
|
|
|
2024-04-27 15:26:35 +00:00
|
|
|
void init_fanports() {
|
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-27 15:26:35 +00:00
|
|
|
PORTD.DIRSET &= ~PIN4_bm;
|
|
|
|
|
PORTD.PIN4CTRL &= ~ PORT_ISC_gm ;
|
|
|
|
|
PORTD.PIN4CTRL = PORT_ISC_INPUT_DISABLE_gc;
|
|
|
|
|
|
|
|
|
|
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-27 15:26:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void init_ac0_fan1(){
|
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-27 15:26:35 +00:00
|
|
|
AC0.MUXCTRL = AC_MUXPOS_AINP3_gc | AC_MUXNEG_AINN2_gc;
|
2024-04-26 15:00:04 +00:00
|
|
|
//AC_MUXPOS_AINP1_gc
|
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 = 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-27 15:26:35 +00:00
|
|
|
void init_ac1_fan2(){
|
|
|
|
|
//Wincontroll disabled
|
|
|
|
|
AC1.CTRLB = 0x00;
|
|
|
|
|
|
|
|
|
|
//SELECT POSITIVE AND NEGATIVE INPUTS FOR COMPARRISON
|
|
|
|
|
// FAN USE PD6 & PD7, COMPARE WITH PD3
|
|
|
|
|
AC1.MUXCTRL = AC_MUXPOS_AINP2_gc | AC_MUXNEG_AINN2_gc;
|
|
|
|
|
|
|
|
|
|
// ENABLE AC BY WRITING 1 TO ENABLE BIT IN ACN.CTRLA
|
|
|
|
|
AC1.CTRLA = AC_ENABLE_bm | AC_INTMODE_NORMAL_POSEDGE_gc | AC_OUTEN_bm;
|
|
|
|
|
|
|
|
|
|
// TURN ON INTERUPT
|
|
|
|
|
AC1.INTCTRL = 0x01;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
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-27 15:26:35 +00:00
|
|
|
falling_edge_counter_1++;
|
|
|
|
|
printf("ac0");
|
|
|
|
|
AC0.STATUS |= 0x10; //CMP flag to 0
|
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-27 15:26:35 +00:00
|
|
|
|
|
|
|
|
ISR(AC1_AC_vect){ // AC0 vec flag
|
|
|
|
|
cli();
|
|
|
|
|
falling_edge_counter_2++;
|
|
|
|
|
printf("ac1");
|
|
|
|
|
AC1.STATUS |= 0x10; //CMP flag to 0
|
|
|
|
|
sei();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2024-04-26 13:47:02 +00:00
|
|
|
ISR (TCA0_OVF_vect) {
|
|
|
|
|
cli();
|
2024-04-27 15:26:35 +00:00
|
|
|
|
|
|
|
|
printf("fan1");
|
|
|
|
|
RPM_calculation(falling_edge_counter_1,1);
|
|
|
|
|
printf("fan2");
|
|
|
|
|
RPM_calculation(falling_edge_counter_2,1);
|
|
|
|
|
falling_edge_counter_1 = 0;
|
|
|
|
|
falling_edge_counter_2 = 0;
|
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
|
|
|
|