Subversion Repositories FlightCtrl

Rev

Go to most recent revision | Details | 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--;
39
        PORTD &= ~(1<<PD2);//PORTD |= (1<<2);
40
        }
41
     else  
42
        PORTD &= ~(1<<PD2);
43
 
44
  if(EE_Parameter.GlobalConfig & CFG_KOMPASS_AKTIV) MM3_timer0();
45
 
46
 
47
  /*
48
  if(PINC & 0x10)
49
   {
50
    cntKompass++;
51
   }
52
  else
53
   {
54
    if((cntKompass) && (cntKompass < 4000))
55
    {
56
     KompassValue = cntKompass;
57
    }
58
//     if(cntKompass < 10) cntKompass = 10;
59
//     KompassValue = (unsigned long)((unsigned long)(cntKompass-10)*720L + 1L) / 703L;
60
     KompassRichtung = ((540 + KompassValue - KompassStartwert) % 360) - 180;
61
    cntKompass = 0;
62
   }
63
 
64
 }*/
65
 
66
}
67
 
68
 
69
void Timer_Init(void)
70
{
71
    tim_main = SetDelay(10);
72
    TCCR0B = CK8;
73
    TCCR0A = (1<<COM0A1)|(1<<COM0B1)|3;//fast PWM
74
    OCR0A =  0;
75
    OCR0B = 120;
76
    TCNT0 = -TIMER_RELOAD_VALUE;  // reload
77
    //OCR1  = 0x00;
78
 
79
    TCCR2A=(1<<COM2A1)|(1<<COM2A0)|3;
80
    TCCR2B=(0<<CS20)|(1<<CS21)|(1<<CS22);
81
 
82
//    TIMSK2 |= _BV(TOIE2);
83
TIMSK2 |= _BV(OCIE2A);
84
 
85
    TIMSK0 |= _BV(TOIE0);
86
    OCR2A = 10;
87
    TCNT2 = 0;
88
 
89
}
90
 
91
// -----------------------------------------------------------------------
92
 
93
unsigned int SetDelay (unsigned int t)
94
{
95
//  TIMSK0 &= ~_BV(TOIE0);
96
  return(CountMilliseconds + t + 1);                                            
97
//  TIMSK0 |= _BV(TOIE0);
98
}
99
 
100
// -----------------------------------------------------------------------
101
char CheckDelay(unsigned int t)
102
{
103
//  TIMSK0 &= ~_BV(TOIE0);
104
  return(((t - CountMilliseconds) & 0x8000) >> 9);
105
//  TIMSK0 |= _BV(TOIE0);
106
}
107
 
108
// -----------------------------------------------------------------------
109
void Delay_ms(unsigned int w)
110
{
111
 unsigned int akt;
112
 akt = SetDelay(w);
113
 while (!CheckDelay(akt));
114
}
115
 
116
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++                
117
//  Servo ansteuern
118
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++                
119
SIGNAL(SIG_OUTPUT_COMPARE2A)
120
{
121
  static unsigned char timer = 10;
122
 
123
  if(!timer--)  
124
    {
125
     TCCR2A=(1<<COM2A1)|(0<<COM2A0)|3;  
126
     ServoValue =  Parameter_ServoNickControl;
127
     if(EE_Parameter.ServoNickCompInvert & 0x01) ServoValue += ((long) EE_Parameter.ServoNickComp * (IntegralNick / 128)) / 512;
128
     else ServoValue -= ((long) EE_Parameter.ServoNickComp * (IntegralNick / 128)) / 512;
129
 
130
     if(ServoValue < EE_Parameter.ServoNickMin) ServoValue = EE_Parameter.ServoNickMin;
131
     else if(ServoValue > EE_Parameter.ServoNickMax) ServoValue = EE_Parameter.ServoNickMax;
132
 
133
     //DebugOut.Analog[10] = ServoValue;     
134
     OCR2A = ServoValue;// + 75;
135
     timer = EE_Parameter.ServoNickRefresh;
136
    }
137
    else
138
    {
139
     TCCR2A =3;
140
     PORTD&=~0x80;
141
    }
142
}