Subversion Repositories FlightCtrl

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
550 walter 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 cntKompass = 0;
7
volatile unsigned int beeptime = 0;
8
unsigned int BeepMuster = 0xffff;
9
int ServoValue = 0;
10
 
11
enum {
12
  STOP             = 0,
13
  CK               = 1,
14
  CK8              = 2,
15
  CK64             = 3,
16
  CK256            = 4,
17
  CK1024           = 5,
18
  T0_FALLING_EDGE  = 6,
19
  T0_RISING_EDGE   = 7
20
};
21
 
22
 
23
SIGNAL (SIG_OVERFLOW0)    // 8kHz
24
{
25
    static unsigned char cnt_1ms = 1,cnt = 0;
26
    unsigned char pieper_ein = 0;
27
//    TCNT0 -= 250;//TIMER_RELOAD_VALUE;
28
 
29
   if(!cnt--)
30
    {
31
     cnt = 9;
32
     cnt_1ms++;
33
     cnt_1ms %= 2;
34
     if(!cnt_1ms) UpdateMotor = 1;
35
     CountMilliseconds++;
36
     }  
37
 
38
     if(beeptime > 1)
39
        {
40
        beeptime--;      
41
        if(beeptime & BeepMuster)
42
         {
43
          pieper_ein = 1;
44
         }
45
         else pieper_ein = 0;
46
        }
47
     else
48
      {
49
       pieper_ein = 0;
50
       BeepMuster = 0xffff;
51
      }
52
 
53
 
54
     if(pieper_ein)
55
        {
56
          if(PlatinenVersion == 10) PORTD |= (1<<2); // Speaker an PORTD.2
57
          else                      PORTC |= (1<<7); // Speaker an PORTC.7
58
        }
59
     else  
60
        {
61
         if(PlatinenVersion == 10) PORTD &= ~(1<<2);
62
         else                      PORTC &= ~(1<<7);
63
        }
64
 
65
 
66
/* MM3 Magentometer 131207WM */
67
#ifdef MM3IS
68
        if(EE_Parameter.GlobalConfig & CFG_KOMPASS_AKTIV) timer0_MM3();         // Kompass auslesen
69
#endif
70
 
71
#ifndef MM3IS
72
 if(EE_Parameter.GlobalConfig & CFG_KOMPASS_AKTIV || EE_Parameter.GlobalConfig & CFG_GPS_AKTIV) //Abfrage um GPS_AKTIV erweitert, damit auch bei nur eingeschaltetem GPS OHNE Kompass der benötigte Kompassvalue berechnet wird (200907Kr)
73
 {
74
  if(PINC & 0x10)
75
   {
76
    cntKompass++;
77
   }
78
  else
79
   {
80
    if((cntKompass) && (cntKompass < 4000))
81
    {
82
     KompassValue = cntKompass;
83
    }
84
//     if(cntKompass < 10) cntKompass = 10;
85
//     KompassValue = (unsigned long)((unsigned long)(cntKompass-10)*720L + 1L) / 703L;
86
     KompassRichtung = ((540 + KompassValue - KompassStartwert) % 360) - 180;
87
    cntKompass = 0;
88
   }
89
 }
90
#endif
91
 
92
 
93
}
94
 
95
 
96
void Timer_Init(void)
97
{
98
    tim_main = SetDelay(10);
99
    TCCR0B = CK8;
100
    TCCR0A = (1<<COM0A1)|(1<<COM0B1)|3;//fast PWM
101
    OCR0A =  0;
102
    OCR0B = 120;
103
    TCNT0 = (unsigned char)-TIMER_RELOAD_VALUE;  // reload
104
    //OCR1  = 0x00;
105
 
106
    TCCR2A=(1<<COM2A1)|(1<<COM2A0)|3;
107
    TCCR2B=(0<<CS20)|(1<<CS21)|(1<<CS22);
108
 
109
//    TIMSK2 |= _BV(TOIE2);
110
TIMSK2 |= _BV(OCIE2A);
111
 
112
    TIMSK0 |= _BV(TOIE0);
113
    OCR2A = 10;
114
    TCNT2 = 0;
115
 
116
}
117
 
118
// -----------------------------------------------------------------------
119
 
120
unsigned int SetDelay (unsigned int t)
121
{
122
//  TIMSK0 &= ~_BV(TOIE0);
123
  return(CountMilliseconds + t + 1);                                            
124
//  TIMSK0 |= _BV(TOIE0);
125
}
126
 
127
// -----------------------------------------------------------------------
128
char CheckDelay(unsigned int t)
129
{
130
//  TIMSK0 &= ~_BV(TOIE0);
131
  return(((t - CountMilliseconds) & 0x8000) >> 9);
132
//  TIMSK0 |= _BV(TOIE0);
133
}
134
 
135
// -----------------------------------------------------------------------
136
void Delay_ms(unsigned int w)
137
{
138
 unsigned int akt;
139
 akt = SetDelay(w);
140
 while (!CheckDelay(akt));
141
}
142
 
143
void Delay_ms_Mess(unsigned int w)
144
{
145
 unsigned int akt;
146
 akt = SetDelay(w);
147
 while (!CheckDelay(akt)) ANALOG_ON;
148
}
149
 
150
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++                
151
//  Servo ansteuern
152
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++                
153
SIGNAL(SIG_OUTPUT_COMPARE2A)
154
{
155
  static unsigned char timer = 10;
156
 
157
  if(!timer--)  
158
    {
159
     TCCR2A=(1<<COM2A1)|(0<<COM2A0)|3;  
160
     ServoValue =  Parameter_ServoNickControl;
161
     if(EE_Parameter.ServoNickCompInvert & 0x01) ServoValue += ((long) EE_Parameter.ServoNickComp * (IntegralNick / 128)) / 512;
162
     else ServoValue -= ((long) EE_Parameter.ServoNickComp * (IntegralNick / 128)) / 512;
163
 
164
     if(ServoValue < EE_Parameter.ServoNickMin) ServoValue = EE_Parameter.ServoNickMin;
165
     else if(ServoValue > EE_Parameter.ServoNickMax) ServoValue = EE_Parameter.ServoNickMax;
166
 
167
     OCR2A = ServoValue;// + 75;
168
     timer = EE_Parameter.ServoNickRefresh;
169
    }
170
    else
171
    {
172
     TCCR2A =3;
173
     PORTD&=~0x80;
174
    }
175
}