欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    数字集成电路参数测试仪源程序.doc

    • 资源ID:17613176       资源大小:173KB        全文页数:24页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数字集成电路参数测试仪源程序.doc

    【精品文档】如有侵权,请联系网站删除,仅供学习与交流数字集成电路参数测试仪源程序.精品文档. 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: * 功能 :* 上位机使用EasyARM软件全仿真的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/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<<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; /AD0.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 #define 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<<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 控制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.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 AD03 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 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 = 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); /* 函数名称 :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) /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 要发送的数据* 出口参数 :无*/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, 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'结束* 出口参数 :无 */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; / 设置SPI时钟分频 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 待发送的数据* 出口参数:返回值为读取的数据*/uint8 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 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*/void 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)|(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 & (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 << 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 << 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; uint16 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 << 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 << 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 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 << 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 << 22)|(1 << 27)|(1 << 24); while(AD1DR & (0x80000000)=0); data3= (AD1DR

    注意事项

    本文(数字集成电路参数测试仪源程序.doc)为本站会员(豆****)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开