Subversion Repositories FlightCtrl

Rev

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

Rev Author Line No. Line
1180 killagreg 1
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2
// + Copyright (c) 04.2007 Holger Buss
3
// + Nur für den privaten Gebrauch
4
// + www.MikroKopter.com
5
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
6
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
7
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist.
8
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
9
// + bzgl. der Nutzungsbedingungen aufzunehmen.
10
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
11
// + Verkauf von Luftbildaufnahmen, usw.
12
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
13
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
14
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
15
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
16
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
17
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
18
// + eindeutig als Ursprung verlinkt werden
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
21
// + Benutzung auf eigene Gefahr
22
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// + Die Portierung der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
25
// + mit unserer Zustimmung zulässig
26
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
27
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
28
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
29
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
30
// + this list of conditions and the following disclaimer.
31
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
32
// +     from this software without specific prior written permission.
33
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permittet
34
// +     for non-commercial use (directly or indirectly)
35
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
36
// +     with our written permission
37
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
38
// +     clearly linked as origin
39
// +   * porting to systems other than hardware from www.mikrokopter.de is not allowed
40
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
41
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
44
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
45
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
46
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
47
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
48
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
49
// +  POSSIBILITY OF SUCH DAMAGE.
50
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
886 killagreg 51
#include <avr/io.h>
52
#include <avr/interrupt.h>
53
#include "main.h"
54
#include "uart1.h"
55
#include "fifo.h"
911 killagreg 56
#if defined (USE_KILLAGREG) || defined (USE_MK3MAG)
886 killagreg 57
#include "ubx.h"
58
#endif
59
 
60
 
61
 
62
// FIFO-objects and buffers for input and output
63
 
64
//#define BUFSIZE_IN  0x96
65
//volatile uint8_t inbuf[BUFSIZE_IN];
66
//fifo_t infifo;
67
 
68
#define BUFSIZE_OUT 0x96
69
volatile uint8_t outbuf[BUFSIZE_OUT];
70
fifo_t outfifo;
71
 
72
/****************************************************************/
73
/*              Initialization of the USART1                    */
74
/****************************************************************/
75
void USART1_Init (void)
76
{
77
        // USART1 Control and Status Register A, B, C and baud rate register
78
        uint8_t sreg = SREG;
79
        uint16_t ubrr = (uint16_t) ((uint32_t) SYSCLK/(8 * USART1_BAUD) - 1);
80
 
81
        // disable all interrupts before reconfiguration
82
        cli();
83
 
84
        // disable RX-Interrupt
85
        UCSR1B &= ~(1 << RXCIE1);
86
        // disable TX-Interrupt
87
        UCSR1B &= ~(1 << TXCIE1);
88
        // disable DRE-Interrupt
89
        UCSR1B &= ~(1 << UDRIE1);
90
 
91
        // set direction of RXD1 and TXD1 pins
92
        // set RXD1 (PD2) as an input pin
93
        PORTD |= (1 << PORTD2);
94
        DDRD &= ~(1 << DDD2);
95
 
96
        // set TXD1 (PD3) as an output pin
97
        PORTD |= (1 << PORTD3);
98
        DDRD  |= (1 << DDD3);
99
 
100
        // USART0 Baud Rate Register
101
        // set clock divider
102
        UBRR1H = (uint8_t)(ubrr>>8);
103
        UBRR1L = (uint8_t)ubrr;
104
 
105
        // enable double speed operation
106
        UCSR1A |= (1 << U2X1);
107
        // enable receiver and transmitter
108
        UCSR1B = (1 << TXEN1) | (1 << RXEN1);
109
        // set asynchronous mode
110
        UCSR1C &= ~(1 << UMSEL11);
111
        UCSR1C &= ~(1 << UMSEL10);
112
        // no parity
113
        UCSR1C &= ~(1 << UPM11);
114
        UCSR1C &= ~(1 << UPM10);
115
        // 1 stop bit
116
        UCSR1C &= ~(1 << USBS1);
117
        // 8-bit
118
        UCSR1B &= ~(1 << UCSZ12);
119
        UCSR1C |=  (1 << UCSZ11);
120
        UCSR1C |=  (1 << UCSZ10);
121
 
122
        // flush receive buffer explicit
123
        while ( UCSR1A & (1<<RXC1) ) UDR1;
124
 
125
        // enable interrupts at the end
126
        // enable RX-Interrupt
127
        UCSR1B |= (1 << RXCIE1);
128
        // enable TX-Interrupt
129
        UCSR1B |= (1 << TXCIE1);
130
        // enable DRE interrupt
131
        //UCSR1B |= (1 << UDRIE1);
132
 
133
 
134
        // restore global interrupt flags
135
    SREG = sreg;
136
 
137
    // inint FIFO buffer
138
        //fifo_init (&infifo,   inbuf, BUFSIZE_IN);
139
    //fifo_init (&outfifo, outbuf, BUFSIZE_OUT);
140
}
141
 
142
/*int16_t USART1_putc (const uint8_t c)
143
{
144
    int16_t ret = fifo_put (&outfifo, c);
145
    // create an data register empty interrupt
146
    UCSR1B |= (1 << UDRIE1);
147
 
148
    return ret;
149
}
150
*/
151
/*int16_t USART1_getc_nowait ()
152
{
153
    return fifo_get_nowait (&infifo);
154
}
155
 
156
 
157
uint8_t USART1_getc_wait ()
158
{
159
    return fifo_get_wait (&infifo);
160
}
161
*/
162
 
163
/****************************************************************/
164
/*               USART1 data register empty ISR                 */
165
/****************************************************************/
166
/*ISR(USART1_UDRE_vect)
167
{
168
// Move a character from the output buffer to the data register.
169
// When the character was processed the next interrupt is generated.
170
// If the output buffer is empty the DRE-interrupt is disabled.
171
    if (outfifo.count > 0)
172
       UDR1 = _inline_fifo_get (&outfifo);
173
    else
174
        UCSR1B &= ~(1 << UDRIE1);
175
}
176
*/
177
 
178
/****************************************************************/
179
/*               USART1 transmitter ISR                         */
180
/****************************************************************/
181
/*ISR(USART1_TX_vect)
182
{
183
 
184
}
185
*/
186
/****************************************************************/
187
/*               USART1 receiver ISR                            */
188
/****************************************************************/
189
ISR(USART1_RX_vect)
190
{
191
        uint8_t c;
192
        c = UDR1; // get data byte
953 killagreg 193
        #if (defined (USE_KILLAGREG) || defined (USE_MK3MAG))
1180 killagreg 194
        ubx_parser(c); // and put it into the ubx protocol parser
886 killagreg 195
        #endif
196
}