关于READ_PORT_UCHAR 的小问题??

TimiXu 2004-08-14 12:00:34
UCHAR
READ_PORT_UCHAR(
IN PUCHAR Port
);
传入的参数是一个字符指针,那么只能寻址IO口0x00-0xff,
我要读0x03f8口怎么办
直接

READ_PORT_UCHAR(0x03f8)???
...全文
285 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
TimiXu 2004-08-15
  • 打赏
  • 举报
回复
thank you
ArthurTu 2004-08-14
  • 打赏
  • 举报
回复
ULONG nPort = 0x3f8;
UCHAR Val = READ_PORT_UCHAR((PUCHAR)nPort);
//;UART0收发一组字符(48个)(通过) // rxd_str必须是全局变量,切使用前要赋值。 // rxd_str不能是局部变量,局部变量会清零, //因为中断一次只能收一个字符rxd_str不可能>=LENM /********************************************** 文件描述: 三相电测量上报 功能说明: 测量ATT7022B完成 PCF8563上报定时(需校时) FM24C256转换数据存储 UART0口用于RS232读数据 UART1控制无线模块上报数据 创建:2006年12月5日 /********************************* *函数:main. *入口:无 *出口:无 *功能说明:接收UART端口命令 执行读ATT7022B的数据 进行处理、存储和回发数据 ********************************/ //***************************** //包含的文件 //****************************** #include #include #include //************************************************* //函数:init_sysclk(void) //功能:时钟初始化 //入口:无 //出口: 无 //说明:使用外部时钟12M //************************************************* void init_sysclk (void) { uint i=0; OSCXCN=0x67; //external oscillator with 12MHz crystal for(i=0;i<256;i++); // XTLVLD blanking while(!(OSCXCN & 0x80)); // Wait for crystal osc. to settle OSCICN=0x88; //时钟丢失检测,选择外部时钟 CKCON = 0x00; //时钟分频 } /********************************* 函数:void enable_wdog(void) void disable_wdog(void) 功能:使能、禁止wdog 入口:无 出口:无 说明: ********************************/ void enable_wdog(void) { WDTCN=0xA5; //允许看门狗定时器工作 } void disable_wdog(void) //禁止看门狗定时器工作 { WDTCN=0xDE; WDTCN=0xAD; } /*********************************** 函数:void init_ioport() 功能:端口配置及端口位定义 入口:无 出口:无 说明: *************************************/ void init_ioport() { XBR0=0x07; //TXD0-P0.0 RXD0-P0.1,SPI_SCK-P0.2,SPI_MISO-P0.3 //SPI_MOSI-P0.4,SPI_NSS-P0.5,SDA-P0.6,SCL-P0.7, XBR2=0x44; //端口I/O弱上拉允许,TX1-P1.0,RXD-P1.1交叉开关允许 XBR1=0X10; //INT1使能INT1--P1.2 P0MDOUT=0x00; //端口0输出方式寄存器:0--漏极开路 P0=0xff; P1MDIN=0XFF; //端口1输入方式寄存器:0--配置为数字输入 P1MDOUT=0x00; //端口1输出方式寄存器,0--漏极开路 P1=0xff; P2MDOUT=0x00; //端口2输出方式寄存器:0--漏极开路 P2=0xff; P3MDOUT=0X00; //端口3输出方式寄存器:0--漏极开路 P3=0xff; P74OUT=0x00; //端口7-4输出方式寄存器:0--漏极开路 P4=0xff; P5=0xff; P6=0xff; P7=0xff; } //-------------------------------------------------------------- //函数:void Delay_ms (unsigned ms) //功能:实现延时功能 Timer0_ms //--------------------------------------------------------------- // /* Configure Timer0 to delay */ void Delay_ms (unsigned ms) { uchar i; // millisecond counter TCON &= ~0x30; // STOP Timer0 and clear overflow flag TMOD |= 0x01; // configure Timer0 to 16-bit mode CKCON |= 0x08; // Timer0 counts SYSCLKs for (i = 0; i < ms; i++) // count milliseconds { TR0 = 0; // STOP Timer0 TH0 = (-SYSCLK/1000) >> 8; // set Timer0 to overflow in 1ms TL0 = -SYSCLK/1000; TR0 = 1; // START Timer0 while (TF0 == 0); // wait for overflow TF0 = 0; // clear overflow indicator } } //------------------------------------------------------- //函数:void Delay_us (unsigned us) //功能:实现延时功能 Timer0_us //------------------------------------------------------- // /* Configure Timer0 to delay */ void Delay_us (unsigned us) { uchar i; // microseconds counter TCON &= ~0x30; // STOP Timer0 and clear overflow flag TMOD |= 0x01; // configure Timer0 to 16-bit mode CKCON |= 0x08; // Timer0 counts SYSCLKs for (i = 0; i < us; i++) // count microseconds { TR0 = 0; // STOP Timer0 TH0 = (-SYSCLK/1000000) >> 8; // set Timer0 to overflow in 1us TL0 = -SYSCLK/1000000; TR0 = 1; // START Timer0 while (TF0 == 0); // wait for overflow TF0 = 0; // clear overflow indicator } } //*************************************** //函数:unsigned char my_add(uchar my_add) //功能:读开关状态确定子地址 //入口:无 //出口:子地址 //说明:子地址存于myadd中(即设备号) //**************************************** void my_add(void) { P74OUT |=0XD0; myadd =P5; } //****************************************** //函数:void jiaob(ATT_JB[]) //功能:写校表寄存器 //说明:UART口接收校表时间并存于FM24C256中 //***************************************** void jiaob (void) { } main() { disable_wdog(); //关看门狗 init_sysclk (); //时钟初始化 init_ioport(); //交叉开关配置 my_add(); //读设备子地址设置 UART0_Init(); //UART0初始化 EX1= 1; //开INT1 EA = 1; //开中断 rxd_str=0; while(1) { if(uart0_flag) { rxd_str=0; uart0_flag = 0; m=ur0_rxd; txd_string(m,LENM); } } //---------判断本设备命令及命令内容执行命令------- } //----------------------------------------------------- //串口初始化 //-------------------------------------------------------- void UART0_Init(void) { SCON0 = 0x50; //串口方式1,波特率可变 PCON |= 0x00; //SMOD = 0 TMOD = 0x20; //选择T1方式2, TH1 = 0xe8; //T1初值, TL1 = 0xe8; ES0 = 1; //UART0中断开启 TR1 = 1; //启动定时器T1 } //---------------------------------------------------------- //发送单个字符 //--------------------------------------------------------- void txd_char(unsigned char ch) { SBUF0 = ch; //送入缓冲区 while(TI0 == 0); //等待发送完毕 TI0 = 0; //软件清零 } //----------------------------------------------------- //发送字符串,调用Send_Char() len字符串长度 //---------------------------------------------------- void txd_string(unsigned char * str,unsigned char len) { unsigned char k = 0; do { txd_char(*(str+k) ); k++; } while(k < len); } //-------------------------------------------------------- //UART0中断服务程序. 接收字符 //-------------------------------------------------------- // rxd_str必须是全局变量,切使用前要赋值。 // rxd_str不能是局部变量,局部变量会清零, //因为中断一次只能收一个字符rxd_str不可能>=LENM void uart0_isr(void) interrupt 4 using 1 { unsigned char rxch; if(RI0) //中断标志 RI0=1 数据完整接收 { RI0 = 0; //软件清零 rxch = SBUF0; //读缓冲 if(rxd_str>=LENM) { uart0_flag=1; rxd_str=0; } ur0_rxd[rxd_str] = rxch; //存入数组,供发送 rxd_str++; } } //********************** //main.h //********************* #ifndef _main_h #define _main_h //***************************** //全局常量 //**************************** #define uchar unsigned char #define uint unsigned int #define SYSCLK 11059200 #define CMD_RESET 0X11 #define CMD_TIME 0X12 #define CMD_DATA 0X13 #define ATT_R 0x00 // ATT Read command #define ATT_W 0x80 // ATT Write command #define fm_Write_add 0xA0 #define fm_Read_add 0xA1 #define Fm_add 0xA0 //fm24c256器件从地?#define LENM 0x30 unsigned char idata r_commond=0x01; //读命令代码 unsigned char idata w_time_commond=0x02; //校时代码 unsigned char xdata jb_commond=0xdd; //校表命令代码 //---------------------------------------------------- //全局变量 //---------------------------------------------------- unsigned char rxd_str; unsigned char * m; unsigned char xdata fm_read_buf[60]={0}; unsigned char xdata fm_write_buf[60]={0}; unsigned char xdata pcf_d[16]={0}; //data of pcf8563 unsigned char xdata *d_ptr; unsigned char xdata ur0_rxd[60]; //每次接收字符串 unsigned char xdata ur0_txd[60]; //要发送的字符串 unsigned char xdata att_rd[90]; unsigned char xdata att_wd[60]; // att7022 of data unsigned char xdata att_jb[40]; //校表数组(myadd=0) unsigned char idata period; //时间间隔 unsigned char idata myadd; unsigned char *str; unsigned char chksum; unsigned char ATT_W_ADD; // ATT Read status register unsigned char ATT_R_ADD; // ATT Write status register uchar slave_add,fm_ram_add,send_byte,write_num,read_num; uchar fm_send_count,fm_receive_count,fm_send_len,fm_receive_len; sbit SDA=P1^6; //*模拟I2C数据传送位*/ sbit SCL=P1^7; //*模拟I2C时钟控制位*/ sbit ATT_CS = P3^0; // ATT CS signal sbit D_E = P1^3; //485收发控制?bit ack; bit uart0_flag; //中断接收完成标志 bit uart1_flag; //中断接收完成标志 bit sm_busy; //收发开始置1,操作结束后由中断清0 bit fm_err_flag; //--------子函数声明------------------------------------- void uart0_isr(); //串口中断服务程序,接收字符 void UART0_Init(void); void txd_char(uchar ch); void txd_string(uchar * str,uchar len); void init_sysclk (void); void enable_wdog(void); void disable_wdog(void); void init_ioport(); void Delay_ms (unsigned ms); void Delay_us (unsigned us) ; void my_add(void); void jiaob (void); void ATT_Write (uchar ATT_WADD, uchar att_wd[]); unsigned char ATT_Read (uchar ATT_RADD,uchar att_rd[]); void SPI0_Init (void); void Start_I2c(); void Stop_I2c(); void Ack_I2c(); void SendByte(uchar x); uchar RcvByte(); bit ISendStr(uchar sla,uchar suba,uchar *d_ptr,uchar no); bit IRcvStr(uchar sla,uchar suba,uchar *d_ptr,uchar no); void WriteClock(void); void StartClock(void); void init_sysclk (void); void init_ioport(); void init_smbus(void); void smbus_receive (uchar chip_select,byte_address,receive_num); void smbus_send (uchar chip_select,byte_address,write_num); void enable_wdog(void); void disable_wdog(void); #endif
PComm 库函数 PComm 库函数是台湾MOXA公司提供的,他为用户提供了基于win32 api的开发接口。 PComm库函数分为7大类 控制函数、数据输入函数、数据输出函数、状态函数、事件驱动函数、传输文件函数、特殊设定函数 上述函数均返回int型数据,若函数调用成功则返回0,否则返回一个负整数。 控制函数主要包括 sio_open(PortNum) 打开串口 sio_close(PortNum) 关闭串口 sio_ioctl(PortNum, baud, mode)设置串口的工作模式,包括 波特率,数据位元,停止位,效验等 sio_flush(portNum,func)清除发送、接收缓冲区 其中func 为0清空输入 ,为1清空输出,为2清空输入输出 sio_SetWriteTimeouts(int port,DWORD TotalTimeouts):设置串口写操作的超时。 sio_lctrl(Portnum,mode) 设置串口RTS/DTS。 待定 数据输入函数主要包括 sio_getch(PortNum) 从输入缓冲区读一个字符 sio_read(PortNum,buf,len) 从输入缓冲区读指定个数的字符 sio_iqueue(Portnum)读取输入缓冲区中的字符长度 数据输出函数主要包括 sio_putch(PortNum) 写一个字符到输出缓冲区 sio_write(PortNum,buf,len)写指定个数的字符到输出缓冲区 状态函数主要包括 sio_lstatus(portNum)获取串口的CTS,DSR,DCD,RI线的状态 sio_getbaud(portNum)获取串口的波特率 sio_getmode(portNum)获取串口的工作模式。对应sio_ioct函数 事件函数主要包括 sio_term_irq(portNum,func,code) 当接收到指定字符时响应事件,func为回调函数名,code为指定的字符 sio_cnt_irq(PortNum,func,count) 当接收到指定个数字元时响应事件,func为回调函数名,count接收的个数 传输文件函数主要包括 sio_FtASCIITx(portNum,fname,func,key)发送一个文本文件 sio_FtASCIIRx(portNum,fname,func,Key,sec)接收一个文本文件 int i,Ret,DataLen; FILE *fp1; uchar RetDataC[30],WriteData[24],PSC[5]; Ret = sio_open(port); if (Ret != SIO_OK ) return(-1);//打开串口错误 Ret = sio_ioctl (port, B9600, P_NONE | BIT_8 | STOP_1 ); if (Ret != SIO_OK) { sio_close(port); return(-2);//设置串口参数失败 } /*Ret = sio_lctrl (port, C_DTR | C_RTS ); if (Ret != SIO_OK) { sio_close(port); return(-2);//设置串口参数失败 }*/ /*Ret = sio_flush(port,2); if (Ret != SIO_OK){ sio_close(port); return(-3);//清空 输入和输出缓冲区的数据 }*/
PComm 库函数 PComm 库函数是台湾MOXA公司提供的,他为用户提供了基于win32 api的开发接口。 PComm库函数分为7大类 控制函数、数据输入函数、数据输出函数、状态函数、事件驱动函数、传输文件函数、特殊设定函数 上述函数均返回int型数据,若函数调用成功则返回0,否则返回一个负整数。 控制函数主要包括 sio_open(PortNum) 打开串口 sio_close(PortNum) 关闭串口 sio_ioctl(PortNum, baud, mode)设置串口的工作模式,包括 波特率,数据位元,停止位,效验等 sio_flush(portNum,func)清除发送、接收缓冲区 其中func 为0清空输入 ,为1清空输出,为2清空输入输出 sio_SetWriteTimeouts(int port,DWORD TotalTimeouts):设置串口写操作的超时。 sio_lctrl(Portnum,mode) 设置串口RTS/DTS。 待定 数据输入函数主要包括 sio_getch(PortNum) 从输入缓冲区读一个字符 sio_read(PortNum,buf,len) 从输入缓冲区读指定个数的字符 sio_iqueue(Portnum)读取输入缓冲区中的字符长度 数据输出函数主要包括 sio_putch(PortNum) 写一个字符到输出缓冲区 sio_write(PortNum,buf,len)写指定个数的字符到输出缓冲区 状态函数主要包括 sio_lstatus(portNum)获取串口的CTS,DSR,DCD,RI线的状态 sio_getbaud(portNum)获取串口的波特率 sio_getmode(portNum)获取串口的工作模式。对应sio_ioct函数 事件函数主要包括 sio_term_irq(portNum,func,code) 当接收到指定字符时响应事件,func为回调函数名,code为指定的字符 sio_cnt_irq(PortNum,func,count) 当接收到指定个数字元时响应事件,func为回调函数名,count接收的个数 传输文件函数主要包括 sio_FtASCIITx(portNum,fname,func,key)发送一个文本文件 sio_FtASCIIRx(portNum,fname,func,Key,sec)接收一个文本文件 int i,Ret,DataLen; FILE *fp1; uchar RetDataC[30],WriteData[24],PSC[5]; Ret = sio_open(port); if (Ret != SIO_OK ) return(-1);//打开串口错误 Ret = sio_ioctl (port, B9600, P_NONE | BIT_8 | STOP_1 ); if (Ret != SIO_OK) { sio_close(port); return(-2);//设置串口参数失败 } /*Ret = sio_lctrl (port, C_DTR | C_RTS ); if (Ret != SIO_OK) { sio_close(port); return(-2);//设置串口参数失败 }*/ /*Ret = sio_flush(port,2); if (Ret != SIO_OK){ sio_close(port); return(-3);//清空 输入和输出缓冲区的数据 }*/
#include #include #define uint unsigned int #define uchar unsigned char #define ulong unsigned long #define CLOCK P1_0 #define D_IN P1_1 #define D_OUT P1_2 #define _CS P1_3 sbit g1=P2^7; sbit g2=P2^1; sbit g3=P2^3; sbit g4=P2^5; ulong AD_ad1,AD_ad2; float JiZhun_AD=2.5; float AD_Data=0.0; ulong AD_ad=0; char chi; unsigned char code table[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F}; void delay02s(void) { unsigned char i,j,k; for(i=1;i>0;i--) for(j=10;j>0;j--) for(k=200;k>0;k--); } uint read1543(uchar port) { uint ad; uint i; uchar al=0,ah=0; CLOCK=0; _CS=0; port<<=4; for (i=0;i<4;i++) //将四位通道地址送1543 { D_IN=(bit)(port&0x80);CLOCK=1;CLOCK=0; port<<=1; } for (i=0;i<6;i++) //填6个CLOCK信号 { CLOCK=1;CLOCK=0; } _CS=1; _nop_();_nop_();_nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_(); _CS=0; //等待AD转换结束 _nop_();_nop_();_nop_(); for (i=0;i<2;i++) //D9,D8 { D_OUT=1;CLOCK=1;ah<<=1; if (D_OUT) ah +=0x01; CLOCK=0; } for (i=0;i<8;i++) //取出D7--D0 { D_OUT=1;CLOCK=1;al <<= 1; if (D_OUT) al +=0x01; CLOCK=0; } _CS=1; ad = (uint)ah; ad <<= 8; ad +=(uint)al; // return(ad); } void main() { TMOD=0x01; TH0=(65535-20000)/255; TL0=(65535-20000)%255; EA=1;ET0=1;TR0=1; while(1) { P0=table[(AD_ad)]; g1=1; delay02s(); g1=0; P0=table[(AD_ad/10)]; g2=1; delay02s(); g2=0; P0=table[(AD_ad/100)]; g3=1; delay02s(); g3=0; P0=table[(AD_ad/1000)]|0X80; g4=1; delay02s(); g4=0; } } zhongduan()interrupt 1 { TH0=(65535-20000)/255; TL0=(65535-20000)%255; chi++; if(chi==50) { chi=0; AD_ad1 = read1543(0); // (通道0电压正端) AD_Data = ((float)AD_ad1)*JiZhun_AD*2/1024+0.15005;//0.15经过实测需要加0.15减少误差 AD_ad =((AD_Data-2.68)/0.185)*1000; } }

21,600

社区成员

发帖
与我相关
我的任务
社区描述
硬件/嵌入开发 驱动开发/核心开发
社区管理员
  • 驱动开发/核心开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧