📄 ini_ok.c
字号:
//-----------------------------------------------------------------------------
// Copyright (C) 2004 Silicon Laboratories, Inc.
//
// AUTH: JS
// DATE: 03 JUL 02
//
// This program flashes the green LED on the C8051F31x target board about
// five times a second using the interrupt handler for Timer2.
//
// Target: C8051F31x
//
// Tool chain: KEIL Eval 'c'
//
//-----------------------------------------------------------------------------
// Includes
//-----------------------------------------------------------------------------
//OSC=24.5MHz
/*
; C8051F310
; KEY5 P0.1 1|---=---|32 P0.2 XTAL1
; KEY6 P0.0 2| |31 P0.3 XTAL2
; GND 3| |30 P0.4 KEY1
; VDD 4| |29 P0.5 KEY2
; /RST/C2ACK 5| |28 P0.6 CNVSTR KEY3
; KEY7 P3.0(C2D) 6| |27 P0.7 KEY4
; CS2 P3.1 7| |26 P1.0 D0
; CS1 P3.2 8| |25 P1.1 D1
; RD P3.3 9| |24 P1.2 D2
; WR P3.4 10| |23 P1.3 D3
; RS P2.7 11| |22 P1.4 D4
; MR_B P2.6 12| |21 P1.5 D5
; MWE P2.5 13| |20 P1.6 D6
; MRE P2.4 14| |19 P1.7 D7
; MALE P2.3 15| |18 P2.0 LP
; MCLE P2.2 16|-------|17 P2.1 MCE
;
*/
//=============================
#include <c8051f310.h>
//=============================
#define uchar unsigned char
#define uint unsigned int
//=============================
uchar xdata buffer[513]; //开辟页缓存数组
uchar *pointer; //建立数组指针
uchar raddrl; uchar raddrh; //页寻址的高、低位
uchar mydata; //数据
//=============================
sbit KEY4 =P0^7;
sbit RD =P3^3;
sbit RS =P2^7;
sbit WR =P3^4;
sbit MR_B =P2^6;
sbit MWE =P2^5;
sbit MRE =P2^4;
sbit MALE =P2^3;
sbit MCLE =P2^2;
sbit MCE =P2^1;
//================
sbit LED =P0^1;
//=================
uchar autorun;
//=========delay without key==========================================
void DelayX1ms(uchar count)
{
uchar i,j,k;
for(i=0;i<count;i++)
for(j=0;j<40;j++)
for(k=0;k<120;k++)
{
;
}
}
//=====================================================================
void DelayX10ms(uint count)
{
uint i,j,k;
for(i=0;i<count;i++)
for(j=0;j<10;j++)
for(k=0;k<120;k++)
{
;
}
}
//====================================================================
void Delay50us(uchar count)
{
uchar i,j;
for(j=0;j<count;j++)
for(i=0;i<6;i++)
{
;
}
}
//=======================================================================
void key_wait(uint count)
{
uint i,j,k;
if(autorun==0)
{
for(i=0;i<count;i++)
for(j=0;j<10;j++)
for(k=0;k<120;k++)
{
if(KEY4!=1)
{
autorun=1;
goto next;
}
;
}
}
else
{
while(1)
{
if(KEY4!=1)
{
for(i=0;i<100;i++)
for(j=0;j<100;j++)
{
;
}
goto next;
}
}
}
next:
;
}
//=============K9F5608U0A===============
//=============RESET====================
void reset(void)
{
MCE=0;
MR_B=1;
MRE=1;
MWE=1;
MCLE=0;
MALE=0;
P1=0xff;
MCLE=1;
MALE=0;
MWE=0;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
MWE=1;
MCLE=0;
MALE=0;
while(MR_B==0)
{
;
}
}
//============命令输出函数=================
void writecomd(unsigned char comd)
{
P1=comd;
MCLE=1;
MALE=0;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
MCLE=0;
MALE=0;
}
//============地址输出函数====================
void writeaddr(uchar raddrl,uchar raddrh)
{
P1=0x00;
MCLE=0;
MALE=1;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
P1=raddrl;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
P1=raddrh;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
MCLE=0;
MALE=0;
}
//=============数据输出函数=============
void writedata(void)
{
P1= *pointer;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
pointer++;
}
//=============读操作==================
uchar readsta(void)
{
unsigned char soop;
P1MDOUT=0x00;
P1=0xff;
DelayX1ms(20);
MRE=0;
MRE=0;
soop=P1;
MRE=1;
P1MDOUT=0xff;
return(soop);
}
//==============整块擦除1块=32pages 共2048块====
uchar blockerase(uint block)
{
unsigned char result;
writecomd(0x60);
block=block*32;
P1=block&0x00ff;
MCLE=0;
MALE=1;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
P1=(block&0xff00)>>8;
MWE=0;
MWE=0;
MWE=1;
MWE=1;
MCLE=0;
MALE=0;
writecomd(0xd0);
while(MR_B==0)
{
;
}
writecomd(0x70);
result=readsta();
if((result&0x01)== 1)
{
return(1);
}//出错处理
else
return(0);
}
//==============整页写入的详细代码======
uchar pagewrite(uchar raddrl,uchar raddrh)
{
int i;
unsigned char result;
pointer = &buffer;
writecomd(0x00);//必须指出开始地址
writecomd(0x80);
writeaddr(raddrl,raddrh);
for(i=0;i<512;i++)
{
writedata();
}
writecomd(0x10);
while(MR_B==0)
{
;
}
writecomd(0x70);
result=readsta();
if((result&0x01) == 1)
{
return(1);
}//出错处理
else
return(0);
}
//===============
//-----------------------------------------------------------------------------
// SYSCLK_Init
//-----------------------------------------------------------------------------
//
// This routine initializes the system clock to use the internal 24.5MHz / 8
// oscillator as its clock source. Also enables missing clock detector reset.
//
void SYSCLK_Init (void)
{
OSCICN = 0x83; // IOSCEN IFRDY 0 0 0 0 IFCN1 IFCN0 (sfr OSCICN=0xB2;内部振荡器控制寄存器)
// IOSCEN=1 内部振荡器使能;IFRDY=0/1 内部振荡器未运行在编程频率/内部振荡器按编程频率运行.
// IFCN1 IFCN0=00~11 8分频 4 2 1分频.
RSTSRC = 0x04; // 0 FERROR C0RSEF SWRSF WDTRSF MCDRSF PORSF PINRSF (sfr RSTSRC=0xEF;复位源寄存器)
// MCDRSF=0/1 禁止时钟丢失检测器/使能时钟丢失检测器;检测到时钟丢失条件时触发复位.
}
//-----------------------------------------------------------------------------
// PORT_Init
//-----------------------------------------------------------------------------
//
// Configure the Crossbar and GPIO ports.
// P3.3 - LED (push-pull)
//
void PORT_Init (void)
{
PCA0MD = 0x88; // CIDL WDTE WDCLK 0 CPS2 CPS1 CPS0 ECF (sfr PCA0MD=0xD9;PCA0 MODE)
// CIDL=0/1 当系统控制器处于空闲方式时,PCA 继续正常工作/当系统控制器处于空闲方式时,PCA 停止工作.
// WDTE=0/1 看门狗定时器被禁止/PCA 模块4 被用作看门狗定时器.
// WDCLK=0/1 对看门狗定时器使能位解锁/锁定看门狗定时器使能位(当WDCLK 被置‘1’时,在发生下一次系统复位之前将不能禁止WDT).
// CPS2-CPS0=000 系统时钟的12分频 001 系统时钟的4 分频 010 定时器0 溢出 011 ECI 负跳变(最大速率= 系统时钟频率/4)100 系统时钟 101 外部时钟的8 分频.
// ECF=0/1 禁止CF中断/当CF(PCA0CN.7)被置位时,允许PCA 计数器/定时器溢出的中断请求.
// disable watchdog timer
// WDTE = 0 (clear watchdog timer enable)
//========================================================
XBR0 = 0x00; // CP1AE CP1E CP0AE CP0E SYSCKE SMB0E SPI0E URT0E (sfr XBR0=0xE1;端口I/O 交叉开关寄存器0)
// no digital peripherals selected
XBR1 = 0x40; // WEAKPUD XBARE T1E T0E ECIE PCA0ME(3位) (sfr XBR1=0xE2;端口I/O 交叉开关寄存器1)
// WEAKPUD=0 弱上拉使能;XBARE=1 交叉开关使能;T1E=0 T1不连到端口引脚;T0E=0 T0不连到端口引脚.
// ECIE(PCA0 外部计数输入使能位)=0 ECI不连到端口引脚;PCA0ME=000 所有的PCA I/O 都不连到端口引脚.
// Enable crossbar and weak pull-ups
P3MDOUT |= 0x1e; // 000 P3MDOUT[4:0](P3.4–P3.0 输出方式配置位) (sfr P3MDOUT=0xA7;端口3输出方式寄存器)
// P3MDOUT[4:0]=0/1 对应的P3.n 输出为漏极开路/对应的P3.n 输出为推挽方式.
// enable LED as a push-pull output
P2MDOUT |= 0xff;
P1MDOUT |= 0xff;
P0MDOUT |= 0x02;
P1=0xff;
}
//-----------------------------------------------------------------------------
/*初始化*/
//========================================
uchar xdata ddata[]={
0x42,
};
//-----------------------------------------------------------------------------
// MAIN Routine
//-----------------------------------------------------------------------------
void main (void)
{
int i;
i=0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -