Project

General

Profile

Statistics
| Revision:

root / branches / autonomous_recharging / code / projects / libbayboard / lbom.c @ 785

History | View | Annotate | Download (2.72 KB)

1
/**
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
/**
28
 * @file lbom.c
29
 * @brief Implementation for using the LBOM
30
 *
31
 * Contains functions for using the Bearing and Orientation Module (BOM)
32
 * on the charging station.
33
 *
34
 * @author Colony Project, CMU Robotics Club
35
 **/
36

    
37
#include <avr/io.h>
38
#include "lbom.h"
39

    
40
static char bom_mode;
41
static char led_mask;
42

    
43
/**
44
 * @defgroup lbom LBOM (Bearing and Orientation Module)
45
 * @brief Functions for dealing with the BOM.
46
 *
47
 * The Bearing and Orientation Module / Barrel of Monkeys / BOM
48
 * is a custom sensor designed and built by the Colony Project.
49
 * It consists of 4 IR emitters.
50
 * The BOM is most often use to determine the direction of other
51
 * robots. This module contains functions for controlling the BOM.
52
 *
53
 * Include lbom.h to access these functions.
54
 *
55
 * @{
56
 **/
57

    
58
/** @brief Sets up the LBOM to be used. **/
59
void bom_init(char type){
60
        set_leds(BOM_ALL_ON);
61
        DDRC |= _BV(BOM0)|_BV(BOM1)|_BV(BOM2)|_BV(BOM3);
62
        DDRD |= _BV(DDD7);                        //sets bom carrier to write
63
        
64
        bom_mode = type;
65
        switch(bom_mode){        
66
        case RBOM:
67
                //set the carrier to produce a 31kHz 50% duty cycle signal
68
                TCCR2A = _BV(COM2A1)|_BV(COM2A0)|_BV(WGM21)|_BV(WGM20);
69
                TCCR2B = _BV(CS20);
70
                OCR2A = 127;
71
        case BOM:
72
        case BOM1_5:
73
        default:
74
                PORTD |= _BV(PD7);
75
        }
76
}
77
/** @brief Turns the enabled LBOM LEDS on. **/
78
void bom_on(void){
79
        PORTC |= led_mask;
80
}
81

    
82
/** @brief Turns all LBOM LEDS off. **/
83
void bom_off(void){
84
        PORTC &= ~(BOM_ALL_ON<<4);
85
}
86

    
87
/** @brief Sets which emitters are enabled **/
88
void set_leds(int bit_field){
89
        led_mask = ((bit_field&BOM_ALL_ON) << 4);
90
}
91

    
92
/** @} **/ //end group