summaryrefslogtreecommitdiff
path: root/src/c/hardware/avr/adc/u8AVRReadADCs.c
blob: 302f8c82bbb0c00b2dd7255f52030919e045d053 (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
70
71
72
73
74
75
76
77
78
79
80
81
82
// Copyright (C) 2017 - IIT Bombay - FOSSEE
//
// This file must be used under the terms of the CeCILL.
// This source file is licensed as described in the file COPYING, which
// you should have received as part of this distribution.  The terms
// are also available at
// http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
// Organization: FOSSEE, IIT Bombay
// Email: toolbox@scilab.in

// Function to get voltage on analog pin on AVR
//
// Calling Sequence
//     u8AVRReadADCs(channel)
//
// Parameters
//     channel 	: Select which channel is to be read. Values from 0-7 select one 
//	             of the pins ADC0-ADC7. For other possible channel values refer
//               datasheet
//   Returns->  
//     result 	: Digital value for the voltage present on channel selected
//
// Description
//     This function returns digital value for present on adc pins. 'channel' 
//     selects which of the ADC0-ADC7 is to be used for reading analog value.
//     Apart from reading just ADC0-ADC7 other it can also read differential 
//     voltages between some pins. For channel values for those options, please 
//     refer datasheet.      
//
// Examples
//     adc_result = u8AVRReadADC(0)   //Read ADC0
//
// Authors
//     Siddhesh Wani
//     Ashish Kamble


#include "AVRPeripheralADC.h"

uint8 u8AVRReadADCs(uint8 channel)
{

uint8 i;

  ADCH=0x00;

  i=channel&0x07;
  ADMUX=i|0x60;                //i|0x40 for 10 bits
  ADCSRA|=1<<ADSC;

  while(ADCSRA & (1<<ADSC));       // wait for conv. to complete
  uint8 temp=ADCH;      //unsigned int temp=ADC;   for 10 bits

  return temp;
	
}










/*Set ADC conversion channel*/
//    ADMUX |= (channel & 0x1F);

	/*Start ADC conversion. Set 'ADSC' bit*/
//	ADCSRA |= (1<<6);

	/*Wait for conversion to complete. Check 'ADIF' bit*/
//    while(!(ADCSRA & (1<<4)));

	/*Clear ADIF flag*/
//    ADCSRA |= (1<<4);

	/*ADC conversion result is stored in ADCH/L registers*/
//	return (ADC);