about summary refs log tree commit diff
diff options
context:
space:
mode:
authorAlessandro Decina <alessandro.d@gmail.com>2021-05-29 22:18:30 +1000
committerAlessandro Decina <alessandro.d@gmail.com>2021-05-29 22:23:32 +1000
commitbd8e5ce4b9353ad68b2180bf9f26e2d4cfcaf0af (patch)
treea66093d320d62ae9f02fad96f0cf01d088c5de42
parent9cf2170a79c73f32e1442120242729dc3af992f0 (diff)
downloadrust-bd8e5ce4b9353ad68b2180bf9f26e2d4cfcaf0af.tar.gz
rust-bd8e5ce4b9353ad68b2180bf9f26e2d4cfcaf0af.zip
BPF: abi: extend args/ret to 32 bits
Let LLVM extend to 64 bits when alu32 is not enabled
-rw-r--r--compiler/rustc_target/src/abi/call/bpf.rs6
1 files changed, 3 insertions, 3 deletions
diff --git a/compiler/rustc_target/src/abi/call/bpf.rs b/compiler/rustc_target/src/abi/call/bpf.rs
index 79af0150e21..466c525531c 100644
--- a/compiler/rustc_target/src/abi/call/bpf.rs
+++ b/compiler/rustc_target/src/abi/call/bpf.rs
@@ -1,11 +1,11 @@
-// see BPFCallingConv.td
+// see https://github.com/llvm/llvm-project/blob/main/llvm/lib/Target/BPF/BPFCallingConv.td
 use crate::abi::call::{ArgAbi, FnAbi};
 
 fn classify_ret<Ty>(ret: &mut ArgAbi<'_, Ty>) {
     if ret.layout.is_aggregate() || ret.layout.size.bits() > 64 {
         ret.make_indirect();
     } else {
-        ret.extend_integer_width_to(64);
+        ret.extend_integer_width_to(32);
     }
 }
 
@@ -13,7 +13,7 @@ fn classify_arg<Ty>(arg: &mut ArgAbi<'_, Ty>) {
     if arg.layout.is_aggregate() || arg.layout.size.bits() > 64 {
         arg.make_indirect();
     } else {
-        arg.extend_integer_width_to(64);
+        arg.extend_integer_width_to(32);
     }
 }