Subversion Repositories FlightCtrl

Rev

Rev 205 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
205 Nick666 1
#include "main.h"
2
 
3
volatile unsigned int CountMilliseconds = 0;
4
volatile static unsigned int tim_main;
5
volatile unsigned char UpdateMotor = 0;
6
volatile unsigned int beeptime = 0;
7
int ServoValue = 0;
8
 
9
enum {
10
  STOP             = 0,
11
  CK               = 1,
12
  CK8              = 2,
13
  CK64             = 3,
14
  CK256            = 4,
15
  CK1024           = 5,
16
  T0_FALLING_EDGE  = 6,
17
  T0_RISING_EDGE   = 7
18
};
19
 
20
 
21
SIGNAL (SIG_OVERFLOW0)    // 8kHz
22
{
23
    static unsigned char cnt_1ms = 1,cnt = 0;
24
//    TCNT0 -= 250;//TIMER_RELOAD_VALUE;
25
 
26
   if(!cnt--)
27
    {
28
     cnt = 9;
29
     cnt_1ms++;
30
     cnt_1ms %= 2;
31
     if(!cnt_1ms) UpdateMotor = 1;
32
     CountMilliseconds++;
33
     if(Timeout) Timeout--;
34
     }  
35
 
36
     if(beeptime > 1)
37
        {
38
        beeptime--;
206 Nick666 39
        PORTD |= (1<<2);
205 Nick666 40
        }
41
     else  
42
        PORTD &= ~(1<<PD2);
43
 
44
  if(EE_Parameter.GlobalConfig & CFG_KOMPASS_AKTIV) MM3_timer0();
45
 
46
  /*
47
  if(PINC & 0x10)
48
   {
49
    cntKompass++;
50
   }
51
  else
52
   {
53
    if((cntKompass) && (cntKompass < 4000))
54
    {
55
     KompassValue = cntKompass;
56
    }
57
//     if(cntKompass < 10) cntKompass = 10;
58
//     KompassValue = (unsigned long)((unsigned long)(cntKompass-10)*720L + 1L) / 703L;
59
     KompassRichtung = ((540 + KompassValue - KompassStartwert) % 360) - 180;
60
    cntKompass = 0;
61
   }
62
 
63
 }*/
64
 
65
}
66
 
67
 
68
void Timer_Init(void)
69
{
70
    tim_main = SetDelay(10);
71
    TCCR0B = CK8;
72
    TCCR0A = (1<<COM0A1)|(1<<COM0B1)|3;//fast PWM
73
    OCR0A =  0;
74
    OCR0B = 120;
75
    TCNT0 = -TIMER_RELOAD_VALUE;  // reload
76
    //OCR1  = 0x00;
77
 
78
    TCCR2A=(1<<COM2A1)|(1<<COM2A0)|3;
79
    TCCR2B=(0<<CS20)|(1<<CS21)|(1<<CS22);
80
 
81
//    TIMSK2 |= _BV(TOIE2);
82
TIMSK2 |= _BV(OCIE2A);
83
 
84
    TIMSK0 |= _BV(TOIE0);
85
    OCR2A = 10;
86
    TCNT2 = 0;
87
 
88
}
89
 
90
// -----------------------------------------------------------------------
91
 
92
unsigned int SetDelay (unsigned int t)
93
{
94
//  TIMSK0 &= ~_BV(TOIE0);
95
  return(CountMilliseconds + t + 1);                                            
96
//  TIMSK0 |= _BV(TOIE0);
97
}
98
 
99
// -----------------------------------------------------------------------
100
char CheckDelay(unsigned int t)
101
{
102
//  TIMSK0 &= ~_BV(TOIE0);
103
  return(((t - CountMilliseconds) & 0x8000) >> 9);
104
//  TIMSK0 |= _BV(TOIE0);
105
}
106
 
107
// -----------------------------------------------------------------------
108
void Delay_ms(unsigned int w)
109
{
110
 unsigned int akt;
111
 akt = SetDelay(w);
112
 while (!CheckDelay(akt));
113
}
114
 
115
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++                
116
//  Servo ansteuern
117
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++                
118
SIGNAL(SIG_OUTPUT_COMPARE2A)
119
{
120
  static unsigned char timer = 10;
121
 
122
  if(!timer--)  
123
    {
124
     TCCR2A=(1<<COM2A1)|(0<<COM2A0)|3;  
125
     ServoValue =  Parameter_ServoNickControl;
126
     if(EE_Parameter.ServoNickCompInvert & 0x01) ServoValue += ((long) EE_Parameter.ServoNickComp * (IntegralNick / 128)) / 512;
127
     else ServoValue -= ((long) EE_Parameter.ServoNickComp * (IntegralNick / 128)) / 512;
128
 
129
     if(ServoValue < EE_Parameter.ServoNickMin) ServoValue = EE_Parameter.ServoNickMin;
130
     else if(ServoValue > EE_Parameter.ServoNickMax) ServoValue = EE_Parameter.ServoNickMax;
131
 
132
     //DebugOut.Analog[10] = ServoValue;     
133
     OCR2A = ServoValue;// + 75;
134
     timer = EE_Parameter.ServoNickRefresh;
135
    }
136
    else
137
    {
138
     TCCR2A =3;
139
     PORTD&=~0x80;
140
    }
141
}