搜索
bottom↓
回复: 2

【经验分享】RTC_TSR寄存器读出不正确,咋回事?

[复制链接]

出0入0汤圆

发表于 2014-4-23 10:17:00 | 显示全部楼层 |阅读模式
本帖最后由 FSL_TICS_Robin 于 2014-7-18 14:11 编辑

客户问题介绍:
•        芯片型号:MK60DN512ZVMD10
•        描述:在程序中,连续不断的读取RTC_TSR寄存器值,并将结果传给上位机,但发现连续读出的值出现前后不匹配的问题,从理论上分析,RTC_TSR寄存器内的值应该逐渐递增的,但从打印的输出结果看,存在个别前后不一致的现象(如图1所示),所以怀疑这是不是芯片的Bug呢?

图1

表1

  1. #include <stdio.h>
  2. #include <drivers/uart/uart.h>
  3. #include "cmd_rtcdebug.h"
  4. #include "common.h"

  5. extern "C"
  6. {
  7. #include "wdog.h"
  8. }

  9. extern "C"
  10. int cmd_rtcdebug(const char *args)
  11. {
  12.         uint32_t lowestValue;
  13.         uint32_t lastFailValue = 0;
  14.         uint32_t failCountInRow = 0;
  15.     int wdCount = 0;

  16.         lowestValue = RTC_TSR;

  17.         printf("press any key to exit\r\n");

  18.         while(1)
  19.         {
  20.                 uint32_t nextValue = RTC_TSR;

  21.                 if (uart_kbhit())
  22.                 {
  23.                         break;
  24.                 }

  25.                 if (nextValue < lowestValue)
  26.                 {
  27.                         if (lastFailValue != nextValue)
  28.                         {
  29.                                 printf("RTC fail: lowest value: %u, next value: %u\r\n", lowestValue, nextValue);
  30.                         }
  31.                         lastFailValue = nextValue;
  32.                         failCountInRow++;
  33.                 }
  34.                 else if (nextValue == lowestValue)
  35.                 {
  36.                         if (failCountInRow)
  37.                         {
  38.                                 printf("RTC fails in row: %u\r\n", failCountInRow);
  39.                                 failCountInRow = 0;
  40.                         }
  41.                 }
  42.                 else if (nextValue > lowestValue)
  43.                 {
  44.                         if (failCountInRow)
  45.                         {
  46.                                 printf("RTC fails in row: %u\r\n", failCountInRow);
  47.                                 failCountInRow = 0;
  48.                         }

  49.             if (wdCount > 300)
  50.             {
  51.                 wdog_refresh();
  52.                 wdCount = 0;
  53.             }
  54.             wdCount++;
  55.             
  56.                         printf("RTC_TSR: %u\r\n", nextValue);
  57.                         lowestValue = nextValue;
  58.                 }
  59.         }

  60.         return 0;
  61. }
复制代码

        针对第一个猜测,在查阅Errata文档后,大致可以排除;至于第二个猜测,我应对的方法是在每次读取RTC_TSR寄存器之前,添加一个延时函数,经过一段时间的测试后,发现出错的频率虽然没有原来那么多,但还是会出现,看来这是个治标不本的方法啊,只能另想方法啊。
        各位网友有没有好的想法,欢迎来讨论!




PS:本帖可从飞思卡尔版块置顶帖:飞思卡尔Kinetis资料大本营飞思卡尔论坛支持小组【经验分享】帖汇总链接进入。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出0入0汤圆

 楼主| 发表于 2014-4-23 10:17:26 | 显示全部楼层
欢迎大伙积极来论坛交流哦!

出0入0汤圆

 楼主| 发表于 2014-4-30 10:24:53 | 显示全部楼层
本帖最后由 FSL_TICS_ZP 于 2014-4-30 10:28 编辑

      看来大家的讨论不积极啊,答案揭晓!
      在咨询过AE部门后,发现问题的根源是K60的参考没有给出读取RTCRTC_TSR需要注意的细节。而在K64的参考手册却有这么一段话(如下所示),而问题也就迎仍而解啊!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-27 00:44

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表