lPC1788的串口通讯
#ifndef __DEBUGSERIAL_H_
#define __DEBUGSERIAL_H_
#include "sys.h"
#include "stdio.h"
extern u8 serialBuffer[256];
extern u16 serialStatus;
//ڰ
void Debug_Serial_Init(u32 baud);
void Debug_Serial_Send_Byte(u8 dat);
void Debug_Serial_Send_Buffer(u8 length,u8* buffer);
#endif
#include "debugSerial.h"
//加入printf支持
#pragma import(__use_no_semihosting)
struct __FILE
{
int handle;
/* Whatever you require here. If the only file you are using is */
/* standard output using printf() for debugging, no file handling */
/* is required. */
};
FILE __stdout;
_sys_exit(int x)
{
x = x;
}
int fputc(int ch, FILE *f)
{
while(!((LPC_UART0->LSR) & 0x20)); //等待判断LSR[5](即THRE)是否是1,1时表示THR中为空
LPC_UART0->THR = (u8)ch; //发送数据
return ch;
}
//定义一个256字节的缓冲区用于存放接收到的串口数据信息
//定义一个16位数据同时保存接收数据长度以及接收数据的状态
u8 serialBuffer[256] = {0};
u16 serialStatus = 0;
//16字节的状态
//低八位为当前存储的有效数据长度
//15位为接收完成等待处理标志
//8位表示当前已经接受到回车符\r
//第9到十四位表示在等待处理期间系统冗余发送的数据量
//用于后期通讯系统的负载自适应
void TransSerialsCommand(u8 res)
{
u8 lostCount;
u8 receiveCount;
//接收数据处理
if(serialStatus & (1<<15))//已经接收完成,这个数据被抛弃
{
lostCount = ((u8)(serialStatus>>9))&0x3f;//漏掉的数据计数
if(lostCount < 0x3f)lostCount++;
serialStatus &= ~(0x3f<<9);
serialStatus |= (lostCount<<9);
}
else//上一个命令没有接收完
{
if(serialStatus & (1<<8))//接收到\r
{
//等待接收\N
if(res == '\n')
{
//接收完成
serialStatus |= 0x8000;
}
else//不是\n,这一次命令作废
{
serialStatus = 0;
}
}
else//没收到\r
{
if(res == '\r')
{
serialStatus |= 0x0100;
}
else
{
receiveCount = (u8)(serialStatus&0xff);
if(receiveCount < 255)
{
serialBuffer[receiveCount] = res;
receiveCount++;
serialStatus &= 0xff00;
serialStatus |= receiveCount;
}
else
{
//数据溢出,清空
serialStatus = 0;
}
}
}
}
}
void UART0_IRQHandler(void)
{
u8 status = 0;
u8 res = 0;
//清除串口中断挂起
NVIC_ClearPendingIRQ(GPIO_IRQn);
//清除串口接收中断
if(!(LPC_UART0->IIR & 0x01))//确认有中断发生
{
status = LPC_UART0->IIR & 0x0e;
if(status == 0x04)//确认是RDA中断
{
//读取串口接收值
res = (LPC_UART0->RBR&0xff);
//处理串口接收值
TransSerialsCommand(res);
}
}
}
void Debug_Serial_Init(u32 baud)
{
LPC_SC->PCONP |= (1<<3)|(1<<15); //打开时钟
//配置io口
LPC_IOCON->P0_2 = 0x00; //选择TXD功能,禁止迟滞 不反向 正常推挽
LPC_IOCON->P0_2 |= (1<<0)|(2<<3); //上拉
LPC_IOCON->P0_3 = 0x00; //选择RXD功能,禁止迟滞 不反向 正常推挽
LPC_IOCON->P0_3 |= (1<<0)|(2<<3); //上拉
LPC_UART0->LCR = 0x83; //设置串口数据格式,8位字符长度,1个停止位,无校验,使能除数访问
LPC_UART0->DLM = ((ApbClock/16)/baud) / 256; //除数高八位 , 没有小数情况
LPC_UART0->DLL = ((ApbClock/16)/baud) % 256; //除数第八位
LPC_UART0->LCR = 0x03; //禁止访问除数锁存器,锁定波特率
LPC_UART0->FCR = 0x00; //禁止FIFO
LPC_UART0->IER = 0x01; //使能接收中断RDA
NVIC_EnableIRQ(UART0_IRQn); //打开IRQ中断
}
void Debug_Serial_Send_Byte(u8 dat)
{
//当检测到UARTn THR已空时,THRE就会立即被设置。写UnTHR会清零THRE
//0 - UnTHR包含有效字符
//1 - UnTHR为空
while(!((LPC_UART0->LSR) & 0x20)); //等待判断LSR[5](即THRE)是否是1,1时表示THR中为空
LPC_UART0->THR = dat; //发送数据
}
void Debug_Serial_Send_Buffer(u8 length,u8* buffer)
{
u8 i = 0;
for(i = 0; i < length; i++)
{
Debug_Serial_Send_Byte(buffer[i]);
}
printf("\r\n");
}
lPC1788的串口通讯的更多相关文章
- C#串口通讯实例
本文参考<C#网络通信程序设计>(张晓明 编著) 程序界面如下图: 参数设置界面代码如下: using System; using System.Collections.Generic; ...
- delphi之动态库调用和串口通讯
串口通讯: Spcomm 控件属性: CommName :表示COM1,COM2等串口的名字: BaudRate:设定波特率9600,4800等 StartComm StopComm 函数Write ...
- 用SPCOMM 在 Delphi中实现串口通讯 转
用Delphi 实现串口通讯,常用的几种方法为:使用控件如MSCOMM和SPCOMM,使用API函数或者在Delphi 中调用其它串口通讯程序.利用API编写串口通信程序较为复杂,需要掌握大量通信 ...
- 西门子plc串口通讯方式
西门子plc串口通讯的三种方式 时间:2015-10-25 14:31:55编辑:电工栏目:西门子plc 导读:西门子plc串口通讯的三种方式,分为RS485 串口通信.PPI 通信.MPI 通信,自 ...
- 教程-Delphi MSComm 实时串口通讯
Delphi MSComm 实时串口通讯 MSComm控件具有丰富的与串口通信密切相关的属性,提供了对串口进行的多种操作,进而使串行通信变得十分简便.MSComm的控件属性较多,常用的属性如下:1) ...
- 浅析PC机串口通讯流控制
转自浅析PC机串口通讯流控制 我们在串行通讯处理中,常常看到RTS/CTS和XON/XOFF这两个选项,这就是两个流控制的选项,目前流控制主要应用于调制解调器的数据通讯中,但对普通RS232编程,了解 ...
- STM32F10x 学习笔记6(USART实现串口通讯 2)
这次讲讲利用串口收发中断来进行串口通讯.STM32 上为每个串口分配了一个中断.也就是说无论是发送完成还是收到数据或是数据溢出都产生同一个中断.程序需在中断处理函数中读取状态寄存器(USART_SR) ...
- STM32F10x 学习笔记5(USART实现串口通讯 1)
STM32F10x 系列单片机中都包含了USART 模块,所谓USART,就是通用同步异步收发器.通用同步异步收发器(USART)提供了一种灵活的方法与使用工业标准NRZ异步串行数据格式的外部设备之间 ...
- Java利用Rxtx进行串口通讯
最近在做传感器数据采集的工作,底层是基于Zigbee的无线传感网络,所有数据采集到Zigbee协调器上然后通知上位机数据采集完成,上位机通过USB转串口去读取数据就可以了.那么问题来了,如何进行串口通 ...
随机推荐
- Swift 学习笔记 (一)
原创: 转载请注明出处 Extention try catch rxSwift internal public private var let as as? 强转 ? ! didSe ...
- sockaddr_u详解
struct sockaddr { unsigned short sa_family; /* address family, AF_xxx */ char sa_data[14]; ...
- 转载 Deep learning:六(regularized logistic回归练习)
前言: 在上一讲Deep learning:五(regularized线性回归练习)中已经介绍了regularization项在线性回归问题中的应用,这节主要是练习regularization项在lo ...
- AngularJS 基础用法
判断语句: <li ng-repeat=”person in persons”> <span ng-switch on=”person.sex”> <span ng-sw ...
- Ubuntu 12.04和Windows 7双系统安装图解
http://wenku.baidu.com/link?url=PZlnNOhY0SjHDW-teFFnCMzPYJVjx7vj6yWY-o5HHFLuFqhLI4uFcQVu_y0_6i7vpSnz ...
- HDU1372,BFS象棋马走日
简单的对于bfs的运用,但是还是写的太慢了写了TMD的1H,主要是不熟悉,以后慢慢熟悉就好了,模型基本已经能建立了,主要出现bug是在方向数组的运用上面,一定要记得是从0开始的,而不是从1开始的,导致 ...
- ibdata1文件--缩小mysql数据库的ibdata1文件
摘要 在MySQL数据库中,如果不指定innodb_file_per_table参数,单独存在每个表的数据,MySQL的数据都会存放在ibdata1文件. mysql ibdata1存放数据,索引等, ...
- FAT32系统中长文件名的存储(转)
FAT32的一个重要的特点是完全支持长文件名.长文件名依然是记录在目录项中的. 为了低版本的OS或程序能正确读取长文件名文件,系统自动为所有长文件名文件创建了一个对应的短文件名,使对应数据既可以用长文 ...
- docker安装hadoop
docker为hadoop的云化带来了极大便利,安装和应用也会更快更方便.进入正题: docker search hadoop 将会看到如下结果: INDEX NAME DESCRIPTION STA ...
- apache2.2.25+mod_jk-apache-2.2.2.so+apache-tomcat-7.0.56集群
1.安装httpd-2.2.25-win32-x86-no_ssl.msi 按默认安装路径,我电脑如果自定义的话安装不了 2.下载mod_jk-apache-2.2.2.so 3.下载tomcat 我 ...