Hi Everyone,
We just bought a Juno Versatile Express board for development. Using the getting started guides and I have successfully installed DS-5 on a host and a rootfs on the board. I'm using the LAMP image provided by Linaro for use with the Juno board (linaro-image-lamp-genericarmv8-20150618-754.rootfs.tar.gz). To set up and test CoreSight I am using the guide provided (On-Target Trace Using the CoreSight Access Library | ARM DS-5 Development Studio) and the readmes provided within the CoreSight_access example source.
Building is no problem but I have two issues:
1. When trying to disable the cpuidle I find that I have no cpuidle directory in any /sys/devices/system/cpu/cpu$ folder.
2. When attempting to run the tracedemo example (rel or dbg) I receive a "CSREG: Failed to detect the board!" error. The Juno r1 is defined in the source as a supported board (and also mentioned in the readme as supported).
Does anyone have an idea why I would be seeing this error?
Thanks in advance for any insight you can provide on CoreSight!
Steve
The Device Tree has changed for Juno since r0 and r1 came out -- CSAL seems to simply strcmp against the /proc/cpuinfo Hardware line, and looks for "ARM Juno development board"
Unfortunately since a little while back, Juno r0 /proc/cpuinfo (from the device tree) is "ARM Juno development board (r0)" and r1 is "ARM Juno development board (r1)" which isn't the same string..
ARM Juno development board (r0)
ARM Juno development board (r1)
I think newer CSAL (from DS-5 5.22) works here.. it puts a null character behind the bracket to work around this stuff. I don't know if that would have been present in DS-5 5.21, and in DS-5 5.20 the registration system was different..
Thanks for the responses!
I also run into issues when strncmp the Hardware line /proc/cpuinfo but it is because my /proc/cpuinfo does not have a Hardware line.
Dumping my /proc/cpuinfo I see:
root@genericarmv8:~# cat /proc/cpuinfo processor : 0 Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 CPU implementer : 0x41 CPU architecture: 8 CPU variant : 0x1 CPU part : 0xd07 CPU revision : 1 processor : 1 Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 CPU implementer : 0x41 CPU architecture: 8 CPU variant : 0x1 CPU part : 0xd07 CPU revision : 1 processor : 2 Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 CPU implementer : 0x41 CPU architecture: 8 CPU variant : 0x0 CPU part : 0xd03 CPU revision : 3 processor : 3 Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 CPU implementer : 0x41 CPU architecture: 8 CPU variant : 0x0 CPU part : 0xd03 CPU revision : 3 processor : 4 Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 CPU implementer : 0x41 CPU architecture: 8 CPU variant : 0x0 CPU part : 0xd03 CPU revision : 3 processor : 5 Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 CPU implementer : 0x41 CPU architecture: 8 CPU variant : 0x0 CPU part : 0xd03 CPU revision : 3 root@genericarmv8:~#
root@genericarmv8:~# cat /proc/cpuinfo
processor : 0
Features : fp asimd evtstrm aes pmull sha1 sha2 crc32
CPU implementer : 0x41
CPU architecture: 8
CPU variant : 0x1
CPU part : 0xd07
CPU revision : 1
processor : 1
processor : 2
CPU variant : 0x0
CPU part : 0xd03
CPU revision : 3
processor : 3
processor : 4
processor : 5
root@genericarmv8:~#
Digging a little into this my kernel/module info:
root@genericarmv8:~# uname -a Linux genericarmv8 4.2.0-rc3 #1 SMP PREEMPT Wed Aug 26 11:24:42 UTC 2015 aarch64 GNU/Linux root@genericarmv8:~# lsmod Module Size Used by root@genericarmv8:~# ls /lib/modules/ 3.10.0-1-linaro-lt-vexpress64 3.18 root@genericarmv8:~#
root@genericarmv8:~# uname -a
Linux genericarmv8 4.2.0-rc3 #1 SMP PREEMPT Wed Aug 26 11:24:42 UTC 2015 aarch64 GNU/Linux
root@genericarmv8:~# lsmod
Module Size Used by
root@genericarmv8:~# ls /lib/modules/
3.10.0-1-linaro-lt-vexpress64 3.18
Like my previous post stated I am using the latest prebuilt binaries: juno-latest-oe-uefi.zip and the prebuilt LAMP image: lt-vexpress64-openembedded_lamp-armv8-gcc-4.9_20150620-722.img.gz.
I would expect to have the 4.2 modules in the /lib/modules folder. How did you build/setup your board?
Hello,
You don't need any modules when using the prebuilt binaries, everything you need is built into the kernel rather than built as separate modules.
The issue is that the check for known boards is looking for "Juno", but finds "ARM Juno development board". Note that the "(r0)" and "(r1)" are actually stripped away before the comparison, so that wasn't the problem.
To fix this, edit the following file: /DS-5Examples/CoreSight_access/demos/cs_demo_known_boards.c, changing line 470 to be this:
.hardware = "ARM Juno development board",
Then recompile the example:
/DS-5Examples/CoreSight_access/demos # make clean /DS-5Examples/CoreSight_access/demos # make tracedemo DEBUG=1 LPAE=1 VA64=1
/DS-5Examples/CoreSight_access/demos # make clean
/DS-5Examples/CoreSight_access/demos # make tracedemo DEBUG=1 LPAE=1 VA64=1
You'll also want to recompile the library with the LPAE and VA64 flags if you hadn't before:
/DS-5Examples/CoreSight_access/build # make clean /DS-5Examples/CoreSight_access/build # make DEBUG=1 LPAE=1 VA64=1
/DS-5Examples/CoreSight_access/build # make clean
/DS-5Examples/CoreSight_access/build # make DEBUG=1 LPAE=1 VA64=1
Make sure you've disabled CPUIdle:
# for i in 0 1 2 3 4 5; > for j in 0 1 2; > echo 1 > /sys/devices/system/cpu/cpu$i/cpuidle/state$j/disable; > done; > done;
# for i in 0 1 2 3 4 5;
> for j in 0 1 2;
> echo 1 > /sys/devices/system/cpu/cpu$i/cpuidle/state$j/disable;
> done;
Make sure you've powered on the Juno's debug logic by running the CSAT script provided in the /DS-5Examples/CoreSight_access/demos/juno_demo_setup folder from your host PC connected to a DSTREAM.
Now you can run the demo:
/DS-5Examples/CoreSight_access/bin/dbg # ./tracedemo
And this should now work:
./tracedemo Default configuration, no CPU affinity selected. ITM disabled. kernel symbol found @ 0xFFFFFFC000081000 CoreSight demonstrator ** Currently affine CPUs: #0 #1 #2 #3 #4 #5 CSREG: Detected 'ARM Juno development board' board CSDEMO: Registering CoreSight devices... 0020010000: 2.3 961 00000480 00/0F type= 6 - SINK BUFFER(64K) LINK [TMC - ETF mode] 0020020000: 4.1 906 00040800 00/0F type=10 - CTI 0020030000: 1.1 912 000000A0 00/0F type= 8 - SINK PORT [TPIU] 0020040000: 2.1 908 00000034 00/0F type= 4 - LINK [FUNNEL: 8 in ports] 0020070000: 1.2 961 00002340 00/0F type= 7 - SINK BUFFER(ETR r/w size: 4K) [TMC - ETR mode] 0020100000: 3.6 963 00010000 00/0F type= 3 - SOURCE SWSTIM(65536) [STM ext ports only, 128 masters] 0020110000: 4.1 906 00040800 00/0F type=10 - CTI 0020120000: 2.2 909 00000002 00/0F type= 5 - LINK [REPLICATOR: 2 out ports] 0020130000: 2.1 908 00000033 00/0F type= 4 - LINK [FUNNEL: 8 in ports] 0020140000: 2.3 961 00000480 00/0F type= 6 - SINK BUFFER(64K) LINK [TMC - ETF mode] 0020150000: 2.1 908 00000032 00/0F type= 4 - LINK [FUNNEL: 8 in ports] // ... // ... // ...
./tracedemo
Default configuration, no CPU affinity selected. ITM disabled.
kernel symbol found @ 0xFFFFFFC000081000
CoreSight demonstrator
** Currently affine CPUs: #0 #1 #2 #3 #4 #5
CSREG: Detected 'ARM Juno development board' board
CSDEMO: Registering CoreSight devices...
0020010000: 2.3 961 00000480 00/0F type= 6 - SINK BUFFER(64K) LINK [TMC - ETF mode]
0020020000: 4.1 906 00040800 00/0F type=10 - CTI
0020030000: 1.1 912 000000A0 00/0F type= 8 - SINK PORT [TPIU]
0020040000: 2.1 908 00000034 00/0F type= 4 - LINK [FUNNEL: 8 in ports]
0020070000: 1.2 961 00002340 00/0F type= 7 - SINK BUFFER(ETR r/w size: 4K) [TMC - ETR mode]
0020100000: 3.6 963 00010000 00/0F type= 3 - SOURCE SWSTIM(65536) [STM ext ports only, 128 masters]
0020110000: 4.1 906 00040800 00/0F type=10 - CTI
0020120000: 2.2 909 00000002 00/0F type= 5 - LINK [REPLICATOR: 2 out ports]
0020130000: 2.1 908 00000033 00/0F type= 4 - LINK [FUNNEL: 8 in ports]
0020140000: 2.3 961 00000480 00/0F type= 6 - SINK BUFFER(64K) LINK [TMC - ETF mode]
0020150000: 2.1 908 00000032 00/0F type= 4 - LINK [FUNNEL: 8 in ports]
// ...
I hope that helps.
Thanks again for bring this issue to our attention
Thanks for looking into this Ash!
Even after patching the source, ensuring cpuidle is disabled, and rerunning the CSAT script I still am seeing the following output:
root@genericarmv8:~/CoreSight_access/bin/dbg# ./tracedemo Default configuration, no CPU affinity selected. ITM disabled. kernel symbol found @ 0xFFFFFFC000082000 CoreSight demonstrator ** Currently affine CPUs: #0 #1 #2 #3 #4 #5 CSREG: Failed to detect the board!
root@genericarmv8:~/CoreSight_access/bin/dbg# ./tracedemo
kernel symbol found @ 0xFFFFFFC000082000
CSREG: Failed to detect the board!
I am using the latest prebuilt binaries: juno-latest-oe-uefi.zip and the prebuilt LAMP image: lt-vexpress64-openembedded_lamp-armv8-gcc-4.9_20150620-722.img.gz. found in the getting started guide: Linaro Releases
I believe it because my /proc/cpuinfo has no "Hardware" line:
root@genericarmv8:~/CoreSight_access/bin/dbg# cat /proc/cpuinfo
What does your /proc/cpuinfo look like? What binary/images are you using?
Hi Steve,
Ah, I believe this is due to this patch to the Linux kernel which has made it into the Latest kernel (which is the one you're using, in 'juno-latest-oe-uefi.zip'), whereas it's not yet made it into the LSK as this is the Linaro Stable Kernel. I was building from source and using the LSK which is why it worked for me.
I've informed the maintainers of the CoreSight demo to let them know, but in the mean time I suggest you follow the instructions at the Linaro ARM Platforms Page in order to build your software stack with the LSK rather than the Latest kernel.
As a side note, if you want to disable the CONFIG_STRICT_DEVMEM flag for your kernel, the simplest way to do it is after running this command (when following the steps on the Platforms page):
repo sync -j8
After running that command and before continuing, open the file /linux/linaro/configs/distribution.conf and change this line:
CONFIG_STRICT_DEVMEM=y
Changing the "y" to "n". You can then continue to follow the instructions as normal.
Cheers,
Ash.
Success!!!
Building with the LSK instead of the latest successfully fixed the /proc/cpuinfo out which allowed the CoreSight tracedemo to run.
Thank you so much for the help Ash! You've been a great resource!
No problem, glad to hear it's working for you now
Hello I have a similar problem, but I am working with a xilinx zybo board, after I execute the tracedemo program i get:
$ ./tracedemo
kernel symbo
And then the system hangs. Any suggestion?
From <DS-5>/examples/CoreSight_Access_Library.zip/DS-5Examples/CoreSight_access/demos/cs_demo_known_boards.c:
const struct board known_boards[] = { { .do_registration = do_registration_arndale, .n_cpu = 2, .hardware = "ARNDALE", }, { .do_registration = do_registration_tc2, .n_cpu = 5, .hardware = "ARM-Versatile Express", }, { .do_registration = do_registration_juno, .n_cpu = 6, .hardware = "Juno", }, { .do_registration = do_registration_altera, .n_cpu = 2, .hardware = "Altera SOCFPGA", }, { .do_registration = do_registration_snowball, .n_cpu = 2, .hardware = "ST-Ericsson Snowball platform", }, { .do_registration = do_registration_axx5500, .n_cpu = 16, .hardware = "LSI Axxia", }, {} };
The Xilinx Zybo board is not listed as a known board and therefore is not supported.