原创 TQ2440裸奔程序:串口UART的PC机按键测试程序

2016-3-9 10:36 1112 14 21 分类: MCU/ 嵌入式

  TQ2440 是由广州天嵌计算机科技有限公司精心打造的一款开发板。以稳定的性能,过硬的质量,丰富的扩展接口,优质的售后服务和技术支持,赢得众多企业的青睐和支持。

  //=========================================

  // NAME: main.c

  // DESC: TQ2440串口UART测试程序

  //=========================================

  /* 头文件包含 */

  #include "def.h"

  #include "option.h"

  #include "2440addr.h"

  #include

  #include

  #include

  #include

  #include

  //======================================================

  static volatile int uart_port = 0;

  void uart_init(int pclk,int buad,int ch)

  {

  //UART初始化:端口使能、功能设定、波特率、设置数据格式

  rGPHCON = (rGPHCON & ~(0xfff<<4)) | (0xaaa<<4);//端口RX[0:2]、TX[0:2]功能

  rGPHUP = rGPHUP | (0x7<<1); //端口GPH[1:3]禁止上拉

  rUFCON0 = 0x0; //禁止FIFO

  rUFCON1 = 0x0; //禁止FIFO

  rUFCON2 = 0x0; //禁止FIFO

  rUMCON0 = 0x0; //禁止AFC

  rUMCON1 = 0x0; //禁止AFC

  //Normal:No parity:One stop:8-bits 中断响应 UART clock: PCLK

  rULCON0 = (rULCON0 & ~0xff) | ((0x0<<6)|(0x0<<3)|(0x0<<2)|(0x3));

  rUCON0 = (rUCON0 & ~0x3ff) | ((0x1<<9)|(0x1<<6)|(0x1<<2)|(0x1));

  rUBRDIV0 = ((int)(pclk/16./buad+0.5)-1);

  rULCON1 = (rULCON1 & ~0xff) | ((0x0<<6)|(0x0<<3)|(0x0<<2)|(0x3));

  rUCON1 = (rUCON1 & ~0x3ff) | ((0x1<<9)|(0x1<<6)|(0x1<<2)|(0x1));

  rUBRDIV1 = ((int)(pclk/16./buad+0.5)-1);

  rULCON2 = (rULCON2 & ~0xff) | ((0x0<<6)|(0x0<<3)|(0x0<<2)|(0x3));

  rUCON2 = (rUCON2 & ~0x3ff) | ((0x1<<9)|(0x1<<6)|(0x1<<2)|(0x1));

  rUBRDIV2 = ((int)(pclk/16./buad+0.5)-1);

  uart_port = ch; //设置串口端口号

  }

  //******************************************************

  // 串口发送函数

  //******************************************************

  //======================================================

  void uart_send_byte(int data)

  {

  if(0 == uart_port)

  {

  if(data == 'n')

  {

  while(!(rUTRSTAT0 & 0x2));

  rUTXH0 = 'n';

  }

  while(!(rUTRSTAT0 & 0x2));

  rUTXH0 = data;

  }

  else if(1 == uart_port)

  {

  if(data == 'n')

  {

  while(!(rUTRSTAT1 & 0x2));

  rUTXH1 = 'n';

  }

  while(!(rUTRSTAT1 & 0x2));

  rUTXH1 = data;

  }

  else if(2 == uart_port)

  {

  if(data == 'n')

  {

  while(!(rUTRSTAT2 & 0x2));

  rUTXH2 = 'n';

  }

  while(!(rUTRSTAT2 & 0x2));

  rUTXH2 = data;

  }

  }

  //======================================================

  void uart_send_string(char *string)

  {

  while(*string)

  {

  uart_send_byte(*string++);

  }

  }

  //======================================================

  void uart_printf(char *fmt,...)

  {

  va_list ap;

  char string[256];

  va_start(ap,fmt);

  vsprintf(string,fmt,ap);

  uart_send_string(string);

  va_end(ap);

  }

  //******************************************************

  // 串口接收函数

  //******************************************************

  //======================================================

  void uart_tx_empty(void)

  {

  if(0 == uart_port)

  {

  while(!(rUTRSTAT0 & 0x4));//等待Tx为空

  }

  if(1 == uart_port)

  {

  while(!(rUTRSTAT1 & 0x4));//等待Tx为空

  }

  if(2 == uart_port)

  {

  while(!(rUTRSTAT2 & 0x4));//等待Tx为空

  }

  }

  //======================================================

  char uart_get_ch(void)

  {

  if(0 == uart_port)

  {

  while(!(rUTRSTAT0 & 0x1));//等待Rx被读

  return rURXH0; //读缓存寄存器

  }

  else if(1 == uart_port)

  {

  while(!(rUTRSTAT1 & 0x1));//等待Rx被读

  return rURXH1; //读缓存寄存器

  }

  else if(2 == uart_port)

  {

  while(!(rUTRSTAT2 & 0x1));//等待Rx被读

  return rURXH2; //读缓存寄存器

  }

  return 0;

  }

  //======================================================

  char uart_get_key(void)

  {

  if(0 == uart_port)

  {

  if(rUTRSTAT0 & 0x1) //Rx被读

  {

  return rURXH0; //读缓存寄存器

  }

  else

  {

  return 0;

  }

  }

  if(1 == uart_port)

  {

  if(rUTRSTAT1 & 0x1) //Rx被读

  {

  return rURXH1; //读缓存寄存器

  }

  else

  {

  return 0;

  }

  }

  if(2 == uart_port)

  {

  if(rUTRSTAT2 & 0x1) //Rx被读

  {

  return rURXH2; //读缓存寄存器

  }

  else

  {

  return 0;

  }

  }

  return 0;

  }

  //======================================================

  void uart_get_string(char *string)

  {

  char *string1 = string;

  char c = 0;

  while((c = uart_get_ch())!='r')

  {

  if(c == 'b')

  {

  if((int)string1 < (int)string)

  {

  uart_printf("bb");

  string--;

  }

  }

  else

  {

  *string++ = c;

  uart_send_byte(c);

  }

  }

  *string = '�';

  uart_send_byte('n');

  }

  //======================================================

  int uart_get_intnum(void)

  {

  char str[30];

  char *string = str;

  int base = 10;

  int minus = 0;

  int result = 0;

  int last_index;

  int i;

  uart_get_string(string);

  if(string[0] == '-')

  {

  minus = 1;

  string++;

  }

  if(string[0] == '0' && (string[1] == 'x' || string[1] == 'X'))

  {

  base = 16;

  string = string + 2;

  }

  last_index = strlen(string)-1;

  if(last_index < 0)

  {

  return -1;

  }

  if(string[last_index] == 'h' || string[last_index] == 'H')

  {

  base = 16;

  string[last_index] = 0;

  last_index--;

  }

  if(base == 10)

  {

  //atoi将字符串转换为整型值

  result = atoi(string);

  result = minus ? (-1*result) : result;

  }

  else

  {

  for(i=0;i<=last_index;i++)

  {

  //判断字符是否为英文字母,当为英文字母a-z或A-Z时,返回非零值,否则返回零。

  if(isalpha(string))

  {

  //isupper 判断字符是否为大写英文字母,当c为大写英文字母,返回非零值,否则返回零。

  if(isupper(string))

  {

  result = (result<<4) + string-'A'+10;

  }

  else

  {

  result = (result<<4) + string-'a'+10;

  }

  }

  else

  {

  result = (result<<4) + string-'0'+10;

  }

  }

  result = minus ? (-1*result) : result;

  }

  return result;

  }

  //======================================================

  int uart_get_intnum_gj(void)

  {

  char string[16];

  char *p_string = string;

  char c;

  int i = 0;

  int data = 0;

  while((c = uart_get_ch()) != 'r')

  {

  if(c == 'b')

  {

  p_string--;

  }

  else

  {

  *p_string++ = c;

  }

  //uart_send_byte(c);

  }

  *p_string = '�';

  i=0;

  while(string != '�')

  {

  data = data*10;

  if(string<'0' || string>'9')

  {

  return -1;

  }

  data = data +(string-'0');

  i++;

  }

  return data;

  }

  //******************************************************

  void Main(void)

  {

  uart_init(50000000,115200,0);

  while(1)

  {

  if('-' == uart_get_ch())

  {

  uart_printf("+n");

  }

  if('+' == uart_get_key())

  {

  uart_printf("-n");

  }

  }

  }

  感谢晨旭晚霞的支持!

  供货情况:

  天嵌科技提供专业嵌入式板卡和行业解决方案。如有需要,可以联系天嵌科技的销售人员。

  销售电话:020-38219416 38373101

  技术支持:020-38219416转807 820

  网址:http://www.embedsky.com

PARTNER CONTENT

文章评论7条评论)

登录后参与讨论

用户1476573 2016-3-16 10:59

活动仍在进行中哦亲,如有需要请去我们淘宝看看,继续关注我们,不定期更新技术文章,希望对你有用

用户1476573 2016-3-16 10:57

有的,请翻找我之前的帖子或是关注我们,不定期有更新技术文章

用户1871598 2016-3-14 16:28

32个赞!!!已分享噢~

用户1871543 2016-3-14 14:20

同学说最近天嵌淘宝有优惠活动,包邮,还送ov9650摄像头跟视频教程光盘,可是我前一个星期就买了2440这套板子,问淘宝客服可不可以送我摄像头,客服说只能是活动期间购买才送……好吧,错过了活动,还好没错过楼主的资料分享!!!拜托下次有活动提前说下!

用户1871561 2016-3-11 20:21

感谢雷锋的分享,有没有有关TQ210的呢?

用户1871547 2016-3-11 15:54

楼主辛苦了,楼主是好人

用户1678053 2016-3-11 08:52

看看
相关推荐阅读
用户1476573 2016-06-27 15:48
TQ210 WINCE 大分辨率不启动的问题
   有客户在TQ210  WINCE系统下遇到大分辨率无法启动的问题,现解决方法如下:   修改了WINCE600\PLATFORM\COMMON\SRC\SOC\S5PV210_SEC_V...
用户1476573 2016-06-12 11:56
天嵌年中狂欢,只打折不打烊
    天嵌年中狂欢,一不做,二不休,终极抄底价,将打折进行到底,机会不是天天有,该出手时就出手!   活动时间     2016年6月13日至17日 ...
用户1476573 2016-05-27 11:02
Cortex-A9嵌入式开发板电池可充电解决方案
  有客户反应E9卡片电脑的rtc久了电池没电不能保存时间,咨询解决方案。E9卡片电脑在设计之初就考虑到客户产品化后可能遇到的这个问题,预留了可充电电池更换的硬件接口。   具体解决方法如下:...
用户1476573 2016-05-20 10:04
TQ210添加永不休眠选项
    很多朋友在使用TQ210做项目的时候都需要屏幕保持长亮,本文介绍如何修改TQ210 android源码,使系统可以永不休眠,代码如下:   1、添加英文选项   修改package...
用户1476573 2016-04-26 10:50
s5pv210中MFC的帧内存格式(转)
  最近调了一下TQ210的mfc硬件h264编码功能,编码是成功了,但出来的视频却是花的。这个问题困扰了我很久,网上关于这方面的资料也很少,没办法只能查看s5pv210的芯片手册,功夫不负有心人...
EE直播间
更多
我要评论
7
14
关闭 站长推荐上一条 /3 下一条