4 impl<'mir, 'tcx> EvalContextExt<'mir, 'tcx> for crate::MiriEvalContext<'mir, 'tcx> {}
5 pub trait EvalContextExt<'mir, 'tcx: 'mir>: crate::MiriEvalContextExt<'mir, 'tcx> {
6 fn emulate_foreign_item_by_name(
9 args: &[OpTy<'tcx, Tag>],
10 dest: PlaceTy<'tcx, Tag>,
11 _ret: mir::BasicBlock,
12 ) -> InterpResult<'tcx, bool> {
13 let this = self.eval_context_mut();
17 let errno_place = this.machine.last_error.unwrap();
18 this.write_scalar(errno_place.to_ref().to_scalar()?, dest)?;
23 // The only reason this is not in the `posix` module is because the `linux` item has a
26 let result = this.close(args[0])?;
27 this.write_scalar(Scalar::from_int(result, dest.layout.size), dest)?;
31 let result = this.macos_stat(args[0], args[1])?;
32 this.write_scalar(Scalar::from_int(result, dest.layout.size), dest)?;
36 let result = this.macos_lstat(args[0], args[1])?;
37 this.write_scalar(Scalar::from_int(result, dest.layout.size), dest)?;
41 let result = this.macos_fstat(args[0], args[1])?;
42 this.write_scalar(Scalar::from_int(result, dest.layout.size), dest)?;
44 // Environment related shims
46 this.write_scalar(this.memory.extra.environ.unwrap().ptr, dest)?;
48 // The only reason this is not in the `posix` module is because the `linux` item has a
50 "opendir$INODE64" => {
51 let result = this.opendir(args[0])?;
52 this.write_scalar(result, dest)?;
55 // The `linux` module has a parallel foreign item, `readdir64_r`, which uses a
56 // different struct layout.
57 "readdir_r$INODE64" => {
58 let result = this.macos_readdir_r(args[0], args[1], args[2])?;
59 this.write_scalar(Scalar::from_int(result, dest.layout.size), dest)?;
64 let result = this.gettimeofday(args[0], args[1])?;
65 this.write_scalar(Scalar::from_int(result, dest.layout.size), dest)?;
69 "pthread_attr_get_np" => {
70 this.write_null(dest)?;
73 "pthread_get_stackaddr_np" => {
74 let stack_addr = Scalar::from_uint(STACK_ADDR, dest.layout.size);
75 this.write_scalar(stack_addr, dest)?;
78 "pthread_get_stacksize_np" => {
79 let stack_size = Scalar::from_uint(STACK_SIZE, dest.layout.size);
80 this.write_scalar(stack_size, dest)?;
84 // FIXME: register the destructor.
88 this.write_scalar(this.machine.argc.expect("machine must be initialized"), dest)?;
92 this.write_scalar(this.machine.argv.expect("machine must be initialized"), dest)?;
95 "SecRandomCopyBytes" => {
96 let len = this.read_scalar(args[1])?.to_machine_usize(this)?;
97 let ptr = this.read_scalar(args[2])?.not_undef()?;
98 this.gen_random(ptr, len as usize)?;
99 this.write_null(dest)?;
102 _ => throw_unsup_format!("can't call foreign function: {}", link_name),