volatile clock_time_t clock_datetime = 0;
 
 //Overflow interrupt
-ISR(TIMER1_COMPA_vect)
+ISR(TIMER1_COMPA_vect, ISR_BLOCK)
 {
        clock_datetime += 1;
 }
 //Initialise the clock
 void clock_init()
 {
-       OCR1A  = ((F_CPU / 1024) / 100);
+       OCR1A  = (((F_CPU / 1024) / 100) - 1);
        TCCR1B = ((1 << WGM12) | (1 << CS12) | (1 << CS10));
        TIMSK1 = (1 << OCIE1A);
 }
 
        return time;
 }
+