亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? adc.c

?? Analog Digital conversion with lpc2148
?? C
字號:
/*****************************************************************************
 *   adc.c:  ADC module file for Philips LPC214x Family Microprocessors
 *
 *   Copyright(C) 2006, Philips Semiconductor
 *   All rights reserved.
 *
 *   History
 *   2005.10.01  ver 1.00    Prelimnary version, first Release
 *
******************************************************************************/
#include "LPC214x.h"                        /* LPC21xx definitions */
#include "type.h"
#include "irq.h"
#include "target.h"
#include "adc.h"

volatile DWORD ADC0Value[ADC_NUM], ADC1Value[ADC_NUM];
volatile DWORD ADC0IntDone = 0, ADC1IntDone = 0;

#if ADC_INTERRUPT_FLAG
/******************************************************************************
** Function name:		ADC0Handler
**
** Descriptions:		ADC0 interrupt handler
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void ADC0Handler (void) __irq 
{
    DWORD regVal;
  
    IENABLE;			/* handles nested interrupt */

    regVal = AD0STAT;		/* Read ADC will clear the interrupt */
    if ( regVal & 0x0000FF00 )	/* check OVERRUN error first */
    {
	regVal = (regVal & 0x0000FF00) >> 0x08;
				/* if overrun, just read ADDR to clear */
				/* regVal variable has been reused. */
	switch ( regVal )
	{
	    case 0x01:
		regVal = AD0DR0;
		break;
	    case 0x02:
		regVal = AD0DR1;
		break;
	    case 0x04:
		regVal = AD0DR2;
		break;
	    case 0x08:
		regVal = AD0DR3;
		break;
	    case 0x10:
		regVal = AD0DR4;
		break;
	    case 0x20:
		regVal = AD0DR5;
		break;
	    case 0x40:
		regVal = AD0DR6;
		break;
	    case 0x80:
		regVal = AD0DR7;
		break;
	    default:
		break;
	}
	AD0CR &= 0xF8FFFFFF;	/* stop ADC now */ 
	ADC0IntDone = 1;
	return;	
    }
    
    if ( regVal & ADC_ADINT )
    {
	switch ( regVal & 0xFF )	/* check DONE bit */
	{
	    case 0x01:
		ADC0Value[0] = ( AD0DR0 >> 6 ) & 0x3FF;
		break;
	    case 0x02:
		ADC0Value[1] = ( AD0DR1 >> 6 ) & 0x3FF;
		break;
	    case 0x04:
		ADC0Value[2] = ( AD0DR2 >> 6 ) & 0x3FF;
		break;
	    case 0x08:
		ADC0Value[3] = ( AD0DR3 >> 6 ) & 0x3FF;
		break;
	    case 0x10:
		ADC0Value[4] = ( AD0DR4 >> 6 ) & 0x3FF;
		break;
	    case 0x20:
		ADC0Value[5] = ( AD0DR5 >> 6 ) & 0x3FF;
		break;
	    case 0x40:
		ADC0Value[6] = ( AD0DR6 >> 6 ) & 0x3FF;
		break;
	    case 0x80:
		ADC0Value[7] = ( AD0DR7 >> 6 ) & 0x3FF;
		break;		
	    default:
		break;
	}
	AD0CR &= 0xF8FFFFFF;	/* stop ADC now */ 
	ADC0IntDone = 1;
    }

    IDISABLE;
    VICVectAddr = 0;		/* Acknowledge Interrupt */
}

/******************************************************************************
** Function name:		ADC1Handler
**
** Descriptions:		ADC1 interrupt handler
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void ADC1Handler (void) __irq 
{
    DWORD regVal;
  
    IENABLE;			/* handles nested interrupt */

    regVal = AD1STAT;		/* Read ADC will clear the interrupt */
    if ( regVal & 0x0000FF00 )	/* check OVERRUN error first */
    {
	regVal = (regVal & 0x0000FF00) >> 0x08;
				/* if overrun, just read AD1DRx to clear */
				/* regVal variable has been reused. */
	switch ( regVal )
	{
	    case 0x01:
		regVal = AD1DR0;
		break;
	    case 0x02:
		regVal = AD1DR1;
		break;
	    case 0x04:
		regVal = AD1DR2;
		break;
	    case 0x08:
		regVal = AD1DR3;
		break;
	    case 0x10:
		regVal = AD1DR4;
		break;
	    case 0x20:
		regVal = AD1DR5;
		break;
	    case 0x40:
		regVal = AD1DR6;
		break;
	    case 0x80:
		regVal = AD1DR7;
		break;
	    default:
		break;
	}
	AD1CR &= 0xF8FFFFFF;	/* stop ADC now */ 
	ADC1IntDone = 1;
	return;	
    }
    
    if ( regVal & ADC_ADINT )
    {
	switch ( regVal & 0xFF )	/* check DONE bit */
	{
	    case 0x01:
		ADC1Value[0] = ( AD1DR0 >> 6 ) & 0x3FF;
		break;
	    case 0x02:
		ADC1Value[1] = ( AD1DR1 >> 6 ) & 0x3FF;
		break;
	    case 0x04:
		ADC1Value[2] = ( AD1DR2 >> 6 ) & 0x3FF;
		break;
	    case 0x08:
		ADC1Value[3] = ( AD1DR3 >> 6 ) & 0x3FF;
		break;
	    case 0x10:
		ADC1Value[4] = ( AD1DR4 >> 6 ) & 0x3FF;
		break;		
	    case 0x20:
		ADC1Value[5] = ( AD1DR5 >> 6 ) & 0x3FF;
		break;
	    case 0x40:
		ADC1Value[6] = ( AD1DR6 >> 6 ) & 0x3FF;
		break;
	    case 0x80:
		ADC1Value[7] = ( AD1DR7 >> 6 ) & 0x3FF;
		break;		
	    default:
		break;
	}
	AD1CR &= 0xF8FFFFFF;	/* stop ADC now */ 
	ADC1IntDone = 1;
    }

    IDISABLE;
    VICVectAddr = 0;		/* Acknowledge Interrupt */
}
#endif

/*****************************************************************************
** Function name:		ADCInit
**
** Descriptions:		initialize ADC channel
**
** parameters:			ADC clock rate
** Returned value:		true or false
** 
*****************************************************************************/
DWORD ADCInit( DWORD ADC_Clk )
{
    /* all the related pins are set to ADC inputs, AD0.1~4, AD1.0~7 */	
    PINSEL0 = 0x0F333F00;
    PINSEL1 = 0x15541800;

    AD0CR = ( 0x01 << 0 ) | 	// SEL=1,select channel 0, 1 to 4 on ADC0
	( ( Fpclk / ADC_Clk - 1 ) << 8 ) |  // CLKDIV = Fpclk / 1000000 - 1 
	( 0 << 16 ) | 		// BURST = 0, no BURST, software controlled
	( 0 << 17 ) |  		// CLKS = 0, 11 clocks/10 bits 
	( 1 << 21 ) |  		// PDN = 1, normal operation 
	( 0 << 22 ) |  		// TEST1:0 = 00 
	( 0 << 24 ) |  		// START = 0 A/D conversion stops
	( 0 << 27 );		/* EDGE = 0 (CAP/MAT singal falling,trigger A/D 
				conversion) */
    AD1CR = ( 0x01 << 0 ) | 	// SEL=1,select channel 0, 0 to 7 on ADC1
	( ( Fpclk / ADC_Clk - 1 ) << 8 ) |  // CLKDIV = Fpclk / 1000000 - 1 
	( 0 << 16 ) | 		// BURST = 0, no BURST, software controlled 
	( 0 << 17 ) |  		// CLKS = 0, 11 clocks/10 bits 
	( 1 << 21 ) |  		// PDN = 1, normal operation 
	( 0 << 22 ) |  		// TEST1:0 = 00 
	( 0 << 24 ) |  		// START = 0 A/D conversion stops
	( 0 << 27 );		/* EDGE = 0 (CAP/MAT singal falling,trigger A/D 
				conversion) */

    /* If POLLING, no need to do the following */
#if ADC_INTERRUPT_FLAG
    AD0INTEN = 0x11E;		// Enable all interrupts 
    AD1INTEN = 0x1FF;

    if ( install_irq( ADC0_INT, (void *)ADC0Handler ) == FALSE )
    {
	return (FALSE);
    }
    if ( install_irq( ADC1_INT, (void *)ADC1Handler ) == FALSE )
    {
	return (FALSE);
    }
#endif

    return (TRUE);
}

/*****************************************************************************
** Function name:		ADC0Read
**
** Descriptions:		Read ADC0 channel
**
** parameters:			Channel number
** Returned value:		Value read, if interrupt driven, return channel #
** 
*****************************************************************************/
DWORD ADC0Read( BYTE channelNum )
{
#if !ADC_INTERRUPT_FLAG
    DWORD regVal, ADC_Data;
#endif

    /* channel number is 0 through 7 */
    if ( channelNum >= ADC_NUM )
    {
	channelNum = 0;		/* reset channel number to 0 */
    }
    AD0CR &= 0xFFFFFF00;
    AD0CR |= (1 << 24) | (1 << channelNum);	
				/* switch channel,start A/D convert */
#if !ADC_INTERRUPT_FLAG
    while ( 1 )			/* wait until end of A/D convert */
    {
	regVal = *(volatile unsigned long *)(AD0_BASE_ADDR 
			+ ADC_OFFSET + ADC_INDEX * channelNum);
				/* read result of A/D conversion */
	if ( regVal & ADC_DONE )
	{
	    break;
	}
    }	
        
    AD0CR &= 0xF8FFFFFF;	/* stop ADC now */    
    if ( regVal & ADC_OVERRUN )	/* save data when it's not overrun
				otherwise, return zero */
    {
	return ( 0 );
    }
    ADC_Data = ( regVal >> 6 ) & 0x3FF;
    return ( ADC_Data );	/* return A/D conversion value */
#else
    return ( channelNum );	/* if it's interrupt driven, the 
				ADC reading is done inside the handler.
				so, return channel number */
#endif
}

/*****************************************************************************
** Function name:		ADC1Read
**
** Descriptions:		Read ADC1 channel
**
** parameters:			Channel number
** Returned value:		Value read, if interrupt driven, return channel #
** 
*****************************************************************************/
DWORD ADC1Read( BYTE channelNum )
{
#if !ADC_INTERRUPT_FLAG
    DWORD regVal;
	DWORD ADC_Data;
#endif

    /* channel number is 0 through 7 */
    if ( channelNum >= ADC_NUM )
    {
	channelNum = 0;		/* reset channel number to 0 */
    }
    AD1CR &= 0xFFFFFF00;
    AD1CR |= (1 << 24) | (1 << channelNum);	
				/* switch channel,start A/D convert */
#if !ADC_INTERRUPT_FLAG
    while ( 1 )			/* wait until end of A/D convert */
    {
	regVal = *(volatile unsigned long *)(AD1_BASE_ADDR 
			+ ADC_OFFSET + ADC_INDEX * channelNum);
				/* read result of A/D conversion */
	if ( regVal & ADC_DONE )
	{
	    break;
	}
    }	
        
    AD1CR &= 0xF8FFFFFF;	/* stop ADC now */
    if ( regVal & ADC_OVERRUN )	/* save data when it's not overrun
				otherwise, return zero */
    {
	return ( 0 );
    }
    
    ADC_Data = ( regVal >> 6 ) & 0x3FF;
    return ( ADC_Data );	/* return A/D conversion value */
#else
    return ( channelNum );
#endif
}

/*********************************************************************************
**                            End Of File
*********************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久一级| 国产日韩欧美制服另类| 国产成人精品影视| 另类中文字幕网| 麻豆成人综合网| 美女网站在线免费欧美精品| 日韩精品国产欧美| 免费在线成人网| 精品一区二区三区免费毛片爱| 老鸭窝一区二区久久精品| 日本不卡免费在线视频| 另类欧美日韩国产在线| 韩国v欧美v日本v亚洲v| 精品一区二区综合| 成人一区二区在线观看| 色偷偷88欧美精品久久久| 欧美色综合影院| 日韩手机在线导航| 国产网站一区二区| 亚洲卡通欧美制服中文| 午夜精品久久久久| 国产在线播放一区| 色婷婷久久综合| 欧美一级视频精品观看| 久久久久九九视频| 亚洲精选视频免费看| 青青草97国产精品免费观看| 狠狠色综合日日| 不卡的电影网站| 欧美久久一二三四区| 欧美精品一区二区三区一线天视频| 日本一区二区三区高清不卡 | 亚洲gay无套男同| 免费观看一级特黄欧美大片| 国产精品一区二区在线观看不卡| 波多野结衣视频一区| 欧美日韩aaaaa| 久久久欧美精品sm网站| 亚洲一卡二卡三卡四卡| 国产精品综合久久| 69堂精品视频| 成人欧美一区二区三区| 日韩影视精彩在线| 色综合欧美在线视频区| 亚洲精品在线免费播放| 午夜精品123| 99久久精品久久久久久清纯| 欧美电影免费观看高清完整版在线观看| 国产精品乱子久久久久| 日韩成人免费电影| 成人app在线| 2020国产精品自拍| 午夜成人免费视频| 99久久国产综合精品女不卡| 久久女同性恋中文字幕| 天堂av在线一区| 91福利社在线观看| 中文字幕不卡三区| 激情小说亚洲一区| 欧美色男人天堂| 一区二区三区四区乱视频| 国产99久久久久久免费看农村| 欧美一区二区三区视频| 亚洲成人激情综合网| 一本大道久久a久久综合| 日本一区二区成人在线| 国内精品免费在线观看| 精品国产百合女同互慰| 日本不卡视频一二三区| 91麻豆精品国产| 激情五月激情综合网| 欧美群妇大交群的观看方式| 一区二区三区在线视频观看58| 99久久久无码国产精品| 久久九九国产精品| 国产成人免费视频网站 | 亚洲码国产岛国毛片在线| 国产黄色91视频| 国产欧美日韩亚州综合| 国产激情一区二区三区桃花岛亚洲| 日韩视频在线你懂得| 久久成人免费网| 欧美成人三级在线| 国产一区二区三区在线观看免费视频| 2021久久国产精品不只是精品| 久久成人久久爱| 久久久亚洲精华液精华液精华液| 国产精品一区二区久久不卡| 日本一区二区不卡视频| 成人精品视频网站| 中文字幕一区二区视频| 91久久人澡人人添人人爽欧美| 亚洲一二三四在线| 制服丝袜亚洲网站| 国产精品一区二区x88av| 久久精品人人做人人综合| 99久久精品一区二区| 亚洲女人小视频在线观看| 欧美福利视频导航| 激情久久五月天| 最新国产精品久久精品| 欧美日韩一区二区在线视频| 同产精品九九九| 久久精品夜色噜噜亚洲aⅴ| 99久久综合国产精品| 一区二区三区欧美| 精品免费视频.| 97精品久久久午夜一区二区三区| 天堂在线亚洲视频| 欧美激情艳妇裸体舞| 欧美一级二级在线观看| 高清久久久久久| 午夜精品久久久久影视| 国产精品久久久久久户外露出| 欧美视频日韩视频| 成人性视频免费网站| 亚洲成va人在线观看| 久久久影视传媒| 欧美精品久久天天躁| 成人国产一区二区三区精品| 奇米综合一区二区三区精品视频| 欧美国产日韩在线观看| 欧美一区二区在线观看| 91丨porny丨国产入口| 理论片日本一区| 一区二区三区中文字幕电影 | 久久夜色精品国产噜噜av| 一本色道久久综合亚洲aⅴ蜜桃| 美女视频网站久久| 亚洲精品国久久99热| 欧美国产1区2区| 精品对白一区国产伦| 欧美剧情电影在线观看完整版免费励志电影| 国产盗摄精品一区二区三区在线| 蜜臀av性久久久久av蜜臀妖精| 亚洲一区二区三区精品在线| 国产精品国产三级国产普通话三级| 91精品国产综合久久久久久久| 在线精品观看国产| 91色婷婷久久久久合中文| 国产剧情av麻豆香蕉精品| 蜜桃久久久久久| 国产一区二区三区视频在线播放| 婷婷一区二区三区| 亚洲一区二区三区四区在线免费观看| 国产精品免费网站在线观看| 久久婷婷成人综合色| 欧美成人一区二区三区在线观看 | 蜜臀av性久久久久蜜臀aⅴ流畅| 一区二区视频在线| 亚洲乱码国产乱码精品精98午夜| 欧美激情中文字幕| 国产精品乱人伦中文| 国产精品成人免费| 亚洲人成网站影音先锋播放| 亚洲免费看黄网站| 亚洲最大色网站| 天天综合色天天综合| 日韩福利电影在线| 日本女人一区二区三区| 九色综合狠狠综合久久| 久久99日本精品| 国产在线精品免费| hitomi一区二区三区精品| 一本一本大道香蕉久在线精品 | 日本va欧美va欧美va精品| 蜜桃视频免费观看一区| 狠狠色2019综合网| 丁香啪啪综合成人亚洲小说 | 91.com视频| 日韩免费性生活视频播放| 久久久国际精品| 亚洲欧美日韩系列| 亚洲成在线观看| 国产在线精品免费| 色综合一区二区| 欧美精品乱码久久久久久按摩| 精品国产网站在线观看| 国产日韩欧美在线一区| 亚洲一区二区av在线| 九一九一国产精品| 色婷婷久久久久swag精品| 日韩欧美国产综合| 亚洲天堂精品在线观看| 日本免费新一区视频| 波波电影院一区二区三区| 欧美情侣在线播放| 国产精品丝袜黑色高跟| 五月综合激情网| 粉嫩13p一区二区三区| 欧美日韩日日摸| 久久综合久久久久88| 亚洲愉拍自拍另类高清精品| 九九九精品视频| 99在线热播精品免费| 精品毛片乱码1区2区3区| 中文字幕亚洲在| 国产麻豆成人精品| 91精品国产色综合久久久蜜香臀| 中文字幕中文字幕一区二区|