Bug 400872 - Add nanoMIPS support to Valgrind
Summary: Add nanoMIPS support to Valgrind
Status: RESOLVED FIXED
Alias: None
Product: valgrind
Classification: Developer tools
Component: general (show other bugs)
Version: unspecified
Platform: Other Linux
: NOR normal
Target Milestone: ---
Assignee: Julian Seward
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2018-11-09 15:59 UTC by Aleksandar Rikalo
Modified: 2020-01-06 14:14 UTC (History)
1 user (show)

See Also:
Latest Commit:
Version Fixed In:
Sentry Crash Report:


Attachments
Mips specific code refactor (2.78 MB, patch)
2018-11-09 15:59 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 1/4 (251.05 KB, patch)
2018-11-09 16:01 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 2/4 (140.29 KB, patch)
2018-11-09 16:02 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 3/4 (4.31 KB, patch)
2018-11-09 16:02 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 4/4 (87.29 KB, patch)
2018-11-09 16:03 UTC, Aleksandar Rikalo
Details
Fix some tests so they can be compiled for nanoMIPS (12.44 KB, patch)
2018-11-09 16:04 UTC, Aleksandar Rikalo
Details
Add tests for nanoMIPS instruction set (460.94 KB, patch)
2018-11-09 16:05 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 1/4 (251.12 KB, patch)
2019-08-20 15:16 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 2/4 (140.86 KB, patch)
2019-08-20 15:17 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 3/4 (4.35 KB, patch)
2019-08-20 15:17 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 4/4 (87.41 KB, patch)
2019-08-20 15:17 UTC, Aleksandar Rikalo
Details
Fix some tests so they can be compiled for nanoMIPS (12.45 KB, patch)
2019-08-20 15:19 UTC, Aleksandar Rikalo
Details
Add tests for nanoMIPS instruction set (461.01 KB, patch)
2019-08-20 15:20 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 3/4 (17.27 KB, patch)
2019-12-13 14:43 UTC, Aleksandar Rikalo
Details
Add nanoMIPS support to Valgrind 4/4 (86.14 KB, patch)
2019-12-13 14:44 UTC, Aleksandar Rikalo
Details
Fix some tests so they can be compiled for nanoMIPS (12.19 KB, patch)
2019-12-13 14:44 UTC, Aleksandar Rikalo
Details
Add tests for nanoMIPS instruction set (468.79 KB, patch)
2019-12-13 14:45 UTC, Aleksandar Rikalo
Details

Note You need to log in before you can comment on or make changes to this bug.
Description Aleksandar Rikalo 2018-11-09 15:59:51 UTC
Created attachment 116204 [details]
Mips specific code refactor

Here are few patches which implement nanoMIPS support.
This issue depends on #400593.
Comment 1 Aleksandar Rikalo 2018-11-09 16:01:55 UTC
Created attachment 116206 [details]
Add nanoMIPS support to Valgrind 1/4
Comment 2 Aleksandar Rikalo 2018-11-09 16:02:25 UTC
Created attachment 116207 [details]
Add nanoMIPS support to Valgrind 2/4
Comment 3 Aleksandar Rikalo 2018-11-09 16:02:51 UTC
Created attachment 116208 [details]
Add nanoMIPS support to Valgrind 3/4
Comment 4 Aleksandar Rikalo 2018-11-09 16:03:33 UTC
Created attachment 116209 [details]
Add nanoMIPS support to Valgrind 4/4
Comment 5 Aleksandar Rikalo 2018-11-09 16:04:48 UTC
Created attachment 116210 [details]
Fix some tests so they can be compiled for nanoMIPS
Comment 6 Aleksandar Rikalo 2018-11-09 16:05:44 UTC
Created attachment 116211 [details]
Add tests for nanoMIPS instruction set
Comment 7 Aleksandar Rikalo 2018-11-09 16:16:21 UTC
Here are few patches which implement nanoMIPS support:

* Mips specific code refactor - there is no functional impact but it is necessary in order apply other patches.

* nanoMIPS support to Valgrind */4 - Add full support for nanoMIPS architecture, including VEX, Coregrind, makefiles, VKI, ..., README. These patches can be merged into one.

* Fix some tests so they can be compiled for nanoMIPS - improve problematic tests so they can be compiled for nanoMIPS.

* Add tests for nanoMIPS instruction set - adds nanoMIPS tests.

Regression tests are done on x86, AMD64, mips32 and mips64.

This issue also depends on #400593.

Regards,
Aleksandar
Comment 8 Petar Jovanovic 2019-07-23 13:42:35 UTC
I will try to review and merge these changes hopefully soon.
If anyone has any objections, please raise them here.
Comment 9 Petar Jovanovic 2019-08-14 17:02:28 UTC
(In reply to Aleksandar Rikalo from comment #1)
> Created attachment 116206 [details]
> Add nanoMIPS support to Valgrind 1/4

Can you rebase all the changes and make sure no new warnings are generated after the patches are applied?
Comment 10 Aleksandar Rikalo 2019-08-20 15:16:22 UTC
Created attachment 122259 [details]
Add nanoMIPS support to Valgrind 1/4
Comment 11 Aleksandar Rikalo 2019-08-20 15:17:02 UTC
Created attachment 122260 [details]
Add nanoMIPS support to Valgrind 2/4
Comment 12 Aleksandar Rikalo 2019-08-20 15:17:22 UTC
Created attachment 122261 [details]
Add nanoMIPS support to Valgrind 3/4
Comment 13 Aleksandar Rikalo 2019-08-20 15:17:51 UTC
Created attachment 122262 [details]
Add nanoMIPS support to Valgrind 4/4
Comment 14 Aleksandar Rikalo 2019-08-20 15:19:05 UTC
Created attachment 122263 [details]
Fix some tests so they can be compiled for nanoMIPS
Comment 15 Aleksandar Rikalo 2019-08-20 15:20:44 UTC
Created attachment 122264 [details]
Add tests for nanoMIPS instruction set

Re-based onto current master branch.
There are no regressions on x86 and MIPS platforms.
Comment 16 Petar Jovanovic 2019-09-03 14:17:19 UTC
(In reply to Aleksandar Rikalo from comment #11)
> Created attachment 122260 [details]
> Add nanoMIPS support to Valgrind 2/4

First of all, thank you for all this work.
I have committed majority of the changes from the patches #1 (VEX) and #2 (Coregrind).
As I said in a different thread, I believe some parts of it can be omitted or done differently, so please revisit the changes that have not been applied and resend what you believe should still be committed and we can continue discussion from there.
Comment 17 Aleksandar Rikalo 2019-12-13 14:43:29 UTC
Created attachment 124466 [details]
Add nanoMIPS support to Valgrind 3/4
Comment 18 Aleksandar Rikalo 2019-12-13 14:44:14 UTC
Created attachment 124467 [details]
Add nanoMIPS support to Valgrind 4/4
Comment 19 Aleksandar Rikalo 2019-12-13 14:44:53 UTC
Created attachment 124468 [details]
Fix some tests so they can be compiled for nanoMIPS
Comment 20 Aleksandar Rikalo 2019-12-13 14:45:45 UTC
Created attachment 124469 [details]
Add tests for nanoMIPS instruction set
Comment 21 Petar Jovanovic 2020-01-06 14:08:58 UTC
(In reply to Aleksandar Rikalo from comment #17)
> Created attachment 124466 [details]
> Add nanoMIPS support to Valgrind 3/4

Committed
https://sourceware.org/git/gitweb.cgi?p=valgrind.git;a=commit;h=24c1f4ada32ce119dd4b1149c44c5c3d4b7f9b38
Comment 22 Petar Jovanovic 2020-01-06 14:09:47 UTC
(In reply to Aleksandar Rikalo from comment #18)
> Created attachment 124467 [details]
> Add nanoMIPS support to Valgrind 4/4

Committed
https://sourceware.org/git/gitweb.cgi?p=valgrind.git;a=commit;h=deae79f733a7c69f183f0e29a720e6c5bc3c1e7f
Comment 23 Petar Jovanovic 2020-01-06 14:10:33 UTC
(In reply to Aleksandar Rikalo from comment #19)
> Created attachment 124468 [details]
> Fix some tests so they can be compiled for nanoMIPS

Committed
https://sourceware.org/git/gitweb.cgi?p=valgrind.git;a=commit;h=192c1673c75737c9ea6b5af7cfdc7b0681759933
Comment 24 Petar Jovanovic 2020-01-06 14:11:28 UTC
(In reply to Aleksandar Rikalo from comment #20)
> Created attachment 124469 [details]
> Add tests for nanoMIPS instruction set

Committed
https://sourceware.org/git/gitweb.cgi?p=valgrind.git;a=commit;h=9acc066ffcf37ad04edfc801cc610ae64fa8d771
Comment 25 Petar Jovanovic 2020-01-06 14:14:01 UTC
Thank you for your contribution.
There will likely be more changes and finetuning for nanomips, but this set of changes gets majority of support in place.