基本信息
源码名称:上位机通过usb控制下位机(上位机通过c8051f320 的usb控制LED)
源码大小:5.21M
文件格式:.zip
开发语言:C/C++
更新时间:2019-03-27
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍

上位机通过c8051f320 的usb控制LED


//	File best viewed using Tab Size of 4 Characters
//	Author DM 	DATE	4-4-03
//	Modified CS DATE	8-25-03
//	This example illustrates usage of the USB_API.lib
//	DO NOT locate code segments at 0x1400 to 0x4000
//	These are used for non-voltile storage for transmitted data.

//	Include files
#include <c8051f320.h>		//	Header file for SiLabs c8051f320  
#include <stddef.h>			//	Used for NULL pointer definition
#include "USB_API.h"		//	Header file for USB_API.lib
#define uchar unsigned char
#define uint unsigned int
sbit clk_164=P1^7;
sbit clr_164=P2^0;
sbit ab_164=P1^6;
//uchar led_value=0;
//uchar code tab[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0xe7f,0xff,0x00};
BYTE Out_Packet[8];   // Last packet received from host
BYTE In_Packet[8] ;   // Next packet to sent to host

void Port_IO_Init()
{
    P1MDOUT   = 0xF8;	   //1111 1000 高5位为推挽方式
    P2MDOUT   = 0x01;	  //P2.0为推挽方式
     XBR1      = 0xC0;	 //交叉开关使能、、弱上拉禁止
}
void Oscillator_Init()
{
    int i = 0;
	if( ( CLKMUL & ( 1<<5 ) ) ) return;
	CLKMUL = 0;
    CLKMUL    = 0x80;	   	//时钟乘法器使能
    for (i = 0; i < 20; i  );    // Wait 5us for initialization
    CLKMUL    |= 0xC0;			//初始化时钟乘法器
    while ((CLKMUL & 0x20) == 0);	//等待时钟乘法器准备好
    CLKSEL    = 0x02;	   //usbclk=48M  sysclk=24M
}
void hc_164_out(uchar value)  //74hc164输出一个字节函数
{
   uchar i;
   for(i=0;i<8;i  )
   {
   		clk_164=0;
		ab_164=(value&0x80);
		clk_164=1;
		value<<=1;
   }
   clk_164=0;								 	
}
void HC138_Sel( uchar x )	  //38译码器选中0-7
{
 	x &= 0x07;
	P1 |= ( 1<<3 ) | ( 1<<4 ) | ( 1<<5 );
	P1 &= ( ( x<<3 ) | 0xC7 );
} 
/*** [BEGIN] USB Descriptor Information [BEGIN] ***/
code const UINT USB_VID = 0x10C4;  //16位卖主ID号
code const UINT USB_PID = 0xEA61;  //16位产品ID
code const BYTE USB_MfrStr[] = {0x1A,0x03,'S',0,'i',0,'l',0,'i',0,'c',0,'o',0,'n',0,' ',0,'L',0,'a',0,'b',0,'s',0};	//描述厂商字符串                     //	Manufacturer String
code const BYTE USB_ProductStr[] = {0x10,0x03,'U',0,'S',0,'B',0,' ',0,'A',0,'P',0,'I',0};	//	描述产品字符串
code const BYTE USB_SerialStr[] = {0x0A,0x03,'1',0,'2',0,'3',0,'4',0};	   //描述序列号字符串
code const BYTE USB_MaxPower = 15;            // Max current = 30 mA (15 * 2) 最大电流
code const BYTE USB_PwAttributes = 0x80;      // Bus-powered, remote wakeup not supported 总线供电
code const UINT USB_bcdDevice = 0x0100;       // Device release number 1.00	   用BCD码表示设备版本号
/*** [ END ] USB Descriptor Information [ END ] ***/



//-----------------------------------------------------------------------------
// Main Routine
//-----------------------------------------------------------------------------
void main(void) 
{
	PCA0MD &= ~0x40;			  	//	Disable Watchdog timer	关闭看门狗
	Port_IO_Init();	
	Oscillator_Init();			   //USB时钟为48M,系统时钟为4倍时钟乘法器除2 ,即24M	
    USB_Clock_Start();                     // Init USB clock *before* calling USB_Init
    USB_Init(USB_VID,USB_PID,USB_MfrStr,USB_ProductStr,USB_SerialStr,USB_MaxPower,USB_PwAttributes,USB_bcdDevice);
	
//	CLKSEL |= 0x02;	//USB时钟为48M,系统时钟为4倍时钟乘法器除2 ,即24M	
//	RSTSRC	|=	0x02;//复位源寄存器	写:使能VDD监视器为复位源	 读:最后一次复位是上电或VDD监视器复位
//	Port_Init();						//	Initialize crossbar and GPIO
	USB_Int_Enable();					//	Enable USB_API Interrupts
	HC138_Sel(0);					  //选通Y0
	USB_Int_Enable();
	EA=1;						 //开总中断
	while (1)
	{
	  if (Out_Packet[0] == 0xAA) 
	  	hc_164_out(0x00);   		// 	  灯亮
     
      if (Out_Packet[0] == 0x55)  
	  	hc_164_out(0xff);			// 	灯灭
    
	}
}



	//	ISR for USB_API, run when API interrupts are enabled, and an interrupt is received	*/
void 	USB_API_TEST_ISR(void)	interrupt	16
{
	BYTE	INTVAL	=	Get_Interrupt_Source();	//	Determine type of API interrupts
	if (INTVAL & TX_COMPLETE)
	{
		Block_Write(In_Packet, 8);
	}
	if (INTVAL & RX_COMPLETE)
	{
		Block_Read(Out_Packet, 8);
	}
}