解決嵌入式Linux中的時區問題

2021-09-23 21:35:35 字數 1938 閱讀 8681

如果說讓我做上層軟體的工作,我做起來可以得心應手,但是讓我做平台方面的工作(系統問題解決、驅動編寫、軟體移植等工作),確實不熟悉。所以很多問題都是摸著石頭過河,沒有經驗。許多問題在有經驗的朋友那裡是小菜一碟,而放在我面前總是如遇大山。不免被嘲笑為「弱雞」~

最近我在做基於 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)

可見,e先是從環境變數中去讀,如果沒有再從 /etc/tz 中去讀,這就是我們想要的原理。

接下來就是一大推解析相關的處理。這個我就不花時間去研究這個過程了,主要去看一下有沒有相關的說明文件。

在uclibc的官網: 中找"tz",有:

在  找到解答:

ok,我全明白了。 如果是在中國,那麼就應該將變數設定成:"cst-8",試試看:

成功!現在有兩種方案:

這兩者都可以做。我們先預設在 /etc/tz 檔案中寫入 "cst-8"

問題解決!

嵌入式面試經典30問

嵌入式面試經典30問 在經過4個多月的學習後,學員們最關心的問題莫過於如何拿到高薪offer問題了。但是很多同學說很害怕面試,看見面試官會露怯,怕自己的知識體系不完整,怕面試官考的問題回答不上了,所以今天為大家準備了嵌入式工程師面試經常遇到的30個經典問題,希望可以幫助大家提前準備,不再懼怕面試 1...

嵌入式面試經典30問

嵌入式面試經典30問 在經過4個多月的學習後,學員們最關心的問題莫過於如何拿到高薪 offer 問題了。但是很多同學說很害怕面試,看見面試官會露怯,怕自己的知識體系不完整,怕面試官考的問題回答不上了,所以今天為大家準備了嵌入式工程師面試經常遇到的30個經典問題,希望可以幫助大家提前準備,不再懼怕面試...

嵌入式 linux 編譯

第二次換了編譯環境編譯時又提示 make 3 drivers video console vgacon.o 錯誤 1 在網上搜尋結果 根據資訊的大概意思是關於vga的支援問題,在這裡我直接把關於vga的配置選項去掉不選,即 在執行 make menuconfig 配置時 不選vga 驅動。devic...