Subversion Repositories FlightCtrl

Rev

Details | Last modification | View Log | RSS feed

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