0

关于投票
波形发生器(毕业设计)

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

entity duoxing is
generic(ACCWidth : Integer := 16); --相位累加器的长度2^N (2^ACCWidth)
port (
CLK: in std_logic; --系统时钟 FClk
-- STEP: in std_logic_vector(ACCWidth-1 downto 0); --步进,即相位累加器的累加增量,控制输出频率 2^M 频率控制字
CHOICE: in std_logic_vector(1 downto 0); --波形选择信号 "00":正弦; "01":三角波; "10":方波; "11":不输出(恒为低电平)
Key : in std_logic;
DAOUT : out std_logic_vector(7 downto 0) --8位DA输出模拟信号,直通方式,如需时钟控制则要修改
);
end;

architecture dacc of duoxing is
signal ACC:std_logic_vector(ACCWidth-1 downto 0):=(others =>'0');
signal KEYADD:std_logic_vector(ACCWidth-1 downto 0):="0000000011111111";
begin
process(CLK)--,STEP)
begin
if(CLK'event and CLK='1') then
ACC<=ACC+KEYADD;
end if;
end process;
process(key)
begin
if(key' event and key='1') then
KEY<=KEYADD+1;
end if;
end process;

process(CHOICE,ACC)
begin
case CHOICE is
when "00"=> --正弦
case ACC(ACCWidth-1 downto ACCWidth-8) is
when "00000000" => DAOUT <= "10000000";
when "00000001" => DAOUT <= "10000011";
when "00000010" => DAOUT <= "10000110";
when "00000011" => DAOUT <= "10001001";
when "00000100" => DAOUT <= "10001101";
when "00000101" => DAOUT <= "10010000";

省略

when "11111110" => DAOUT <= "01111010";
when "11111111" => DAOUT <= "01111101";
when others => DAOUT <= (others =>'0');
end case;
when "01"=> --三角波
case ACC(ACCWidth-1) is
when '0' => DAOUT <= ACC(ACCWidth-2 downto ACCWidth-9); --模二加,左移一位
when '1' => DAOUT <= ("11111111" - ( ACC(ACCWidth-2 downto ACCWidth-9) ));
when others => DAOUT <= (others =>'0');
end case;
when "10"=> --方波
case ACC(ACCWidth-1) is
when '0' => DAOUT <= (others =>'0');
when '1' => DAOUT <= (others =>'1');
when others => DAOUT <= (others =>'0');
end case ;
when "11" => DAOUT <= ACC(ACCWidth-1 downto ACCWidth-8);
when others => DAOUT <= (others =>'0');
end case;
end process;
end;

出现如下错误:

Error: VHDL error at duoxing.vhd(29): can't write to interface object "Key" of mode IN
Error: VHDL error at duoxing.vhd(29): can't determine definition of operator ""+"" -- found 0 possible definitions
Error: Ignored construct dacc at duoxing.vhd(16) because of previous errors
Info: Found 0 design units, including 0 entities, in source file duoxing.vhd

系统分类: CPLD/FPGA
用户分类: 学习笔记
标签: CPLD/VHDL
来源: 转贴
发表评论 阅读全文(527) | 回复(0)

0

关于投票
液晶画面移动起来!

以前的文章写过1602液晶的显示程序,现在将液晶显示的画面移动起来,其实很简单,大家实验!

/*
***************************************************************************
*项目名称:    51单片机学习开发系统          
*本文件名称:LCD1602.c  
* 完成作者 : 单片机初学者  
* 当前版本 : V3.0       
* 完成日期 :
* 描    述 : 
*                此程序实现,完成液晶的驱动程序,可以显示任意的ASCII字符
*            
博客:http://blog.ednchina.com/ahai0306/
*  开发板介绍:http://blog.ednchina.com/ahai0306/84416/message.aspx

论坛:http://dianzi.5d6d.com/?fromuser=mcu_51          
****************************************************************************
*/

#include  <reg52.h>     //调用头文件(单片机内部的寄存器定义)

/******本段为硬件I/O口定义********/
sbit  KEY0   = P0 ^ 0;  //KEY和发光管复用,请将跳线插到KEY端
sbit  KEY1   = P0 ^ 1;
sbit  KEY2   = P0 ^ 2;
sbit  KEY3   = P0 ^ 3;
sbit  DIG0   = P0 ^ 4;  //数码管位0
sbit  DIG1   = P0 ^ 5;  //数码管位1

sbit  BUZZ   = P3 ^ 3;  //蜂鸣器
sbit  LCD_RW = P3 ^ 6; 
sbit  LCD_RS = P3 ^ 7; 
sbit  LCD_E  = P3 ^ 4;

#define  LED_SEG    P1  //数码管
#define  LCD_DATA   P2   //LCD DATA
#define  LCD_BUSY   0x80  // 用于检测LCD的BUSY标识(本程序中用的延时,未检测)
//LCD显示内容,定义到代码段
 unsigned  char code LcdBuf1[]= {"welcom!"};
unsigned  char code LcdBuf2[]= {"MCU-STUDY-BOARD"};

//函数声明
void  lcd_init(void);
void  display_string(unsigned  char x,unsigned  char y,unsigned  char *s);
void  disp_selec(unsigned  char bit_selec,unsigned  char  seg);

void  WriteCommandLcd(unsigned  char wdata);


 /**************************************************
** 函数名称: dellay
** 入口参数:h(unsigned int型)
** 出口参数:无
** 功能描述: 短暂延时,使用11.0592晶体,约0.01MS
****************************************************/

void dellay(unsigned int  h)
{
  while(h--);    //0.01MS
}


/************主程序**************/
main()
{
    lcd_init();
 display_string(3,0,LcdBuf1);  //显示第一行,从第3个位置开始
 display_string(0,1,LcdBuf2);  //显示第二行,从第0个位置开始
 
   while(1)    //单片机待机
   { 

    dellay(23000);            //滚动的延时时间
   WriteCommandLcd(0x18);   //画面向左移动1位

    //WriteCommandLcd(0x1c);   //画面向右移动1位

    }

}

/**************************************************
** 函数名称: WriteDataLcd
** 入口参数:wdata(unsigned  char型)
** 出口参数:无
** 功能描述: 写数据到LCD
****************************************************/

void  WriteDataLcd(unsigned  char wdata)
{
   LCD_DATA=wdata;
   LCD_RS=1;
   LCD_RW=0;
   LCD_E=0;
   dellay(100);     //短暂延时,代替检测忙状态

   LCD_E=1;
}
/**************************************************
** 函数名称: WriteCommandLcd
** 入口参数:wdata(unsigned  char型)
** 出口参数:无
** 功能描述: 写命令到LCD
****************************************************/

void  WriteCommandLcd(unsigned  char wdata)
{
   LCD_DATA=wdata;
   LCD_RS=0;
   LCD_RW=0;
   LCD_E=0;
   dellay(100);      //短暂延时,代替检测忙状态
   LCD_E=1;
}

//LCD初始化
void  lcd_init(void)
{
     LCD_DATA=0;
     WriteCommandLcd(0x38);
     dellay(1000);
     WriteCommandLcd(0x38); //显示模式设置
    WriteCommandLcd(0x08); //关闭显示
    WriteCommandLcd(0x01); //显示清屏
    WriteCommandLcd(0x06); //显示光标移动设置
    WriteCommandLcd(0x0c); //显示开及光标移动设置
}
/**************************************************
** 函数名称: display_xy
** 入口参数:x(unsigned  char型),y(unsigned  char型)
** 出口参数:无
** 功能描述: 设置光标位置, x是列号,y是行号
****************************************************/
void  display_xy(unsigned  char x,unsigned  char y)
{
    if(y==1)
   x+=0x40;
  x+=0x80;
  WriteCommandLcd(x);
}
/********************************************************************
** 函数名称: display_char
** 入口参数:x(unsigned  char型),y(unsigned  char型),dat(unsigned  char型)
** 出口参数:无
** 功能描述: 在具体位置显示单个字符,x是列号,y是行号
*********************************************************************/

void  display_char(unsigned  char x,unsigned  char y,unsigned  char dat)
{
  display_xy(x,y);
  WriteDataLcd(dat);
}

/*********************************************************************
** 函数名称: display_string
** 入口参数:x(unsigned  char型),y(unsigned  char型),s(指针型)
** 出口参数:无
** 功能描述: 在具体位置显示字符串,以/0结束,x是列号,y是行号
**********************************************************************/

void  display_string(unsigned  char x,unsigned  char y,unsigned  char *s)
{
  display_xy(x,y);
  while(*s)
  {
   WriteDataLcd(*s);
   s++;
  }
}

增加硬件原理图:

点击看大图

系统分类: 单片机
用户分类: 学习笔记
标签: 1602
来源: 转贴
发表评论 阅读全文(192) | 回复(0)

0

关于投票
USB接口芯片CH375的原理及应用
    随着计算机技术的快速发展,USB移动存储设备的使用已经非常普遍,因此在一些需要转存数据的设备、仪器上使用USB移动存储设备接口芯片便相继产生了,CH375就是其中之一,它是一个USB总线的通用接口芯片,支持HOST主机方式和SLAVE设备方式。

       在本地端,CH375具有8位数据总线和读、写、片选控制线以及中断输出,可以方便地挂接到单片机/DSP/MCU等控制器的系统总线上。在USB主机方式下,CH375还提供了串行通信方式,通过串行输入、串行输出和中断输出与单片机/DSP/MCU等相连接。CH375的USB主机方式支持各种常用的USB全速设备,外部单片机/DSP/MCU可以通过CH375按照相应的USB协议与USB设备通信。

       CH375芯片内部结构

       1 、内部结构

 & nbsp;     CH375芯片内部集成了PLL倍频器、主从USB接口SIE、数据缓冲区、被动并行接口、异步串行接口、命令解释器、控制传输的协议处理器、通用的固件程序等。CH375芯片引脚排列如图1所示。
 

CH375芯片引脚排列

                                                                             图   1
      


       2 、内部物理端点

       CH375芯片内部具有7个物理端点。
       端点0是默认端点,支持上传和下传,上传和下传缓冲区各是8B;端点1包括上传端点和下传端点,上传和下传缓冲区各是8B,上传端点的端点号是81H,下传端点的端点号是01H;端点2包括上传端点和下传端点,上传和下传缓冲区各是64B,上传端点的端点号是82H,下传端点的端点号是02H。

       主机端点包括输出端点和输入端点,输出和输入缓冲区各是64B,主机端点与端点2合用同一组缓冲区,主机端点的输出缓冲区就是端点2的上传缓冲区,主机端点的输入缓冲区就是端点2的下传缓冲区。 其中,CH375的端点0、端点1、端点2只用于USB设备方式,在USB主机方式下只需要用到主机端点。

       软件接口

       对于USB存储设备的应用,CH375直接提供了数据块的读写接口,以512b的物理扇区为基本读写单位,从而将USB存储设备简化为一种外部数据存储器,单片机可以自由读写USB存储设备中的数据,也可以自由定义其数据结构。

       CH375以C语言子程序库提供了USB存储设备的文件级接口,这些应用层接口API包含了常用的文件级操作,可以移植并嵌入到各种常用的单片机程序中。

       CH375的U盘文件级子程序库具有以下特性:支持常用的FAT12、FAT16 和FAT32 文件系统,磁盘容量可达100GB以上,支持多级子目录,支持8.3格式的大写字母文件名,支持文件打开、新建、删除、读写以及搜索等。

    CH375的文件级接口API子程序需要大约600b的随机存储器RAM 作为缓冲区。所有API在调用后都有操作状态返回,但不一定有应答数据。有关API参数的说明请参考CH375数据手册。

       CH375在单片机读写U盘中的电路原理图

MCS

                                           &nbs

p;                          图   2

       图2给出了MCS-51单片机读写U盘的电路原理图,如果CH375芯片的TXD引脚悬空或者没有通过下接电阻接地,那么CH375工作于串口方式。在串口方式下,CH375只需要与单片机/DSP/MCU连接3个信号线,TXD引脚、RXD引脚以及INT#引脚,其他引脚都可以悬空。除了连接线较少之外,其他外围电路与并口方式基本相同。由于INT#引脚和TXD 引脚在CH375复位期间只能提供微弱的高电平输出电流,在进行较远距离的连接时,为了避免INT#或者TXD在CH375复位期间受到干扰而导致单片机误操作,可以在INT#引脚或者TXD引脚上加阻值为1~5kΩ的上拉电阻,以维持较稳定的高电平。在CH375芯片复位完成后,INT#引脚和TXD引脚将能够提供5mA的高电平输出电流或者5mA的低电平吸入电流。

       单片机读写U盘的接口

       由于CH375内置了处理Mass-Storage海量存储设备的专用通信协议的固件,所以嵌入式系统的单片机可以通过CH375将U盘(USB闪存盘、USB外置硬盘)作为可移动的大容量存储器。数据读写只需要几条指令,而不需要详细了解USB通信协议。

       如果嵌入式系统需要将USB存储设备组织为文件系统,那么可以直接调用CH375文件级子程序库提供的接口API,由子程序库处理文件系统。

       CH375主机USB-HOST的电路设计注意事项

       某些USB设备带电插入时常出现如下问题: 

       (1)、CH375复位或者单片机复位(尤其是采用uP 监控电路的单片机系统)。 

       (2)、 CH375或者单片机突然工作不正常,失去控制。 

       (3)、 CH375芯片的工作电流突然增大并且持续如此,时间长了芯片发热烫手。

       出现上述问题时可参考如下解决方法: 

       (1)、给USB插座单独供电,这样即使USB设备刚插上时存在电容充电过程,也不会影响单片机和CH375。变通方法是,将5V主电源分别通过两个独立的限流电感后(或者在PCB中电源线分开走),一组提供给CH375和单片机等,另一组提供给USB插座。 

  (2)、在USB插座前串接限流电阻或者电感,并在USB插座电源上并联储能用的电解电容。如果用电感也可以限制电流突变,防止电源电压突降,但是用电感在USB设备拔出后,容易在USB插座中产生过冲高压,所以必须接储能电容。(注意,在第一版CH375评估板的原理图中已经标出USB插座的限流电阻R1为1Ω,建议将其换为阻值5Ω的电阻或者保险电阻) 

       (3)、其他临时的解决方法(不推荐):①在USB设备与USB插座之间加入USB延长线。②在主电源上并联较大的储能电容,在U盘刚插入时提供足够的瞬时电能,减少对电源电压的影响。 

      (4)、参考目前计算机端的解决方法:USB端口的电源供给是通过保险电阻或者限流电感提供的,这些能够限制瞬时电流。对于计算机前面板的USB端口,由于本身通过一段较长的连接导线,自然减弱了对主电源的影响,而且计算机的5V电源功率很大,连续供电电流都在20A以上,所以不易受影响。

系统分类: 单片机
用户分类: 学习笔记
标签: CH375
来源: 转贴
发表评论 阅读全文(220) | 回复(0)

0

关于投票
USB接口芯片的原理及应用
随着计算机技术的快速发展,USB移动存储设备的使用已经非常普遍,因此在一些需要转存数据的设备、仪器上使用USB移动存储设备接口芯片便相继产生了,CH375就是其中之一,它是一个USB总线的通用接口芯片,支持HOST主机方式和SLAVE设备方式。

       在本地端,CH375具有8位数据总线和读、写、片选控制线以及中断输出,可以方便地挂接到单片机/DSP/MCU等控制器的系统总线上。在USB主机方式下,CH375还提供了串行通信方式,通过串行输入、串行输出和中断输出与单片机/DSP/MCU等相连接。CH375的USB主机方式支持各种常用的USB全速设备,外部单片机/DSP/MCU可以通过CH375按照相应的USB协议与USB设备通信。

       CH375芯片内部结构

       1 内部结构


  &n
bsp;    CH375芯片内部集成了PLL倍频器、主从USB接口SIE、数据缓冲区、被动并行接口、异步串行接口、命令解释器、控制传输的协议处理器、通用的固件程序等。CH375芯片引脚排列如图1所示。

CH375芯片引脚排列

                                                              图 1 CH375芯片引脚排列

       2 内部物理端点

       CH375芯片内部具有7个物理端点。端点0是默认端点,支持上传和下传,上传和下传缓冲区各是8B;端点1包括上传端点和下传端点,上传和下传缓冲区各是8B,上传端点的端点号是81H,下传端点的端点号是01H;端点2包括上传端点和下传端点,上传和下传缓冲区各是64B,上传端点的端点号是82H,下传端点的端点号是02H。

       主机端点包括输出端点和输入端点,输出和输入缓冲区各是64B,主机端点与端点2合用同一组缓冲区,主机端点的输出缓冲区就是端点2的上传缓冲区,主机端点的输入缓冲区就是端点2的下传缓冲区。

       其中,CH375的端点0、端点1、端点2只用于USB设备方式,在USB主机方式下只需要用到主机端点。

       软件接口

      
对于USB存储设备的应用,CH375直接提供了数据块的读写接口,以512b的物理扇区为基本读写单位,从而将USB存储设备简化为一种外部数据存储器,单片机可以自由读写USB存储设备中的数据,也可以自由定义其数据结构。

       CH375以C语言子程序库提供了USB存储设备的文件级接口,这些应用层接口API包含了常用的文件级操作,可以移植并嵌入到各种常用的单片机程序中。

       CH375的U盘文件级子程序库具有以下特性:支持常用的FAT12、FAT16 和FAT32 文件系统,磁盘容量可达100GB以上,支持多级子目录,支持8.3格式的大写字母文件名,支持文件打开、新建、删除、读写以及搜索等。

       CH375的文件级接口API子程序需要大约600b的随机存储器RAM 作为缓冲区。所有API在调用后都有操作状态返回,但不一定有应答数据。有关API参数的说明请参考CH375数据手册。

CH375在单片机读写U盘中的电路原理图

      
图2给出了MCS-51单片机读写U盘的电路原理图,如果CH375芯片的TXD引脚悬空或者没有通过下接电阻接地,那么CH375工作于串口方式。在串口方式下,CH375只需要与单片机/DSP/MCU连接3个信号线,TXD引脚、RXD引脚以及INT#引脚,其他引脚都可以悬空。除了连接线较少之外,其他外围电路与并口方式基本相同。由于INT#引脚和TXD 引脚在CH375复位期间只能提供微弱的高电平输出电流,在进行较远距离的连接时,为了避免INT#或者TXD在CH375复位期间受到干扰而导致单片机误操作,可以在INT#引脚或者TXD引脚上加阻值为1~5kΩ的上拉电阻,以维持较稳定的高电平。在CH375芯片复位完成后,INT#引脚和TXD引脚将能够提供5mA的高电平输出电流或者5mA的低电平吸入电流。

MCS

  &nb

sp;                                             图2 MCS-51单片机读写U盘的电路原理图

       单片机读写U盘的接口

      
由于CH375内置了处理Mass-Storage海量存储设备的专用通信协议的固件,所以嵌入式系统的单片机可以通过CH375将U盘(USB闪存盘、USB外置硬盘)作为可移动的大容量存储器。数据读写只需要几条指令,而不需要详细了解USB通信协议。

       如果嵌入式系统需要将USB存储设备组织为文件系统,那么可以直接调用CH375文件级子程序库提供的接口API,由子程序库处理文件系统。

       CH375主机USB-HOST的电路设计注意事项

       某些USB设备带电插入时常出现如下问题:
 

       ● CH375复位或者单片机复位(尤其是采用uP 监控电路的单片机系统)。

       ● CH375或者单片机突然工作不正常,失去控制。

       ● CH375芯片的工作电流突然增大并且持续如此,时间长了芯片发热烫手。

       出现上述问题时可参考如下解决方法:

       ● 给USB插座单独供电,这样,即使USB设备刚插上时存在电容充电过程,也不会影响单片机和CH375。变通方法是,将5V主电源分别通过两个独立的限流电感后(或者在PCB中电源线分开走),一组提供给CH375和单片机等,另一组提供给USB插座。

       ● 在USB插座前串接限流电阻或者电感,并在USB插座电源上并联储能用的电解电容。如果用电感也可以限制电流突变,防止电源电压突降,但是用电感在USB设备拔出后,容易在USB插座中产生过冲高压,所以必须接储能电容。(注意,在第一版CH375评估板的原理图中已经标出USB插座的限流电阻R1为1Ω,建议将其换为阻值5Ω的电阻或者保险电阻)

       ● 其他临时的解决方法(不推荐):①在USB设备与USB插座之间加入USB延长线。②在主电源上并联较大的储能电容,在U盘刚插入时提供足够的瞬时电能,减少对电源电压的影响。

       ● 参考目前计算机端的解决方法:USB端口的电源供给是通过保险电阻或者限流电感提供的,这些能够限制瞬时电流。对于计算机前面板的USB端口,由于本身通过一段较长的连接导线,自然减弱了对主电源的影响,而且计算机的5V电源功率很大,连续供电电流都在20A以上,所以不易受影响。

系统分类: 单片机
用户分类: 学习笔记
标签: USB
来源: 转贴
发表评论 阅读全文(228) | 回复(0)

1

关于投票
二极管的奇妙用法!(经典)
大多数人都只知道二极管有单向导通/反向截止的特性,所以都只是把二极管作为整流或者开关来使用。其实二极管还有一个非常特殊的性能,就是它能够很好的作为温度检测器件,稳定、可靠又取材方便而且非常便宜。可能好多人不知道它还可以这样用。
    原理非常简单:就是二极管的PN结具有负温度特性,温度每升高一度C,它的正向压降就降低3mV左右。如果用5个1N4148二极管串接的话,那么就有15mV/度C的变化。对于用LM358以及LM324或者LM339的运放或者比较起来说,只要变化2mV就足够使输出翻转了。具体使用时只要用一个电阻和二极管串接,电阻起到限流的作用,让二极管的正向电流在0.5至3mA之间就可以了。从二极管两端取出正向电压给比较器输入端。
    早些年,我用这个东西来替换东芝电冰箱里面很容易损坏的那个感温电阻,至今没有一台出现温度失控问题,东芝维修部的人也看的晕乎乎,始终不明白之中奥妙。
系统分类: 模拟技术
用户分类: 学习笔记
标签: 二极管
来源: 转贴
发表评论 阅读全文(240) | 回复(3)
总共 , 当前 /