Project

General

Profile

Statistics
| Revision:

root / branches / init_refactor / code / projects / libdragonfly / dragonfly_lib.c @ 1518

History | View | Annotate | Download (3.8 KB)

1
/**
2
 * Copyright (c) 2007 Colony Project
3
 * 
4
 * Permission is hereby granted, free of charge, to any person
5
 * obtaining a copy of this software and associated documentation
6
 * files (the "Software"), to deal in the Software without
7
 * restriction, including without limitation the rights to use,
8
 * copy, modify, merge, publish, distribute, sublicense, and/or sell
9
 * copies of the Software, and to permit persons to whom the
10
 * Software is furnished to do so, subject to the following
11
 * conditions:
12
 * 
13
 * The above copyright notice and this permission notice shall be
14
 * included in all copies or substantial portions of the Software.
15
 * 
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
18
 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
20
 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
21
 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
22
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
23
 * OTHER DEALINGS IN THE SOFTWARE.
24
 **/
25

    
26

    
27
/**
28
 * @file dragonfly_lib.c
29
 * @brief Dragonfly initialization
30
 *
31
 * Contains implementation of dragonfly_init.
32
 *
33
 * @author Colony Project, CMU Robotics Club
34
 **/
35

    
36
#include "dragonfly_lib.h"
37

    
38
/* init_dragonfly - Initializes functions based on configuration parameters
39
   examples:
40

41
   init_dragonfly (0, 0, 0); - just initialize the digital IO (buttons, potentiometer)
42

43
   init_dragonfly (ANALOG | SERIAL | BUZZER, C0_C1_ANALOG, BAUD115200); 
44
   Initialize ADC and set C0 and C1 as analog inputs.  Initialize serial and set baud rate
45
   to 115200 bps.  Initialize the buzzer.
46
   
47
   init_dragonfly (MOTORS | ORB, 0, 0);
48
   Initialize motor driving and the color fading abilities of the ORB. */
49

    
50
/**
51
 * @defgroup dragonfly Dragonfly
52
 * @brief General Dragonfly Functions
53
 * General functions for the dragonfly. Include
54
 * dragonfly_lib.h to access these functions.
55
 *
56
 * @{
57
 **/
58

    
59
/**
60
 * Initializes the components specified by config.
61
 * 
62
 * @see analog_init, usb_init, xbee_init, buzzer_init,
63
 * bom_init, orb_init, motors_init, lcd_init, encoders_init
64
 **/
65
 
66
void flash_red(void);
67

    
68
int dragonfly_init(int config) 
69
{
70
  int ret = 0;
71

    
72
    sei();
73
    // Set directionality of various IO pins
74
    DDRG &= ~(_BV(PING0)|_BV(PING1));
75
    PORTG |= _BV(PING0)|_BV(PING1);
76
    
77
    if(config & ANALOG) {
78
      analog_init(ADC_START);
79
    }
80
    
81
    if(config & COMM)
82
    {
83
        //Defaults to 115200. Check serial.h for more information.
84
        usb_init();
85
        xbee_init();
86
    }
87
    
88
    if(config & BUZZER)
89
    {
90
        sei();
91
        buzzer_init();
92
    }
93
    
94
    if(config & ORB)
95
    {
96
        sei();
97
        orb_init();
98
    }
99
    
100
    if(config & MOTORS)
101
        motors_init();
102

    
103
    if(config & LCD)
104
        lcd_init();
105
    
106
    if(config & RANGE)
107
        range_init();
108
        
109
    if(config & BOM)
110
    {
111
        unsigned char bom_read = get_bom_type();
112
        if(bom_read == 0xFF) {
113
            //warn that bom initialization failed
114
            flash_red();
115
            return ERROR_INIT_FAILED;
116
        }
117
        else
118
          if (bom_init(bom_read) != 0)
119
            return ERROR_INIT_FAILED;
120
    }
121

    
122
    if (config & ENCODERS)
123
    {
124
        encoders_init();
125
    }
126

    
127
    // delay a bit for stability
128
    _delay_ms(1);
129
    
130
  return 0;
131
}
132

    
133
//flash lights red three times and restore ports
134
void flash_red(void)
135
{
136
    cli();
137
    char dd = DDRC;
138
    char po = PORTC;
139
    char i;
140
    DDRC = 0x77;
141
    for(i = 0; i<3; i++)
142
    {
143
        PORTC = 0x77;
144
        delay_ms(300);
145
        PORTC = 0x66;
146
        delay_ms(300);
147
    }
148
    
149
    DDRC = dd;
150
    PORTC = po;
151
    sei();
152
}
153
/** @} **/ //end defgroup
154