标题:
这边写程序,最后想把ICC通信接收到的打印出来,但是51单片机里面不能用printf语句?
[打印本页]
作者:
yxyxyxyx
时间:
2022-9-8 13:54
标题:
这边写程序,最后想把ICC通信接收到的打印出来,但是51单片机里面不能用printf语句?
想把接收到的程序用串口打印出来,咋写类,大佬们指点一下
单片机源程序如下:
****************************************************************************
* @file main.h
* @author
* @version V1.0
* @brief IIC Slave Mode Test
****************************************************************************
*#include "RX8F103.h"
#define STCON MSCON
#define SRXBUF MSRXBUF
#define STXBUF MSTXBUF
#define SSTAT0 MSSTAT0
#define SSTAT1 MSSTAT1
#define SIEN0 MSIEN0
#define SIEN1 MSIEN1
#define SSADDR MSADDR
//I2C主机多字节,单字节读写
//I2C Master 和 I2C Slave通信协议
/*
S + DevAdd(Read) + BayteN + Stop
S + DevAdd(Write) + BayteN + Stop
*/
//I2C从机地址 7位地址
#define I2C_SLAVE_ADD 0x50
#define BUFF_MAX 128
unsigned char xdata DataBuf[BUFF_MAX];
unsigned char DataTxIndex = 0;
unsigned char DataRxIndex = 0;
unsigned char InterruptIndex = 0;
unsigned char WrtieTxBufFlag = 0;
void EUart0_SendOneChar(char c)
{
ES0=0; //发送数据时关串口中断
TI0=0; //清TI位
S0BUF = c; //将待发送字符放入串口数据缓冲寄存器,并开始传输。
while(!TI0); //等待传送结束。当字符发送结束后由硬件置位请求中断,
//此时while循环结束,而串口中断处理函数需等到ES重新置1后才可能响应。
TI0=0; //软件清TI位,亦可在中断处理函数中清0
ES0 = 1; //开串口中断
}
void EUart0_SendString(char *st)
{
while(*st)
{
EUart0_SendOneChar(*st++);
}
}
void Uart0_init(void)
{
UART0PORTEN = 1; //串口端口使能
S0CON = 0x50; //SCON: Mode 1, 8-bit UART, Enable Rcvr
S0RELH = 0x03; //S0RELH + S0RELL 构成波特率设置S0REL[9:0]
S0RELL = 0xF7; //Baud rate = SYSCK/(16×(1024-S0REL)) SYSCK跟CLKDIV寄存器有关 波特率为115200
ES0 = 1; //允许串口中断位
EUart0_SendString("RX8F103 UART0 Init OK!\r\n");
}
void I2c_Init(void)
{
I2CPORTEN = 1; //IIC PORT口使能
TOPCON = 0x00; //IIC Slave
SSADDR = I2C_SLAVE_ADD;//IIC 从机地址寄存器
SIEN0 = 0x01; //正常结束中断
SIEN1 = 0x21; //使能接收区满中断
STCON = 0x40; //使能I2C
}
void I2c_TxBuf_Reset(void)
{
TOPCON |= 0x02;
TOPCON &= 0xFD;
I2c_Init();
}
void main(void)
{
unsigned char i;
CLKCON |= 0x1F; //默认所有时钟打开
RSTPORTEN = 1; //使能复位功能
Uart0_init();
//初始化数组
for (i=0; i<BUFF_MAX; i++)
{
DataBuf[i] = 0x10+i;
}
I2c_Init();
EI2CFIFO = 1; //开IIC FIFO 中断
EI2CRXTX = 1; //开IIC TXRX 中断
EA = 1; //使能总中断
while(1);
}
/*
GC
SUNF
SOVF
SNE
以上任意一个或多个事件发送,均为产生EI2CRXTX中断
*/
void I2C_Slave_TRX_ISR(void) interrupt EI2CRXTX_VECTOR //TRX中断
{
unsigned char ReadData;
//Transmitted Data Byte not ready
if (0x04 == (SSTAT0 & 0x04))
{
//清中断标志位
SSTAT0 &= 0xFB;
}
//Receive Overflow
if (0x02 == (SSTAT0 & 0x02))
{
ReadData = SRXBUF;
//清中断标志位
SSTAT0 &= 0xFD;
}
//Normal End
if (0x01 == (SSTAT0 & 0x01))
{
InterruptIndex = 0;
WrtieTxBufFlag = 0;
I2c_TxBuf_Reset();
//清中断标志位
SSTAT0 &= 0xFE;
}
}
/*
STBE
STBF
SRBE
SRBF
以上任意一个或多个事件发送,均为产生EI2CFIFO中断
*/
void I2C_Slave_FIFO_ISR(void) interrupt EI2CFIFO_VECTOR //FIFO中断
{
unsigned char ReadData;
//Transmission buffer is empty
if (0x20 == (SSTAT1 & 0x20))
{
if ((DataTxIndex < BUFF_MAX) && (1 == WrtieTxBufFlag))
{
STXBUF = DataBuf[DataTxIndex];
DataTxIndex++;
}
SSTAT1 &= 0xDF;
}
// Reception buffer is full
if (0x01 == (SSTAT1 & 0x01))
{
ReadData = SRXBUF;
if (0 == InterruptIndex)
{
//收到Sub地址
if (ReadData < BUFF_MAX)
{
DataTxIndex = ReadData;
DataRxIndex = ReadData;
WrtieTxBufFlag = 1;
}
}
else
{
WrtieTxBufFlag = 0;
if (DataRxIndex < BUFF_MAX)
{
DataBuf[DataRxIndex] = ReadData;
DataRxIndex++;
}
}
InterruptIndex++;
SSTAT1 &= 0xFE;
}
}
/*---------------------------------EUART0 ISR--------------------------------------------*/
void EUART0ISR(void) interrupt EUART0_VECTOR //using 2
{
if(S0CON & RI0) //接收中断
{
}
RI0 = 0; //清中断标志位
}
复制代码
作者:
coody_sz
时间:
2022-9-8 15:51
printf语句是编译器提供的,只要你的编译器支持,就没有问题,剩下的就是你程序的问题了。
串口初始化好了,printf语句就可以使用。
作者:
yxyxyxyx
时间:
2022-9-8 15:59
编译器里面不支持printf语句,我试了一下田间了stdio.h“文件,编译不成功
作者:
123syf
时间:
2022-9-8 16:39
printf语句需要重定向否则没法正常使用
作者:
hz_dyg
时间:
2022-9-8 21:28
#ifdef __GNUC__
/* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
set to 'Yes') calls __io_putchar() */
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif /* __GNUC__ */
/**
* @brief Retargets the C library printf function to the USART.
* @param None
* @retval None
*/
#if 1
PUTCHAR_PROTOTYPE
{
/* Place your implementation of fputc here */
/* e.g. write a character to the USART */
PortIO_SendChar((uint8_t) ch);
return ch;
}
你需要重新定向你的输出 PortIO_SendChar((uint8_t) ch); 换成你自己的串口输出,前提是初始化好你的串口
作者:
yzwzfyz
时间:
2022-9-9 09:25
楼主还没有弄懂单片机是如何通讯的。补一下吧。
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1