Subversion Repositories NaviCtrl

Rev

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

Rev Author Line No. Line
119 killagreg 1
/*#######################################################################################*/
2
/* !!! THIS IS NOT FREE SOFTWARE !!!                                                     */
3
/*#######################################################################################*/
4
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
5
// + Copyright (c) 2008 Ingo Busker, Holger Buss
6
// + Nur für den privaten Gebrauch
7
// + FOR NON COMMERCIAL USE ONLY
8
// + www.MikroKopter.com
9
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
10
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
11
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist.
12
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
13
// + bzgl. der Nutzungsbedingungen aufzunehmen.
14
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
15
// + Verkauf von Luftbildaufnahmen, usw.
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
17
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
18
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
21
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
22
// + eindeutig als Ursprung verlinkt werden
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
25
// + Benutzung auf eigene Gefahr
26
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
28
// + Die PORTIERUNG der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
29
// + mit unserer Zustimmung zulässig
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
31
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
32
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
33
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
34
// + this list of conditions and the following disclaimer.
35
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
36
// +     from this software without specific prior written permission.
37
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permitted
38
// +     for non-commercial use (directly or indirectly)
39
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
40
// +     with our written permission
41
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
42
// +     clearly linked as origin
43
// +   * PORTING this software (or part of it) to systems (other than hardware from www.mikrokopter.de) is NOT allowed
44
//
45
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
46
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
47
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
48
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
49
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
50
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
51
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
52
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
53
// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
54
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
55
// +  POSSIBILITY OF SUCH DAMAGE.
56
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
57
#include "91x_lib.h"
58
#include "timer1.h"
59
#include "uart1.h"
60
 
61
u32 CountMilliseconds;
62
DateTime_t SystemTime;
63
 
64
//----------------------------------------------------------------------------------------------------
65
void TIM1_IRQHandler(void)
66
{
67
        if(TIM_GetFlagStatus(TIM1, TIM_FLAG_OC1) == SET)
68
        {
69
                TIM1->OC1R += 200;    // Timerfreq is 200kHz, generate an interrupt every 1ms
70
                CountMilliseconds++;
71
                //if (GPIO_ReadBit(GPIO6, GPIO_Pin_3)) GPIO_WriteBit(GPIO6, GPIO_Pin_3, Bit_RESET);  else GPIO_WriteBit(GPIO6, GPIO_Pin_3, Bit_SET);
72
                TIM_ClearFlag(TIM1, TIM_FLAG_OC1); // clear irq pending bit
73
        }
74
        // write any value to VIC0 Vector address register
75
        VIC0->VAR = 0xFF;
76
}
77
 
78
//----------------------------------------------------------------------------------------------------
79
// 1ms Timer
80
//----------------------------------------------------------------------------------------------------
81
void TIMER1_Init(void)
82
{
83
        TIM_InitTypeDef   TIM_InitStructure;
84
 
120 killagreg 85
        UART1_PutString("\r\n Timer1 init...");
119 killagreg 86
 
87
        #define TIM1_FREQ 200000 // 200kHz
88
        // TimerOCR set in IntHandler
89
 
90
        SCU_APBPeriphClockConfig(__TIM01, ENABLE);
91
 
120 killagreg 92
        TIM_DeInit(TIM1);
119 killagreg 93
        TIM_StructInit(&TIM_InitStructure);
94
        TIM_InitStructure.TIM_Mode = TIM_OCM_CHANNEL_1;
95
        TIM_InitStructure.TIM_OC1_Modes = TIM_TIMING;
96
        TIM_InitStructure.TIM_Clock_Source = TIM_CLK_APB;
97
        TIM_InitStructure.TIM_Prescaler = (SCU_GetPCLKFreqValue() * 1000) / TIM1_FREQ;  // is only valid up to 48 MHz !
98
        TIM_Init (TIM1, &TIM_InitStructure);
99
 
100
        TIM_ITConfig(TIM1, TIM_IT_OC1, ENABLE);
101
        TIM_CounterCmd(TIM1, TIM_START);
102
 
103
        VIC_Config(TIM1_ITLine, VIC_IRQ, 5);
104
        VIC_ITCmd(TIM1_ITLine, ENABLE);
105
 
106
        SystemTime.Year = 0;
107
        SystemTime.Month = 0;
108
        SystemTime.Day = 0;
109
        SystemTime.Hour = 0;
110
        SystemTime.Min = 0;
111
        SystemTime.Sec = 0;
112
        SystemTime.mSec = 0;
113
        SystemTime.Valid = 0;
114
 
115
        CountMilliseconds = 0;
116
 
120 killagreg 117
        UART1_PutString("ok");
119 killagreg 118
 
119
}
120
 
121
// -----------------------------------------------------------------------
122
u32 SetDelay (u32 t)
123
{
124
        return(CountMilliseconds + t -1);
125
}
126
 
127
// -----------------------------------------------------------------------
128
u8 CheckDelay(u32 t)
129
{
130
        return(((t - CountMilliseconds)& 0x80000000) >> 27);
131
}
132
 
133
// -----------------------------------------------------------------------
134
// this function calculates the time difference of t to the current time in ms
135
// if t < current time the delay is reportet as zero
136
u32 GetDelay(u32 t)
137
{
138
        u32 delay = 0;
139
        delay =  t - CountMilliseconds;
140
        if(delay & 0x80000000) delay = 0; // avoid negative delay values
141
        return(delay);
142
}
143
 
144
// -----------------------------------------------------------------------
145
void Delay_ms(u32 w)
146
{
147
        static u32 akt;
148
        akt = SetDelay(w);
149
        while (!CheckDelay(akt));
150
}