Project

General

Profile

Statistics
| Revision:

root / trunk / code / projects / autonomous_recharging / charging_station / new station driver code / orb.c @ 617

History | View | Annotate | Download (3.21 KB)

1 612 emullini
/**
2
 * Copyright (c) 2008 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
 * @file orb.c
28
 * @brief Orbs
29
 *
30
 * Implemenation for the orbs (tri-colored LEDs)
31
 *
32
 * @author Colony Project, CMU Robotics Club
33
 **/
34
35
#include <avr/io.h>
36
#include "orb.h"
37
38
39 616 jsexton
int main (void){
40 617 emullini
orb_init();
41
set_orb(0, 0, 200);
42 616 jsexton
while(1);
43
return 0;
44
}
45
46 612 emullini
/**
47
 * @defgroup orbs Orbs
48
 * @brief Functions for controlling the color of the orbs.
49
 *
50
 * Functions for controlling the color and lighting of the orbs.
51
 *
52
 * @{
53
 **/
54
55
/**
56
 * Initializes the PWM for Orb control. This must be called before
57
 * the orbs are used for them to function.
58
 **/
59
int orb_init (void)
60
{
61
        /*data direction registers, blue, green (bit 7) and red (bit 5)*/
62 617 emullini
        //DDRB = _BV(DDB4);
63
        DDRB = 0b00010000;
64
65
        //DDRD = _BV(DDD4)|_BV(DDD6);
66
        DDRD = 0b01010000;
67 612 emullini
68
69
        /*blue is here. it goes on timer 0*/
70
        /*timer counter control registers for timer 0*/
71 617 emullini
        //TCCR0A = _BV(COM0B1)|_BV(COM0B0)|_BV(WGM01)|_BV(WGM00);
72
        TCCR0A = 0b00110011;
73
74
        //TCCR0B = _BV(CS00);
75
        TCCR0B = 0b00000001;
76 616 jsexton
        OCR0B = 0;
77 612 emullini
78
        /*green is here. it goes on timer 2*/
79 617 emullini
        //TCCR2A = _BV(COM2B1)|_BV(COM2B0)|_BV(WGM21)|_BV(WGM20);
80
        TCCR2A = 0b00110011;
81
82
        //TCCR2B = _BV(CS20);
83
        TCCR2B = 0b00000001;
84 616 jsexton
        OCR2B = 0;
85 612 emullini
86
87
        /*red is here. it goes on timer 1 which counts to the value in ICR1 instead of 8 bits*/
88 617 emullini
        //TCCR1A = _BV(COM1B1)|_BV(COM1B0)|_BV(WGM11);
89
        TCCR1A = 0b00110001;
90
91
        //TCCR1B = _BV(WGM13)|_BV(WGM12)|_BV(CS10);
92
        TCCR1B = 0b00011001;
93 612 emullini
        ICR1 = 0x9C40;
94 616 jsexton
        OCR1B = 0;
95 612 emullini
96
        return 0;
97
}
98
99
/**
100
 * Set both orbs to the color specified. orb_init must
101
 * be called before this function may be used.
102
 *
103
 * @param red the red component of the color
104
 * @param green the green component of the color
105
 * @param blue the blue component of the color
106
 *
107
 * @see orb_init
108
 **/
109
110
int set_orb(int red, int green, int blue){
111
        /*blue is here. it goes on timer 0*/
112
        blue = blue%256;
113 616 jsexton
        OCR0B = blue;
114 612 emullini
115
        /*green is here. it goes on timer 2*/
116
        green = green%256;
117 616 jsexton
        OCR2B = green;
118 612 emullini
119
120
        /*red is here. it goes on timer 1*/
121
        red = red%256;
122
        red *= (int)(ICR1/256);
123 616 jsexton
        OCR1B = red;
124 612 emullini
125
        return 0;
126
}
127
128
/** @} **/ //end group