嵌入式linux 时间同步,解决嵌入式Linux中的时区问题
如果說讓我做上層軟件的工作,我做起來可以得心應手,但是讓我做平臺方面的工作(系統問題解決、驅動編寫、軟件移植等工作),確實不熟悉。所以很多問題都是摸著石頭過河,沒有經驗。許多問題在有經驗的朋友那里是小菜一碟,而放在我面前總是如遇大山。不免被嘲笑為“弱雞”~
最近我在做基于 Realtek 芯片RTL8196E的家庭網關的研發工作。Realtek提供了一個Linux的SDK開發環境。由于硬件上沒有RTC,所以其中Linux的系統(下面簡稱為RTLinux)時鐘是不正確的。需要時間同步。這個我從busybox中集成了ntpd便可。但是,我發現就算是同步好了時間,在執行 date 命令輸出的時間時區都不對。
我在網上找了許多Linux系統設置時區的辦法。從部分是:將 /usr/share/zoneinfo/Asia/Shanghai 符號鏈接為 /etc/localtime 便可。我在自己的PC機Linux(下面簡稱為PCLinux)上嘗試,果然奏效。而同樣的方法運用到 RTLinux 卻沒有一點效果。
這是博主想抱怨兩句:網上找到的資料大多是告訴你怎么怎么去做就能達到什么目標,而沒有說明為什么要這么做,它內在的原理是什么。如果不知道為什么,那么一旦發生一點變化,就無法變通了。
經博主研究,解決上面問題的辦法有兩種:
設置 /etc/TZ 文件,在該文件中指明時區
設置 TZ 環境變量
若讀者不想深究其原因,那后面的內容便不必再看了。
博主先是發現了 /etc/TZ 這個文件看似時區的意思,其內容為: PST8PDT7,不知道是什么意思。嘗試改改它。
到busybox里去找找 "/etc/TZ",看是誰,是怎么實用這個文件的。沒有找到相關的引用。
到Linux內核中去找。也沒有~
到boards中去找。結果找到:
可以看出是在 romfs/lib/libc.so.0 庫文件里的。
而這個庫文件則是由toolchain的工具集中復制得來。
于是再到toolchain下去找,結果有很多:
這時區的問題原來是由uclibc來決定的。
去看看uclibc/libc/misc/time/time.c中是怎么解決 /etc/TZ 文件的。
read_TZ_file()函數從 __UCLIBC_TZ_FILE_PATH__宏所(值為"/etc/TZ")指文件中讀取數據。
在 _time_tzset(int use_old_rules) 中設置時區。
大致過程:
e?=?getenv("TZ");
if?((!e?&&?!(e?=?read_TZ_file(buf)))?||?!*e)?{
//!ERROR
}
可見,e先是從環境變量中去讀,如果沒有再從 /etc/TZ 中去讀??,??這就是我們想要的原理。
接下來就是一大推解析相關的處理。這個我就不花時間去研究這個過程了,主要去看一下有沒有相關的說明文檔。
OK,我全明白了。 如果是在中國,那么就應該將變量設置成:"CST-8",試試看:
成功!
現在有兩種方案:
直接到時區信息寫到 /etc/TZ 文件
在系統啟動時,設置環境變量 TZ
這兩者都可以做。我們先默認在 /etc/TZ 文件中寫入 "CST-8"
問題解決!
總結
以上是生活随笔為你收集整理的嵌入式linux 时间同步,解决嵌入式Linux中的时区问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ios游戏开发 Sprite Kit教程
- 下一篇: linux 其他常用命令