commit | b7f3fe4c3a2330a65a2fdae820aef29e6155c8ad | [log] [tgz] |
---|---|---|
author | yingopq <115543042+yingopq@users.noreply.github.com> | Sat Feb 24 15:13:43 2024 +0800 |
committer | Copybara-Service <copybara-worker@google.com> | Fri Feb 23 23:19:46 2024 -0800 |
tree | c83a63a5e63f7568cc9ac6916cbe6f942f01a7f8 | |
parent | e3bd07d10234cb757755c3786cb4595cc4aba941 [diff] |
[Mips] Fix unable to handle inline assembly ends with compat-branch o… (#77291) …n MIPS Modify: Add a global variable 'CurForbiddenSlotAttr' to save current instruction's forbidden slot and whether set reorder. This is the judgment condition for whether to add nop. We would add a couple of '.set noreorder' and '.set reorder' to wrap the current instruction and the next instruction. Then we can get previous instruction`s forbidden slot attribute and whether set reorder by 'CurForbiddenSlotAttr'. If previous instruction has forbidden slot and .set reorder is active and current instruction is CTI. Then emit a NOP after it. Fix https://github.com/llvm/llvm-project/issues/61045. Because https://reviews.llvm.org/D158589 was 'Needs Review' state, not ending, so we commit pull request again. GitOrigin-RevId: 96abee5eef31274415681018553e1d4a16dc16c9
This directory and its subdirectories contain source code for the LLVM Linker, a modular cross platform linker which is built as part of the LLVM compiler infrastructure project.
lld is open source software. You may freely distribute it under the terms of the license agreement found in LICENSE.txt.
In order to make sure various developers can evaluate patches over the same tests, we create a collection of self contained programs.
It is hosted at https://s3-us-west-2.amazonaws.com/linker-tests/lld-speed-test.tar.xz
The current sha256 is 10eec685463d5a8bbf08d77f4ca96282161d396c65bd97dc99dbde644a31610f
.