博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mini2440裸机试炼之——Uart与pc端实现文件、字符传输
阅读量:4569 次
发布时间:2019-06-08

本文共 3564 字,大约阅读时间需要 11 分钟。

1、  波特率(Baud rate)即调制速率,1波特即指每秒传输1个符号。

2、  非FIFO模式,即数据传输不利用FIFO缓存,一个字节一个字节地传输。

3、  接收到的数据是放到接收缓存器URXHn中。要发送数据时,是把数据放入发送缓存器UTXHn中。因为UART是通过字节方式数据传输的。因此要区分是大端模式还是小端模式,也就是说这两个寄存器在这两种模式下,所在的地址是不同。为了了解当前数据传输的各种状态,还须要一些状态寄存器。传输状态寄存器UTRSTATn很实用,它的第0位能够用来推断接受缓存器内是否有可接收的数据。第1位和第2位能够用来推断发送缓存器中是否为空,为空时能够发送数据。因为在这里我们不进行数据传输时错误的推断。因此错误状态寄存器UERSTATn不须要。FIFO状态寄存器UFSTATnMODEM状态寄存器UMSTATn在这里也不须要。

本来是想使用中断方式接收和发送的,可是仅仅实现发送接收一个字符。

之后试下查询方式,结果能行。

Uart方框图

1、使用非FIFO模式时,接收、发送缓存寄存器仅仅存一个字节

2、时钟源使用PCLK(50000000)。波特率为115200;

      UBRDIVn= (int)( UART时钟 / ( 波特率 ×16) ) – 1   

配置GPH

 

rGPHCON|=((2<<4)|(2<<6));    //设置GPH2、GPH3为TXD0、RXD0功能

rGPHUP=0x00;               //上拉电阻使能

设置Uart寄存器

rUFCON0 = 0x0;              //禁止FIFO

rUMCON0 = 0x0;             //禁止AFC

 

UCONn控制寄存器:

rUCON0=0x05;                //发送模式和接收模式都使用查询模式

 

ULCONn控制寄存器:

rULCON0|=0x03;              //设置UART0数据发送8个数据位

赵老师的一段话(关于中断的。作为笔记):

最后还要强调几点关于非FIFO模式下UART中断的一些注意事项:1.对于s3c2440来说。接收数据是被动的,发送数据是主动的。因此一般来说。接收数据用中断方式,发送数据用查询方式较好;2. 在中断方式下,当接收到数据时,虽然可能该数据无用,但也一定要读取它,否则下次再接收数据时,不会再引起中断,因为接收数据缓存器被上次接收到的数据所霸占。仅仅要没有读取它,它就永远在那里;3. 因为UART中断涉及到SUBSRCPND寄存器,因此在中断处理程序中不仅要清SRCPND寄存器,还要清SUBSRCPND寄存器,它们的顺序一定是先清SUBSRCPND寄存器,再清SRCPND寄存器,否则就会引起一个中断两次响应的问题。因为是否中断由SRCPND寄存器决定,而SRCPND寄存器的相关状态位由SUBSRCPND寄存器决定。假设先清SRCPND寄存器,而还没有清SUBSRCPND寄存器的话,SRCPND寄存器的相关位还是会被置1,而一旦被置1,则一定还会引起中断。

总结:

使用查询方法确实能够通过PC端的串口工具发送文件或者字符串,再通过uart0接收文件或字符串发送给PC端的串口工具和存储于文件uart.txt中,可是过程中会出现字符丢失(发送回PC端串口工具和文件里都是一样的情况)的情况。如今感觉可能是串口工具同步的问题或者机器之间的延迟问题,时间的延迟并不会影响串口之间数据传输

代码区:

Main.c

#define GLOBAL_CLK      1#include "def.h"#include "option.h"#include "2440addr.h"#include "2440lib.h"  //函数声明#include "2440slib.h"#include "mmu.h"#include "profile.h"extern void Uart(void); void Main(void){       U32 mpll_val = 0,consoleNum;    Port_Init();       mpll_val = (92<<12)|(1<<4)|(1);        //init FCLK=400M,    ChangeMPllValue((mpll_val>>12)&0xff, (mpll_val>>4)&0x3f, mpll_val&3);    ChangeClockDivider(14, 12);   //the result of rCLKDIVN [0:1:0:1] 3-0 bit    cal_cpu_bus_clk();            //HCLK=100M   PCLK=50M           MMU_Init(); //地址映射初始化        Beep(2000, 100);       Uart();            //实现串口传送文件 字符串到开发板。并显示在串口终端(调试成功!

) }

Uart.c

#include "2440addr.h" #include "def.h"#include "2440lib.h"#include 
//文件库函数void Uart_init(){//下面使用uart0 rGPHCON&=~((3<<4)|(3<<6)); //GPH2--TXD0;GPH3--RXD0 rGPHCON|=((2<<4)|(2<<6)); //设置GPH2、GPH3为TXD0、RXD0功能//手冊中GPH2、GPH3描写叙述例如以下://GPHCON Bit Description//GPH3 [7:6] 00 = Input 01 = Output // 10 = RXD0 11 = reserved//GPH2 [5:4] 00 = Input 01 = Output// 10 = TXD0 11 = Reserved rGPHUP=0x00; //上拉电阻使能 rUFCON0 = 0x0; //禁止FIFO rUMCON0 = 0x0; //撤销nRTS rULCON0|=0x03; //设置UART0数据发送8个数据位 rUCON0=0x05; //发送模式和接收模式都使用查询模式 //设置波特率,当中波特率作为一个參数传递到该初始化函数 rUBRDIV0=(int)((50000000/(115200*16))-1); Delay( 10 ) ; } void Uart(){ int i=0; char ch; FILE *FP; //文件指针 FP=fopen("uart.txt","w"); //以写方式打开uart.txt文件 Uart_init(); //uart初始化函数 while(1){ if(rUTRSTAT0&1) { //假设接收数据缓存器接收到有效数据 ch = rURXH0; //ch存储接收字节数据 rUTXH0=ch; //PC机将接收的字符通过串口调试工具显示在屏幕上 fputc(ch,FP); //将ch字符内容存进文件里 i++; if(i>200) fclose(FP); //假设有200个字节关闭文件 } } }

结果截图:

1、PC端串口工具

2、Uart.txt是存储于项目2440test_Data\DebugRel_bin文件夹下。与bin文件同一文件夹

转载于:https://www.cnblogs.com/llguanli/p/8616208.html

你可能感兴趣的文章
redis哈希表数据类型键的设置
查看>>
redis字符串类型键的二进制操作
查看>>
redis哈希表数据类型键的查询和删除命令
查看>>
redis列表数据类型---list
查看>>
redis集合数据类型---SET
查看>>
php 字符串函数
查看>>
PHP数组函数
查看>>
PHP Math函数
查看>>
PHP Math常量
查看>>
idea使用git上传项目到coding
查看>>
SpringMVC+mybatis配置多数据源
查看>>
mybatis中条件查询大于等于和小于等于写法
查看>>
mybatis无法给带有下划线属性赋值问题
查看>>
java.lang.NoSuchMethodException: com.sun.tools.javac.util.List.<init>()
查看>>
Could not set property of class with value There is no setter for property named
查看>>
Could not find result map com.youotech.tl_cons_credit_rating.entity.Result
查看>>
Element ui 上传文件组件(单文件上传) 点击提交 没反应
查看>>
vue子传父、父传子
查看>>
centos安装ffmpeg4.2
查看>>
启动程序添加启动脚本
查看>>