數(shù)字集成電路參數(shù)測試儀源程序_第1頁
數(shù)字集成電路參數(shù)測試儀源程序_第2頁
數(shù)字集成電路參數(shù)測試儀源程序_第3頁
數(shù)字集成電路參數(shù)測試儀源程序_第4頁
數(shù)字集成電路參數(shù)測試儀源程序_第5頁
已閱讀5頁,還剩18頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、 File name: main.c* Last modified Date: 2004-09-16* Last Version: 1.0* Descriptions: The main() function example template*-* Created by: lls* Created date: 2006-09-16* Version: 1.0* Descriptions: The original version*-* Modified by: * Modified date: 2006-09-21* Version:* Descriptions: * 功能 :* 上位機使用E

2、asyARM軟件全仿真的DOS窗口觀察。* 說明 :* 通訊波特率115200,8位數(shù)據(jù)位,1位停止位,無奇偶校驗。*#include "config.h"#include "stdio.h"#include "math.h"uint32 DA_OUT,DCT;uint32 value67;/*數(shù)組:六個參數(shù)的標準值(比較錯誤時用)*/uint32 biaozhunzhi6=0.8*413, /VIL 2.0*413, /VIH 2.7*413, /VOH 0.5*413, /VOL 4*1024/2480, /IIL 8*1024/

3、2480; /IOL /*數(shù)組:繼電器使用情況*/uint32 a63=(1<<8) |(1<<17),(1<<8),(1<<17), /J1 J7 (1<<9) |(1<<18),(1<<9),(1<<18), /J2 J8 (1<<10)|(1<<19),(1<<10),(1<<19), /J3 J9 (1<<12)|(1<<20),(1<<12),(1<<20), /J4 J10 (1<<

4、;13)|(1<<23),(1<<13),(1<<23), /J5 J11 (1<<16)|(1<<27),(1<<16),(1<<27); /J6 J12 uint8 ay7=1,2,3,4,5,6,7; /數(shù)組:六個參數(shù)的名稱uint8 fm1,fm2,fm3,fm4,fm5,fm6; /非門編號 uint8 zj_flag; /三角波過頂標志 uint8 rcv_buf18;uint8 rcv_dat0; /*實際電路中各參數(shù)要修正的偏差系數(shù)*/const float ad01x = 1.905; /AD

5、0.1測VOH const float ad03x = 1.905; /AD0.3測VIH const float ad05x = 0.500; /AD0.5測IILconst float ad15x = 0.500; /AD1.5測VILconst float ad16x = 0.500; /AD1.6測VOLconst float ad17x = 1.900; /AD1.7測IOL(看為高電平) /*模擬開關CD4051 GPIO口*/#define A0 1<<16 /P1.16 IO1DIR #define A1 1<<17 /P1.17 IO1DIR #def

6、ine A2 1<<24 /P1.24 IO1DIR /*繼電器 GPIO口*/ #define J1 1<<8 /P0.8 IO0DIR 非門1 (左)#define J2 1<<9 /P0.9 IO0DIR 非門2#define J3 1<<10 /P0.10 IO0DIR 非門3#define J4 1<<12 /P0.12 IO0DIR 非門4#define J5 1<<13 /P0.13 IO0DIR 非門5#define J6 1<<16 /P0.16 IO0DIR 非門6#define J7 1&

7、lt;<17 /P0.17 IO0DIR 非門1 (右)#define J8 1<<18 /P0.18 IO0DIR 非門2#define J9 1<<19 /P0.19 IO0DIR 非門3#define J10 1<<20 /P0.20 IO0DIR 非門4#define J11 1<<23 /P0.23 IO0DIR 非門5#define J12 1<<27 /P0.27 IO0DIR 非門6 /*LED燈 GPIO口*/const uint32 LED1 = (1 << 18); /P1.18 IO1DIR

8、控制LED1低電平點亮const uint32 LED2 = (1 << 19); /P1.19 IO1DIR 控制LED2低電平點亮const uint32 LED3 = (1 << 20); /P1.20 IO1DIR 控制LED3低電平點亮const uint32 LED4 = (1 << 21); /P1.21 IO1DIR 控制LED4低電平點亮const uint32 LED5 = (1 << 22); /P1.22 IO1DIR 控制LED5低電平點亮const uint32 LED6 = (1 << 23); /P1.

9、23 IO1DIR 控制LED6低電平點亮 /*key1 UART0 SPI BEEP DAC GPIO口*/#define UART0 0x05 /P0.0 P0.1控制UART0,發(fā)送到PC機顯示#define SPI 0x00005500 /P0.4 P0.5 P0.6 P0.7連接SPI,數(shù)碼管顯示用 #define DAC 2<<18 /P0.25連接到DAC #define key1 1<<25 /P1.25連接到按鍵key1 /*AD GPIO口*/#define AD01 1<<24 /P0.28連接到AD0.1測VOH#define AD0

10、3 1<<28 /P0.30連接到AD0.3測VIH#define AD05 1<<20 /P0.26連接到AD0.5測IIL#define AD15 3<<30 /P0.15連接到AD1.5測VIL#define AD16 2<<10 /P0.21連接到AD1.6測VOL#define AD17 1<<12 /P0.22連接到AD1.7測IOL#define UART_BPS 115200 / 通訊波特率115200#define HC595_CS (1 << 29) / P0.29口為74HC595的片選uint32

11、IODIR0;/* 函數(shù)名稱 :DelayNS()* 函數(shù)功能 :長軟件延時* 入口參數(shù) :dly 延時參數(shù),值越大,延時越久* 出口參數(shù) :無*/void DelayNS (uint32 dly) uint32 m; for ( ; dly>0; dly-) for (m=0; m<5000; m+);/* 函數(shù)名稱 :UART0_Init()* 函數(shù)功能 :初始化串口0:波特率115200,8位數(shù)據(jù)位,1位停止位,無奇偶校驗。* 入口參數(shù) :無* 出口參數(shù) :無*/void UART0_Init (void) uint16 Fdiv; U0LCR = 0x83; / DLAB

12、= 1 Fdiv = (Fpclk / 16) / UART_BPS; U0DLM = Fdiv / 256; U0DLL = Fdiv % 256; U0LCR = 0x03;/* 函數(shù)名稱 :UART0_GetByte()* 函數(shù)功能 :從串口接收1字節(jié)數(shù)據(jù),使用查詢方式接收。* 入口參數(shù) :無* 出口參數(shù) :接收到的數(shù)據(jù)*/uint8 UART0_GetByte (void) uint8 rcv_dat; while (U0LSR & 0x01) = 0); rcv_dat = U0RBR; rcv_dat0=rcv_dat-48; return (rcv_dat); /* 函數(shù)

13、名稱 :UART0_GetStr()* 函數(shù)功能 :從串口接收* 入口參數(shù) : s 指向接收數(shù)據(jù)數(shù)組的指針* n 接收的個數(shù)* 出口參數(shù) : 無*/void UART0_GetStr (uint8 *s, uint32 n) uint8 i="0" for ( ; n>0; n-) *s+ = UART0_GetByte(); rcv_bufi+=rcv_dat0; biaozhunzhi0=(rcv_buf0*100+rcv_buf1*10+rcv_buf2) /100; biaozhunzhi1=(rcv_buf3*100+rcv_buf4*10+rcv_buf5

14、) /100; biaozhunzhi2=(rcv_buf6*100+rcv_buf7*10+rcv_buf8) /100; biaozhunzhi3=(rcv_buf9*100+rcv_buf10*10+rcv_buf11)/100; biaozhunzhi4=(rcv_buf12*100+rcv_buf13*10+rcv_buf14)/100; biaozhunzhi5=(rcv_buf15*100+rcv_buf16*10+rcv_buf16)/100;/* 函數(shù)名稱 :UART0_SendByte()* 函數(shù)功能 :向串口發(fā)送字節(jié)數(shù)據(jù),并等待數(shù)據(jù)發(fā)送完畢。* 入口參數(shù) :data 要發(fā)

15、送的數(shù)據(jù)* 出口參數(shù) :無*/void UART0_SendByte (uint8 data) U0THR = data; while (U0LSR & 0x40) = 0); / 等待數(shù)據(jù)發(fā)送完畢/* 函數(shù)名稱 :PC_DispChar()* 函數(shù)功能 :向PC機發(fā)送顯示字符。* 入口參數(shù) :x 顯示字符的橫坐標* y 顯示字符的縱坐標* chr 顯示的字符,不能為ff* color 顯示的狀態(tài),包括前景色、背景色、閃爍位。* 與DOS字符顯示一樣:03,前景色,46,背景色,7,閃爍位。* 出口參數(shù) :無 */void PC_DispChar (uint8 x, uint8 y,

16、uint8 chr, uint8 color) UART0_SendByte(0xff); / 起始字符 UART0_SendByte(x); UART0_SendByte(y); UART0_SendByte(chr); UART0_SendByte(color);/* 函數(shù)名稱 :ISendStr()* 函數(shù)功能 :向上位機發(fā)送字符串。* 入口參數(shù) :x 顯示字符的橫坐標* y 顯示字符的縱坐標* color 顯示的狀態(tài),包括前景色、背景色、閃爍位。* 與DOS字符顯示一樣:03,前景色,46,背景色,7,閃爍位。* str 要發(fā)送的字符串,以'0'結束* 出口參數(shù) :無

17、*/void ISendStr (uint8 x, uint8 y, uint8 color, char *str) while (1) if (*str = '0') break; / 結束字符 PC_DispChar(x+, y, *str+, color); if (x >= 80) x = 0; y+; /* 函數(shù)名稱:MSPI_Init()* 函數(shù)功能:初始化SPI接口,設置為主機。* 入口參數(shù):無* 出口參數(shù):無*/void MSPI_Init(void) IODIR0=IODIR; IODIR = HC595_CS; S0PCCR = 0x52; / 設置S

18、PI時鐘分頻 S0PCR =(0 << 3) | / CPHA = 0, 數(shù)據(jù)在SCK 的第一個時鐘沿采樣 (1 << 4) | / CPOL = 1, SCK 為低有效 (1 << 5) | / MSTR = 1, SPI 處于主模式 (0 << 6) | / LSBF = 0, SPI 數(shù)據(jù)傳輸MSB (位7)在先 (0 << 7); / SPIE = 0, SPI 中斷被禁止/* 函數(shù)名稱:MSPI_SendData()* 函數(shù)功能:向SPI總線發(fā)送數(shù)據(jù)。* 入口參數(shù):data 待發(fā)送的數(shù)據(jù)* 出口參數(shù):返回值為讀取的數(shù)據(jù)*/u

19、int8 MSPI_SendData(uint8 data) IOCLR = HC595_CS; / 片選74HC595 SPI_SPDR = data; while( 0 = (SPI_SPSR & 0x80); / 等待SPIF置位,即等待數(shù)據(jù)發(fā)送完畢 IOSET = HC595_CS; return(SPI_SPDR);/* 此表為LED0F以及L、P的字模 */uint8 const DISP_TAB19 = / 0 1 2 3 4 5 6 7 8 9 0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8, 0x80,0x90,/ A b C d E

20、F 0x88, 0x83, 0xC6, 0xA1,0x86, 0x8E,/ L P C 0xC7, 0x8C,0xC6 ;/* 函數(shù)名稱 :DA ()* 函數(shù)功能 :向端口送出DA值。* 調(diào)試說明 :*/void DA (void) if(DA_OUT<1023) DA_OUT+; DACR=(DA_OUT<<6); /* 函數(shù)名稱 :csh0()* 函數(shù)功能 :測量VILVIH* 調(diào)試說明 :*把各個參數(shù)的值存到數(shù)組value里,其對應關系如下:VIL value0VIH value1VOH value2VOL value3IIL value4IOL value5*/voi

21、d csh0 (void) uint32 data,data1; DA_OUT=0; DA(); if(DA_OUT>=240) IO1PIN=(IO1PIN |(0x3f<<18)&(1<<19); /LED2 測量VIH /*先測AD1.6,將其值作為條件測AD0.3 VIH*/ AD1CR = (1 << 6)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1 << 27)|(

22、1 << 24); while(AD1DR & (0x80000000) )=0); data1= (AD1DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data1=data1*ad16x; AD0CR = (1 << 3)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1 << 27)|(1 << 24); while(AD0DR &am

23、p; (0x80000000) )=0); if (data1<=510)&(data1>=490) /0.5V左右的范圍 fm2=(fm2+1)%7; valuefm2-11= data1; else IO1PIN=(IO1PIN |(0x3f<<18)&(1<<18);/LED1 測量VIL /*先測AD0.1,將其值作為條件 VIL*/ AD0CR = (1 << 1)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 <<

24、21)|(0 << 22)|(1 << 27)|(1 << 24); while(AD0DR & (0x80000000) )=0); data= (AD0DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data="data"*ad01x; AD1CR = (1 << 5)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1

25、 << 27)|(1 << 24); while(AD1DR & (0x80000000) )=0); if(data>=2690)&(data<=2710) /AD0.1 VOH="2".7V為條件 測AD1.5 VIL="0".8V fm1=(fm1+1)%7; valuefm1-10= data; /fm1+=1; /* 函數(shù)名稱 :csh1()* 函數(shù)功能 :測量VOHVOL* 調(diào)試說明 :*/void csh1 (void) uint32 data,data1,data2,data3; uin

26、t16 ddd1,ddd2; /DA輸出值/*AD1.5*k輸出VIL=0.8V為條件 測量AD0.1 VOH="2".7V*/ IO1PIN=(IO1PIN |(0x3f<<18)&(1<<20); /LED3 測量VOH ddd1=165;loop1: DACR=(ddd1<<6); DelayNS(1); AD1CR = (1 << 5)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 <

27、;< 22)|(1 << 27)|(1 << 24); while(AD1DR & (0x80000000)=0); data= (AD1DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data="data"*ad15x; if(data<=803) if (data>=797) /判斷是否為0.8V DelayNS(1); AD0CR = (1 << 1)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 &

28、lt;< 17)|(1 << 21)|(0 << 22)|(1 << 27)|(1 << 24); while(AD0DR & (0x80000000)=0); data1= (AD0DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data1=data1*ad01x; fm3=(fm3+1)%7; valuefm3-12= data1; /fm3+=1; else ddd1=(ddd1+1)%1024; goto loop1; else ddd1=(ddd1-1)%1024; goto

29、 loop1; /*AD0.3*k輸出VIH=2V為條件 測量AD1.6 VOL="0".5V*/ DelayNS(100); IO1PIN=(IO1PIN |(0x3f<<18)&(1<<21); /LED4 測量VOL ddd2=826;loop2: DACR=(ddd2<<6); AD0CR = (1 << 3)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1

30、<< 27)|(1 << 24); while(AD0DR & (0x80000000)=0); data2= (AD0DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data2=data2*ad03x; if(data2<=2005) if (data2>=1995) /判斷是否為2.0V AD1CR = (1 << 6)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0

31、 << 22)|(1 << 27)|(1 << 24); while(AD1DR & (0x80000000)=0); data3= (AD1DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data3=data3*ad16x; fm4=(fm4+1)%7; valuefm4-13= data3; /fm4+=1; else /如果>2.0V ddd2-; goto loop2; else /<2.0V ddd2+; goto loop2; /* 函數(shù)名稱 :csh2()* 函數(shù)功能 :測量I

32、ILIOL* 調(diào)試說明 :*/void csh2 (void) uint32 data,data1,data2; uint16 ddd3; /DA輸出值/*AD1.5*k輸出VIL=0.4V為條件 測量AD0.5 IIL="-0".4mA*/ DelayNS(100); IO1PIN=(IO1PIN |(0x3f<<18)&(1<<22); /LED5 測量IIL ddd3=83; loop3: DACR=(ddd3<<6); AD1CR = (1 << 5)|(Fpclk / 1000000 - 1) <<

33、; 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1 << 27)|(1 << 24); while(AD1DR & (0x80000000)=0); data=(AD1DR >> 6) & 0x3ff; data="data"*ad15x; if(data<=402) if (data>=398) /AD1.5=0.4V為條件 測AD0.5 IIL AD0CR =(1 << 5)|(Fpclk / 10000

34、00 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1 << 27)|(1 << 24); while(AD0DR & (0x80000000)=0); data1= (AD0DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data1=data1*ad05x; fm5=(fm5+1)%7; valuefm5-14= (data1-data)/300; /300歐姆 根據(jù)實際修改 /fm5+=1; e

35、lse ddd3-; goto loop3; else ddd3+; goto loop3; /*測量AD1.7 IOL (硬件)調(diào)節(jié)電位器使得恒壓輸出為0.5V*/ IO1PIN=(IO1PIN |(0x3f<<18)&(1<<23); /LED6 測量IOL DelayNS(2); AD1CR =(1 << 7)|(Fpclk / 1000000 - 1) << 8)|(0 << 16)|(0 << 17)|(1 << 21)|(0 << 22)|(1 << 27)|(1 &

36、lt;< 24); while(AD1DR & (0x80000000)=0); data2= (AD1DR >> 6) & 0x3ff; /讀取ADC結果,并清除DONE標志位 data2=data2*ad17x; fm6=(fm6+1)%7; valuefm6-15= (data2-500)/390; /390歐姆 根據(jù)實際修改 /fm6+=1;/* 函數(shù)名稱 :bijiao()* 函數(shù)功能 :把存到數(shù)組的測量值與標準值相比較,如有錯誤則發(fā)送到valuei6顯示* 調(diào)試說明 :*/void bijiao (void) uint8 i; uint32 j; for(i=0;i<6;i+) if(valuei0<b

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論