summaryrefslogtreecommitdiff
path: root/src/c/hardware/avr/gpio/u8AVRDigitalOuts.c
blob: 5ee84a80214af9e5fdbc107cc8437183cbf139de (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Function to change state (high\low) of a digital output pin on AVR
//
// Calling Sequence
//     u8AVRDigitalOuts(port,pin,state)
//
// Parameters
//     port : port of microcontroller to be used (1 for PORTA, 2 for PORTB,...)
//     pin : pin of port (mentioned above) to be used
//     state : state to be outputed on pin (0 for low and 1 for high)
//
// Description
//     Each AVR microcontroller has pins which can be configured as digital
//     outputs. These are normally divided among some 'ports' (group of pins).
//     User has to select one of these port and which pin of that port as 
//     digital output. Also, desired output state must be specified as 
//     '1' (high) or '0' (low).     
//
// Examples
//     u8AVRDigitalOuts(1,0,1)
//
// Authors
//     Siddhesh Wani
//


#include "AVRPeripheralGPIO.h"

uint8 u8AVRDigitalOuts(uint8 port,uint8 pin,uint8 state)
{
    if(state == LOW)
    {/*Make output pin high*/
	if(port == PORT_A)
	{
	    PORTA = PORTA & ~(1<<pin);
	}
	if(port == PORT_B)
	{
	    PORTB = PORTB & ~(1<<pin);
	}
	if(port == PORT_C)
	{
	    PORTC = PORTC & ~(1<<pin);
	}
	if(port == PORT_D)
	{
	    PORTD = PORTD & ~(1<<pin);
	}
    }
    else
    {/*Make output pin high*/
	if(port == PORT_A)
	{
	    PORTA = PORTA | (1<<pin);
	}
	if(port == PORT_B)
	{
	    PORTB = PORTB | (1<<pin);
	}
	if(port == PORT_C)
	{
	    PORTC = PORTC | (1<<pin);
	}
	if(port == PORT_D)
	{
	    PORTD = PORTD | (1<<pin);
	}
    }
return 0;
}