/* * geigerzaehler.c * * Created : 28.02.2019 09:07:22 * Author : John Ditgens, Alexander Brandscheidt * Git-Repository : https://gitea.Railduction.eu/JohnD/Geigerzaehler.git * * MController : AtMega328P * Board : Arduino Nano */ #define F_CPU 16000000UL // Clock speed: 16 MHz - Speed from onboard oscillator // Macros #define bit_get(p,m) ((p) & (m)) #define bit_set(p,m) ((p) |= (m)) #define bit_clear(p,m) ((p) &= ~(m)) #define bit_flip(p,m) ((p) ^= (m)) #define bit_write(c,p,m) (c ? bit_set(p,m) : bit_clear(p,m)) #define BIT(x) (0x01 << (x)) #define LONGBIT(x) ((unsigned long)0x00000001 << (x)) // Imports #include #include #include #include // Global variable declaration uint16_t boost_frequency = 2000; // 2kHz frequency bool boost_enable = false; bool boost_highVoltage_nextHigh = true; clock_t boost_highVoltage_nextTick = 0; bool signalOutput_enable = false; bool signalOutput_nextHigh = true; clock_t signalOutput_nextTick = 0; int main() { DDRD &= ~(1<<2); // Activate input PD2 DDRD &= ~(1<<3); // Activate input PD3 PORTD |= (1<<2); // Enable pull-up-resistor D2 PORTD |= (1<<3); // Enable pull-up-resistor D3 // Interrupt for INT0 Pin-D2 High-voltage check EICRA |= (0 << ISC01)|(1 << ISC00); // On at any edge [Code: 01] EIMSK |= (1 << INT0); // Activate Interrupt INT0 // Interrupt for INT1 Pin-D3 Counter-click EICRA |= (1 << ISC11)|(1 << ISC10); // On rising edge [Code: 11] EIMSK |= (1 <= boost_highVoltage_nextTick) // If we are on or after the tick it should be executed { // Set pin according to next exec if(boost_highVoltage_nextHigh) // Set it high { bit_set(PD4, 1); boost_highVoltage_nextHigh = false; // Next is low } else // Set it low { bit_set(PD4, 0); boost_highVoltage_nextHigh = true; // Next is high } // Calculate when next high/low should be set boost_highVoltage_nextTick = clock() + F_CPU * 1/(boost_frequency/2) // Half of time it should be high/low } }else { if(boost_highVoltage_nextTick > 0) // If boosting is deactivated, but the nextTick was not reset yet { // Reset boost-state bit_set(PD4, 0); boost_highVoltage_nextHigh = true; boost_highVoltage_nextTick = 0; } } // Signal output if(signalOutput_enable) { if(clock() >= signalOutput_nextTick) // If we are on or after the tick it should be executed { // Set pin according to next exec if(signalOutput_nextHigh) // Set it high { bit_set(PD5, 1); bit_set(PD6, 1); signalOutput_nextHigh = false; // Next is low } else // Set it low { bit_set(PD5, 0); bit_set(PD6, 0); signalOutput_nextHigh = true; // Next is high signalOutput_enable = false; // Disable signalOutput } // When the signal should stop signalOutput_nextTick = clock() + F_CPU * 0.2 // nextTick is in 0.2s } } } } /* * Interrupt-handler * ISR - Interrupt service routine */ // Address: 0x001 INT0 - On any edge [Code: 01] // Handles: Over/Below working voltage ISR(INT0_vect) { if(PIND&0x20 == 0x00) // Falling edge { // Below ~400V, activate booster boost_enable = true; } else // Rising edge { // Reached ~400V, deactivate booster boost_enable = false; } reti(); // Exit interrupt-handler } // Address: 0x002 INT1 - On rising edge [Code: 11] // Handles: Counter tube "tick" ISR(INT1_vect) { // Tick detected, signalOutput signalOutput_enable = true; // Execute immediately signalOutput_nextTick = 0; reti(); // Exit interrupt-handler }