Stream: git-wasmtime

Topic: wasmtime / issue #5920 Cranelift: call_indirect sends ran...


view this post on Zulip Wasmtime GitHub notifications bot (Mar 03 2023 at 13:36):

salmmanfred opened issue #5920:

Thanks for filing an issue! Please fill out the TODOs below.

.clif Test Case

use cranelift::codegen::ir::{UserFuncName, FuncRef};
use cranelift::frontend::{FunctionBuilder, FunctionBuilderContext};
use cranelift::codegen::{
    ir::{types::I64, AbiParam, Function, Signature},
    isa::CallConv,
};
use cranelift::prelude::{InstBuilder, types, ExtFuncData, MemFlags, EntityRef};

use cranelift::codegen::{isa, settings, Context};
use cranelift_jit::{JITModule, JITBuilder};
use target_lexicon::Triple;
use cranelift_module::{DataContext, Linkage, Module};
use core::fmt::write;

fn pr(t: i64,b:i64,c:i64,d:i64){

        println!("{t},{},{},{}",b,c,d);
    //println!("{:?}",*t);

}

pub fn test_compile(){

    let mut builder = settings::builder();
    let flags = settings::Flags::new(builder);

    let isa = match isa::lookup(Triple::host()) {
        Err(err) => panic!("Error looking up target: {}", err),
        Ok(isa_builder) => isa_builder.finish(flags).unwrap(),
    };



    let mut sig = Signature::new(CallConv::SystemV);
    sig.params.push(AbiParam::new(I64));


    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));


    let mut func = Function::with_name_signature(UserFuncName::default(), sig);
    let mut func_ctx = FunctionBuilderContext::new();
    let mut builder = FunctionBuilder::new(&mut func, &mut func_ctx);
    let pointer_type = isa.pointer_type();
    let block = builder.create_block();
    builder.seal_block(block);

    builder.append_block_params_for_function_params(block);
    builder.switch_to_block(block);


    let (write_sig, write_address) = {
        let mut write_sig = Signature::new(CallConv::SystemV);
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));


       // write_sig.returns.push(AbiParam::new(pointer_type));
        let write_sig = builder.import_signature(write_sig);

        let write_address = pr as *const () as i64;
        let write_address = builder.ins().iconst(pointer_type, write_address);
        (write_sig, write_address)
    };








    let arg = builder.block_params(block)[0];


    let plus_one = builder.ins().iadd_imm(arg, 1);
    let plus_two = builder.ins().iadd_imm(arg, 2);


    let plus_three = builder.ins().iadd(plus_one,plus_two);





    builder.ins().call_indirect(write_sig,write_address,&[plus_three,plus_three,plus_three,plus_three]);
   // builder.ins().store(mem_flags, cell_value, plus_three, 0);

    builder.ins().return_(&[plus_three,plus_three,plus_three]);

    builder.finalize();
    println!("{}", func.display());





    let mut ctx = Context::for_function(func);
    let code = ctx.compile(&*isa).unwrap();

    let mut buffer = memmap2::MmapOptions::new()
        .len(code.buffer.data().len())
        .map_anon()
        .unwrap();

    buffer.copy_from_slice(code.code_buffer());

    let buffer = buffer.make_exec().unwrap();

    let x = unsafe {
        let code_fn: unsafe extern "sysv64" fn(usize) -> usize =
            std::mem::transmute(buffer.as_ptr());

        code_fn(55)
    };

    println!("out: {}", x);


}

Expected Results

The pr should print out 113 4 times

Actual Results

The pr function prints out random values
when you have the pr set up to only have 3 I64s
the middle I64 is always correct
when there is 2 or less I64s there are no correct results

when you have 4 I64s there are 2 correct and 2 wrong results.
I have not tried added more I64 arguments

![bild](https://user-images.githubusercontent.com/32799244/222733355-ca869c9a-4e20-4752-99bf-53a4e14a2273.png)

Versions and Environment

Cranelift version or commit: 0.93.0

Operating system: Windows 10 19042.1288

Architecture: X86

Extra Info

Im quite new to cranelift but this just does not make sense im unsure if I messed something up when experimenting but to me this seems like a bug.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 03 2023 at 13:36):

salmmanfred labeled issue #5920:

Thanks for filing an issue! Please fill out the TODOs below.

.clif Test Case

use cranelift::codegen::ir::{UserFuncName, FuncRef};
use cranelift::frontend::{FunctionBuilder, FunctionBuilderContext};
use cranelift::codegen::{
    ir::{types::I64, AbiParam, Function, Signature},
    isa::CallConv,
};
use cranelift::prelude::{InstBuilder, types, ExtFuncData, MemFlags, EntityRef};

use cranelift::codegen::{isa, settings, Context};
use cranelift_jit::{JITModule, JITBuilder};
use target_lexicon::Triple;
use cranelift_module::{DataContext, Linkage, Module};
use core::fmt::write;

fn pr(t: i64,b:i64,c:i64,d:i64){

        println!("{t},{},{},{}",b,c,d);
    //println!("{:?}",*t);

}

pub fn test_compile(){

    let mut builder = settings::builder();
    let flags = settings::Flags::new(builder);

    let isa = match isa::lookup(Triple::host()) {
        Err(err) => panic!("Error looking up target: {}", err),
        Ok(isa_builder) => isa_builder.finish(flags).unwrap(),
    };



    let mut sig = Signature::new(CallConv::SystemV);
    sig.params.push(AbiParam::new(I64));


    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));


    let mut func = Function::with_name_signature(UserFuncName::default(), sig);
    let mut func_ctx = FunctionBuilderContext::new();
    let mut builder = FunctionBuilder::new(&mut func, &mut func_ctx);
    let pointer_type = isa.pointer_type();
    let block = builder.create_block();
    builder.seal_block(block);

    builder.append_block_params_for_function_params(block);
    builder.switch_to_block(block);


    let (write_sig, write_address) = {
        let mut write_sig = Signature::new(CallConv::SystemV);
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));


       // write_sig.returns.push(AbiParam::new(pointer_type));
        let write_sig = builder.import_signature(write_sig);

        let write_address = pr as *const () as i64;
        let write_address = builder.ins().iconst(pointer_type, write_address);
        (write_sig, write_address)
    };








    let arg = builder.block_params(block)[0];


    let plus_one = builder.ins().iadd_imm(arg, 1);
    let plus_two = builder.ins().iadd_imm(arg, 2);


    let plus_three = builder.ins().iadd(plus_one,plus_two);





    builder.ins().call_indirect(write_sig,write_address,&[plus_three,plus_three,plus_three,plus_three]);
   // builder.ins().store(mem_flags, cell_value, plus_three, 0);

    builder.ins().return_(&[plus_three,plus_three,plus_three]);

    builder.finalize();
    println!("{}", func.display());





    let mut ctx = Context::for_function(func);
    let code = ctx.compile(&*isa).unwrap();

    let mut buffer = memmap2::MmapOptions::new()
        .len(code.buffer.data().len())
        .map_anon()
        .unwrap();

    buffer.copy_from_slice(code.code_buffer());

    let buffer = buffer.make_exec().unwrap();

    let x = unsafe {
        let code_fn: unsafe extern "sysv64" fn(usize) -> usize =
            std::mem::transmute(buffer.as_ptr());

        code_fn(55)
    };

    println!("out: {}", x);


}

Expected Results

The pr should print out 113 4 times

Actual Results

The pr function prints out random values
when you have the pr set up to only have 3 I64s
the middle I64 is always correct
when there is 2 or less I64s there are no correct results

when you have 4 I64s there are 2 correct and 2 wrong results.
I have not tried added more I64 arguments

![bild](https://user-images.githubusercontent.com/32799244/222733355-ca869c9a-4e20-4752-99bf-53a4e14a2273.png)

Versions and Environment

Cranelift version or commit: 0.93.0

Operating system: Windows 10 19042.1288

Architecture: X86

Extra Info

Im quite new to cranelift but this just does not make sense im unsure if I messed something up when experimenting but to me this seems like a bug.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 03 2023 at 13:36):

salmmanfred labeled issue #5920:

Thanks for filing an issue! Please fill out the TODOs below.

.clif Test Case

use cranelift::codegen::ir::{UserFuncName, FuncRef};
use cranelift::frontend::{FunctionBuilder, FunctionBuilderContext};
use cranelift::codegen::{
    ir::{types::I64, AbiParam, Function, Signature},
    isa::CallConv,
};
use cranelift::prelude::{InstBuilder, types, ExtFuncData, MemFlags, EntityRef};

use cranelift::codegen::{isa, settings, Context};
use cranelift_jit::{JITModule, JITBuilder};
use target_lexicon::Triple;
use cranelift_module::{DataContext, Linkage, Module};
use core::fmt::write;

fn pr(t: i64,b:i64,c:i64,d:i64){

        println!("{t},{},{},{}",b,c,d);
    //println!("{:?}",*t);

}

pub fn test_compile(){

    let mut builder = settings::builder();
    let flags = settings::Flags::new(builder);

    let isa = match isa::lookup(Triple::host()) {
        Err(err) => panic!("Error looking up target: {}", err),
        Ok(isa_builder) => isa_builder.finish(flags).unwrap(),
    };



    let mut sig = Signature::new(CallConv::SystemV);
    sig.params.push(AbiParam::new(I64));


    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));


    let mut func = Function::with_name_signature(UserFuncName::default(), sig);
    let mut func_ctx = FunctionBuilderContext::new();
    let mut builder = FunctionBuilder::new(&mut func, &mut func_ctx);
    let pointer_type = isa.pointer_type();
    let block = builder.create_block();
    builder.seal_block(block);

    builder.append_block_params_for_function_params(block);
    builder.switch_to_block(block);


    let (write_sig, write_address) = {
        let mut write_sig = Signature::new(CallConv::SystemV);
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));


       // write_sig.returns.push(AbiParam::new(pointer_type));
        let write_sig = builder.import_signature(write_sig);

        let write_address = pr as *const () as i64;
        let write_address = builder.ins().iconst(pointer_type, write_address);
        (write_sig, write_address)
    };








    let arg = builder.block_params(block)[0];


    let plus_one = builder.ins().iadd_imm(arg, 1);
    let plus_two = builder.ins().iadd_imm(arg, 2);


    let plus_three = builder.ins().iadd(plus_one,plus_two);





    builder.ins().call_indirect(write_sig,write_address,&[plus_three,plus_three,plus_three,plus_three]);
   // builder.ins().store(mem_flags, cell_value, plus_three, 0);

    builder.ins().return_(&[plus_three,plus_three,plus_three]);

    builder.finalize();
    println!("{}", func.display());





    let mut ctx = Context::for_function(func);
    let code = ctx.compile(&*isa).unwrap();

    let mut buffer = memmap2::MmapOptions::new()
        .len(code.buffer.data().len())
        .map_anon()
        .unwrap();

    buffer.copy_from_slice(code.code_buffer());

    let buffer = buffer.make_exec().unwrap();

    let x = unsafe {
        let code_fn: unsafe extern "sysv64" fn(usize) -> usize =
            std::mem::transmute(buffer.as_ptr());

        code_fn(55)
    };

    println!("out: {}", x);


}

Expected Results

The pr should print out 113 4 times

Actual Results

The pr function prints out random values
when you have the pr set up to only have 3 I64s
the middle I64 is always correct
when there is 2 or less I64s there are no correct results

when you have 4 I64s there are 2 correct and 2 wrong results.
I have not tried added more I64 arguments

![bild](https://user-images.githubusercontent.com/32799244/222733355-ca869c9a-4e20-4752-99bf-53a4e14a2273.png)

Versions and Environment

Cranelift version or commit: 0.93.0

Operating system: Windows 10 19042.1288

Architecture: X86

Extra Info

Im quite new to cranelift but this just does not make sense im unsure if I messed something up when experimenting but to me this seems like a bug.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 03 2023 at 13:36):

salmmanfred edited issue #5920:

Thanks for filing an issue! Please fill out the TODOs below.

The Code

use cranelift::codegen::ir::{UserFuncName, FuncRef};
use cranelift::frontend::{FunctionBuilder, FunctionBuilderContext};
use cranelift::codegen::{
    ir::{types::I64, AbiParam, Function, Signature},
    isa::CallConv,
};
use cranelift::prelude::{InstBuilder, types, ExtFuncData, MemFlags, EntityRef};

use cranelift::codegen::{isa, settings, Context};
use cranelift_jit::{JITModule, JITBuilder};
use target_lexicon::Triple;
use cranelift_module::{DataContext, Linkage, Module};
use core::fmt::write;

fn pr(t: i64,b:i64,c:i64,d:i64){

        println!("{t},{},{},{}",b,c,d);
    //println!("{:?}",*t);

}

pub fn test_compile(){

    let mut builder = settings::builder();
    let flags = settings::Flags::new(builder);

    let isa = match isa::lookup(Triple::host()) {
        Err(err) => panic!("Error looking up target: {}", err),
        Ok(isa_builder) => isa_builder.finish(flags).unwrap(),
    };



    let mut sig = Signature::new(CallConv::SystemV);
    sig.params.push(AbiParam::new(I64));


    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));


    let mut func = Function::with_name_signature(UserFuncName::default(), sig);
    let mut func_ctx = FunctionBuilderContext::new();
    let mut builder = FunctionBuilder::new(&mut func, &mut func_ctx);
    let pointer_type = isa.pointer_type();
    let block = builder.create_block();
    builder.seal_block(block);

    builder.append_block_params_for_function_params(block);
    builder.switch_to_block(block);


    let (write_sig, write_address) = {
        let mut write_sig = Signature::new(CallConv::SystemV);
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));


       // write_sig.returns.push(AbiParam::new(pointer_type));
        let write_sig = builder.import_signature(write_sig);

        let write_address = pr as *const () as i64;
        let write_address = builder.ins().iconst(pointer_type, write_address);
        (write_sig, write_address)
    };








    let arg = builder.block_params(block)[0];


    let plus_one = builder.ins().iadd_imm(arg, 1);
    let plus_two = builder.ins().iadd_imm(arg, 2);


    let plus_three = builder.ins().iadd(plus_one,plus_two);





    builder.ins().call_indirect(write_sig,write_address,&[plus_three,plus_three,plus_three,plus_three]);
   // builder.ins().store(mem_flags, cell_value, plus_three, 0);

    builder.ins().return_(&[plus_three,plus_three,plus_three]);

    builder.finalize();
    println!("{}", func.display());





    let mut ctx = Context::for_function(func);
    let code = ctx.compile(&*isa).unwrap();

    let mut buffer = memmap2::MmapOptions::new()
        .len(code.buffer.data().len())
        .map_anon()
        .unwrap();

    buffer.copy_from_slice(code.code_buffer());

    let buffer = buffer.make_exec().unwrap();

    let x = unsafe {
        let code_fn: unsafe extern "sysv64" fn(usize) -> usize =
            std::mem::transmute(buffer.as_ptr());

        code_fn(55)
    };

    println!("out: {}", x);


}

Expected Results

The pr should print out 113 4 times

Actual Results

The pr function prints out random values
when you have the pr set up to only have 3 I64s
the middle I64 is always correct
when there is 2 or less I64s there are no correct results

when you have 4 I64s there are 2 correct and 2 wrong results.
I have not tried added more I64 arguments

![bild](https://user-images.githubusercontent.com/32799244/222733355-ca869c9a-4e20-4752-99bf-53a4e14a2273.png)

Versions and Environment

Cranelift version or commit: 0.93.0

Operating system: Windows 10 19042.1288

Architecture: X86

Extra Info

Im quite new to cranelift but this just does not make sense im unsure if I messed something up when experimenting but to me this seems like a bug.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 03 2023 at 13:37):

salmmanfred edited issue #5920:

The Code

use cranelift::codegen::ir::{UserFuncName, FuncRef};
use cranelift::frontend::{FunctionBuilder, FunctionBuilderContext};
use cranelift::codegen::{
    ir::{types::I64, AbiParam, Function, Signature},
    isa::CallConv,
};
use cranelift::prelude::{InstBuilder, types, ExtFuncData, MemFlags, EntityRef};

use cranelift::codegen::{isa, settings, Context};
use cranelift_jit::{JITModule, JITBuilder};
use target_lexicon::Triple;
use cranelift_module::{DataContext, Linkage, Module};
use core::fmt::write;

fn pr(t: i64,b:i64,c:i64,d:i64){

        println!("{t},{},{},{}",b,c,d);
    //println!("{:?}",*t);

}

pub fn test_compile(){

    let mut builder = settings::builder();
    let flags = settings::Flags::new(builder);

    let isa = match isa::lookup(Triple::host()) {
        Err(err) => panic!("Error looking up target: {}", err),
        Ok(isa_builder) => isa_builder.finish(flags).unwrap(),
    };



    let mut sig = Signature::new(CallConv::SystemV);
    sig.params.push(AbiParam::new(I64));


    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));


    let mut func = Function::with_name_signature(UserFuncName::default(), sig);
    let mut func_ctx = FunctionBuilderContext::new();
    let mut builder = FunctionBuilder::new(&mut func, &mut func_ctx);
    let pointer_type = isa.pointer_type();
    let block = builder.create_block();
    builder.seal_block(block);

    builder.append_block_params_for_function_params(block);
    builder.switch_to_block(block);


    let (write_sig, write_address) = {
        let mut write_sig = Signature::new(CallConv::SystemV);
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));


       // write_sig.returns.push(AbiParam::new(pointer_type));
        let write_sig = builder.import_signature(write_sig);

        let write_address = pr as *const () as i64;
        let write_address = builder.ins().iconst(pointer_type, write_address);
        (write_sig, write_address)
    };








    let arg = builder.block_params(block)[0];


    let plus_one = builder.ins().iadd_imm(arg, 1);
    let plus_two = builder.ins().iadd_imm(arg, 2);


    let plus_three = builder.ins().iadd(plus_one,plus_two);





    builder.ins().call_indirect(write_sig,write_address,&[plus_three,plus_three,plus_three,plus_three]);
   // builder.ins().store(mem_flags, cell_value, plus_three, 0);

    builder.ins().return_(&[plus_three,plus_three,plus_three]);

    builder.finalize();
    println!("{}", func.display());





    let mut ctx = Context::for_function(func);
    let code = ctx.compile(&*isa).unwrap();

    let mut buffer = memmap2::MmapOptions::new()
        .len(code.buffer.data().len())
        .map_anon()
        .unwrap();

    buffer.copy_from_slice(code.code_buffer());

    let buffer = buffer.make_exec().unwrap();

    let x = unsafe {
        let code_fn: unsafe extern "sysv64" fn(usize) -> usize =
            std::mem::transmute(buffer.as_ptr());

        code_fn(55)
    };

    println!("out: {}", x);


}

Expected Results

The pr should print out 113 4 times

Actual Results

The pr function prints out random values
when you have the pr set up to only have 3 I64s
the middle I64 is always correct
when there is 2 or less I64s there are no correct results

when you have 4 I64s there are 2 correct and 2 wrong results.
I have not tried added more I64 arguments

![bild](https://user-images.githubusercontent.com/32799244/222733355-ca869c9a-4e20-4752-99bf-53a4e14a2273.png)

Versions and Environment

Cranelift version or commit: 0.93.0

Operating system: Windows 10 19042.1288

Architecture: X86

Extra Info

Im quite new to cranelift but this just does not make sense im unsure if I messed something up when experimenting but to me this seems like a bug.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 03 2023 at 20:19):

bjorn3 commented on issue #5920:

pr needs to be extern "sysv" as that is what you use when calling it. By the way I would suggest using cranelift-jit instead of manually writing code to handle jitting.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 04 2023 at 12:00):

salmmanfred commented on issue #5920:

Currently only experimenting, but its working now with extern. Thanks!

view this post on Zulip Wasmtime GitHub notifications bot (Mar 04 2023 at 12:00):

salmmanfred closed issue #5920:

The Code

use cranelift::codegen::ir::{UserFuncName, FuncRef};
use cranelift::frontend::{FunctionBuilder, FunctionBuilderContext};
use cranelift::codegen::{
    ir::{types::I64, AbiParam, Function, Signature},
    isa::CallConv,
};
use cranelift::prelude::{InstBuilder, types, ExtFuncData, MemFlags, EntityRef};

use cranelift::codegen::{isa, settings, Context};
use cranelift_jit::{JITModule, JITBuilder};
use target_lexicon::Triple;
use cranelift_module::{DataContext, Linkage, Module};
use core::fmt::write;

fn pr(t: i64,b:i64,c:i64,d:i64){

        println!("{t},{},{},{}",b,c,d);
    //println!("{:?}",*t);

}

pub fn test_compile(){

    let mut builder = settings::builder();
    let flags = settings::Flags::new(builder);

    let isa = match isa::lookup(Triple::host()) {
        Err(err) => panic!("Error looking up target: {}", err),
        Ok(isa_builder) => isa_builder.finish(flags).unwrap(),
    };



    let mut sig = Signature::new(CallConv::SystemV);
    sig.params.push(AbiParam::new(I64));


    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));
    sig.returns.push(AbiParam::new(I64));


    let mut func = Function::with_name_signature(UserFuncName::default(), sig);
    let mut func_ctx = FunctionBuilderContext::new();
    let mut builder = FunctionBuilder::new(&mut func, &mut func_ctx);
    let pointer_type = isa.pointer_type();
    let block = builder.create_block();
    builder.seal_block(block);

    builder.append_block_params_for_function_params(block);
    builder.switch_to_block(block);


    let (write_sig, write_address) = {
        let mut write_sig = Signature::new(CallConv::SystemV);
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));
        write_sig.params.push(AbiParam::new(types::I64));


       // write_sig.returns.push(AbiParam::new(pointer_type));
        let write_sig = builder.import_signature(write_sig);

        let write_address = pr as *const () as i64;
        let write_address = builder.ins().iconst(pointer_type, write_address);
        (write_sig, write_address)
    };








    let arg = builder.block_params(block)[0];


    let plus_one = builder.ins().iadd_imm(arg, 1);
    let plus_two = builder.ins().iadd_imm(arg, 2);


    let plus_three = builder.ins().iadd(plus_one,plus_two);





    builder.ins().call_indirect(write_sig,write_address,&[plus_three,plus_three,plus_three,plus_three]);
   // builder.ins().store(mem_flags, cell_value, plus_three, 0);

    builder.ins().return_(&[plus_three,plus_three,plus_three]);

    builder.finalize();
    println!("{}", func.display());





    let mut ctx = Context::for_function(func);
    let code = ctx.compile(&*isa).unwrap();

    let mut buffer = memmap2::MmapOptions::new()
        .len(code.buffer.data().len())
        .map_anon()
        .unwrap();

    buffer.copy_from_slice(code.code_buffer());

    let buffer = buffer.make_exec().unwrap();

    let x = unsafe {
        let code_fn: unsafe extern "sysv64" fn(usize) -> usize =
            std::mem::transmute(buffer.as_ptr());

        code_fn(55)
    };

    println!("out: {}", x);


}

Expected Results

The pr should print out 113 4 times

Actual Results

The pr function prints out random values
when you have the pr set up to only have 3 I64s
the middle I64 is always correct
when there is 2 or less I64s there are no correct results

when you have 4 I64s there are 2 correct and 2 wrong results.
I have not tried added more I64 arguments

![bild](https://user-images.githubusercontent.com/32799244/222733355-ca869c9a-4e20-4752-99bf-53a4e14a2273.png)

Versions and Environment

Cranelift version or commit: 0.93.0

Operating system: Windows 10 19042.1288

Architecture: X86

Extra Info

Im quite new to cranelift but this just does not make sense im unsure if I messed something up when experimenting but to me this seems like a bug.


Last updated: Jan 24 2025 at 00:11 UTC