From: meino.cramer@gmx.de
To: gentoo-embedded <gentoo-embedded@lists.gentoo.org>
Subject: [gentoo-embedded] Additional informations about the clock drifting problem on the Arietta G25
Date: Sun, 7 Dec 2014 06:36:28 +0100 [thread overview]
Message-ID: <20141207053628.GA6232@solfire> (raw)
Hi,
when dmesg is called right after logging into an Arietta G25,
which was freshly rebooted you will find either this line
lines:
[ 0.054687] Calibrating delay loop... 198.76 BogoMIPS (lpj=775168)
or these lines:
[ 0.000000] Main crystal frequency not set, using approximate value
[ 0.000000] master clk is overclocked
If you experience heavy clock drifts AND you find the second group of
lines in dmesgs output...then the clocks are not defined properly in
the dts file for your Arietta.
Up to kernel 3.16.1, which is used by Acmesystem another clock setting
mechanism was valid and choosen while compiling the kernel. So the dts
file provided by Acmesystems for the Arietta dont need to define all
clock settings and works well with that kernel.
For kernels after that (dont know, when the switch happened exactly),
you need to define all clock settings in the dts file.
A posting in the google groups for the Arietta board by dpvgi shows
the correct settings.
The settings in the original dts file by Acmesystems for the clock
settings are:
clocks {
#address-cells = <1>;
#size-cells = <1>;
ranges;
main_clock: clock@0 {
compatible = "atmel,osc", "fixed-clock";
clock-frequency = <12000000>;
};
};
and should be replaced by
clocks {
#address-cells = <1>;
#size-cells = <1>;
ranges;
main_clock: clock@0 {
compatible = "atmel,osc", "fixed-clock";
clock-frequency = <12000000>;
};
slow_xtal {
clock-frequency = <32768>;
};
main_xtal {
clock-frequency = <12000000>;
};
};
for kernel newer than version 3.16.1
The file to patch is located here
<root of your kernel source tree>/arch/arm/boot/dts/acme-arietta.dts
in the kernel tree (linux 3.18.rc7 as mentioned in my previous post)
Dont rename that file, since otherwise the kernel compilation process
will not find and or create the correct dtb.
You dont need to recompile the whole kernel to create a new dtb file.
Just setup your cross compiling prefix. For that I choose (using zsh,
any other ksh like shell will do):
export CCC=<insert path to your toolchain here>/gcc-linaro-arm-none-eabi-4.9-2014.09_linux/bin/arm-none-eabi-
and then (after changing the above lines) call
make ARCH=arm CROSS_COMPILE=${CCC} acme-arietta.dtb
. scp the resulting dtb file (same place as the according dts file) to
the /boot/. directory of your Arietta and reboot.
A dmesg should show the above Bogomips output and the clock
does not drift anymore (that much...RTCs of that kind are no
chronometers...)
HTH!
Best regards
Meino
reply other threads:[~2014-12-07 5:36 UTC|newest]
Thread overview: [no followups] expand[flat|nested] mbox.gz Atom feed
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20141207053628.GA6232@solfire \
--to=meino.cramer@gmx.de \
--cc=gentoo-embedded@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox