Linux boot fails with "fatal: Unable to find destination for [0x10015000:0x10015008] on system.iobus" because m5ops_base is not being passed to the C++ correctly

Description

[0x10015000:0x10015008] is supposed to be in the m5ops address range.

system.m5ops_base represents the m5ops base address and is configured as 0x10010000 in src/dev/arm/RealView.py. However, it seems not passed correctly to C++ world.

I checked its runtime value in config.ini and also manually printed it out in configs/example/arm/fs_bigLITTLE.py. All of these showed the same result: 268500992 i.e. 0x10010000, which means in python world, the value of system.m5ops_base is set correctly.

When I checked the corresponding value in C++ world, however, it seemed not passed from python world as expected. In src/sim/system.cc, the constructor of the System class sets its member, _m5opRange, according to p->m5ops_base passed from python world. The most strange thing is: the value of p->m5ops_base was 0 ! This made gem5 not recognize the correct m5ops address range.

gem5-dev thread here.

Environment

None

Attachments

2

Activity

Show:

liyichao July 24, 2020 at 1:00 AM

Yes, you’r right. I do “m5 --addr “ in KVM and “m5 --inst“ in O3.

Ciro Santilli July 23, 2020 at 2:55 PM

I think --inst does not work because there’s no way ( ? ) for the KVM CPU to handle gem5 m5op instructions. But there is some way for memory accesses.

liyichao July 23, 2020 at 11:47 AM

I would like to ask a question:

Do I Need to Distinguish “m5 --addr” and “m5 --inst” on KVM CPU OS and O3 CPU OS?

暗黑聖飢魔 July 3, 2020 at 2:20 AM

Bobby Bruce July 3, 2020 at 1:49 AM

Please add me as a reviewer as well . Thank you all for figuring this out!

Done
Pinned fields
Click on the next to a field label to start pinning.

Details

Assignee

Reporter

Priority

Affects versions

Fix versions

Components

Created July 2, 2020 at 6:56 AM
Updated July 24, 2020 at 1:00 AM
Resolved July 3, 2020 at 1:43 PM