数字集成电路参数测试仪源程序_第1页
数字集成电路参数测试仪源程序_第2页
数字集成电路参数测试仪源程序_第3页
数字集成电路参数测试仪源程序_第4页
数字集成电路参数测试仪源程序_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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位数据位,1位停止位,无奇偶校验。*#include "config.h"#include "stdio.h"#include "math.h"uint32 DA_OUT,DCT;uint32 value67;/*数组:六个参数的标准值(比较错误时用)*/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 /*数组:继电器使用情况*/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; /数组:六个参数的名称uint8 fm1,fm2,fm3,fm4,fm5,fm6; /非门编号 uint8 zj_flag; /三角波过顶标志 uint8 rcv_buf18;uint8 rcv_dat0; /*实际电路中各参数要修正的偏差系数*/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,发送到PC机显示#define SPI 0x00005500 /P0.4 P0.5 P0.6 P0.7连接SPI,数码管显示用 #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;/* 函数名称 :DelayNS()* 函数功能 :长软件延时* 入口参数 :dly 延时参数,值越大,延时越久* 出口参数 :无*/void DelayNS (uint32 dly) uint32 m; for ( ; dly>0; dly-) for (m=0; m<5000; m+);/* 函数名称 :UART0_Init()* 函数功能 :初始化串口0:波特率115200,8位数据位,1位停止位,无奇偶校验。* 入口参数 :无* 出口参数 :无*/void UART0_Init (void) uint16 Fdiv; U0LCR = 0x83; / DLAB

12、= 1 Fdiv = (Fpclk / 16) / UART_BPS; U0DLM = Fdiv / 256; U0DLL = Fdiv % 256; U0LCR = 0x03;/* 函数名称 :UART0_GetByte()* 函数功能 :从串口接收1字节数据,使用查询方式接收。* 入口参数 :无* 出口参数 :接收到的数据*/uint8 UART0_GetByte (void) uint8 rcv_dat; while (U0LSR & 0x01) = 0); rcv_dat = U0RBR; rcv_dat0=rcv_dat-48; return (rcv_dat); /* 函数

13、名称 :UART0_GetStr()* 函数功能 :从串口接收* 入口参数 : s 指向接收数据数组的指针* n 接收的个数* 出口参数 : 无*/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;/* 函数名称 :UART0_SendByte()* 函数功能 :向串口发送字节数据,并等待数据发送完毕。* 入口参数 :data 要发

15、送的数据* 出口参数 :无*/void UART0_SendByte (uint8 data) U0THR = data; while (U0LSR & 0x40) = 0); / 等待数据发送完毕/* 函数名称 :PC_DispChar()* 函数功能 :向PC机发送显示字符。* 入口参数 :x 显示字符的横坐标* y 显示字符的纵坐标* chr 显示的字符,不能为ff* color 显示的状态,包括前景色、背景色、闪烁位。* 与DOS字符显示一样:03,前景色,46,背景色,7,闪烁位。* 出口参数 :无 */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);/* 函数名称 :ISendStr()* 函数功能 :向上位机发送字符串。* 入口参数 :x 显示字符的横坐标* y 显示字符的纵坐标* color 显示的状态,包括前景色、背景色、闪烁位。* 与DOS字符显示一样:03,前景色,46,背景色,7,闪烁位。* str 要发送的字符串,以'0'结束* 出口参数 :无

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+; /* 函数名称:MSPI_Init()* 函数功能:初始化SPI接口,设置为主机。* 入口参数:无* 出口参数:无*/void MSPI_Init(void) IODIR0=IODIR; IODIR = HC595_CS; S0PCCR = 0x52; / 设置S

18、PI时钟分频 S0PCR =(0 << 3) | / CPHA = 0, 数据在SCK 的第一个时钟沿采样 (1 << 4) | / CPOL = 1, SCK 为低有效 (1 << 5) | / MSTR = 1, SPI 处于主模式 (0 << 6) | / LSBF = 0, SPI 数据传输MSB (位7)在先 (0 << 7); / SPIE = 0, SPI 中断被禁止/* 函数名称:MSPI_SendData()* 函数功能:向SPI总线发送数据。* 入口参数:data 待发送的数据* 出口参数:返回值为读取的数据*/u

19、int8 MSPI_SendData(uint8 data) IOCLR = HC595_CS; / 片选74HC595 SPI_SPDR = data; while( 0 = (SPI_SPSR & 0x80); / 等待SPIF置位,即等待数据发送完毕 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 ;/* 函数名称 :DA ()* 函数功能 :向端口送出DA值。* 调试说明 :*/void DA (void) if(DA_OUT<1023) DA_OUT+; DACR=(DA_OUT<<6); /* 函数名称 :csh0()* 函数功能 :测量VILVIH* 调试说明 :*把各个参数的值存到数组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; /* 函数名称 :csh1()* 函数功能 :测量VOHVOL* 调试说明 :*/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; /* 函数名称 :csh2()* 函数功能 :测量I

32、ILIOL* 调试说明 :*/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欧姆 根据实际修改 /fm5+=1; e

35、lse ddd3-; goto loop3; else ddd3+; goto loop3; /*测量AD1.7 IOL (硬件)调节电位器使得恒压输出为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欧姆 根据实际修改 /fm6+=1;/* 函数名称 :bijiao()* 函数功能 :把存到数组的测量值与标准值相比较,如有错误则发送到valuei6显示* 调试说明 :*/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. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论