Skip to content

Commit 7f28835

Browse files
committed
Implement read_buf and vectored read/write for SGX stdio
1 parent ac91805 commit 7f28835

File tree

4 files changed

+66
-4
lines changed

4 files changed

+66
-4
lines changed

library/std/src/sys/pal/sgx/abi/usercalls/alloc.rs

+17-1
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ use super::super::mem::{is_enclave_range, is_user_range};
66
use crate::arch::asm;
77
use crate::cell::UnsafeCell;
88
use crate::convert::TryInto;
9-
use crate::mem::{self, ManuallyDrop};
9+
use crate::mem::{self, ManuallyDrop, MaybeUninit};
1010
use crate::ops::{CoerceUnsized, Deref, DerefMut, Index, IndexMut};
1111
use crate::pin::PinCoerceUnsized;
1212
use crate::ptr::{self, NonNull};
@@ -658,6 +658,22 @@ where
658658
self.copy_to_enclave(&mut dest[..]);
659659
}
660660

661+
/// Copies the value from user memory and place it into `dest`.
662+
///
663+
/// # Panics
664+
/// This function panics if the destination doesn't have the same length as
665+
/// the source.
666+
pub fn copy_to_enclave_uninit(&self, dest: &mut [MaybeUninit<T>]) {
667+
unsafe {
668+
assert_eq!(self.len(), dest.len());
669+
copy_from_userspace(
670+
self.0.get() as *const [T] as *const u8,
671+
dest.as_mut_ptr() as *mut u8,
672+
mem::size_of_val(dest),
673+
);
674+
}
675+
}
676+
661677
/// Copies the value from user memory into a vector in enclave memory.
662678
pub fn to_enclave(&self) -> Vec<T> {
663679
let mut ret = Vec::with_capacity(self.len());

library/std/src/sys/pal/sgx/abi/usercalls/mod.rs

+16-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
use crate::cmp;
2-
use crate::io::{Error as IoError, ErrorKind, IoSlice, IoSliceMut, Result as IoResult};
2+
use crate::io::{
3+
BorrowedCursor, Error as IoError, ErrorKind, IoSlice, IoSliceMut, Result as IoResult,
4+
};
35
use crate::random::{DefaultRandomSource, Random};
46
use crate::time::{Duration, Instant};
57

@@ -36,6 +38,19 @@ pub fn read(fd: Fd, bufs: &mut [IoSliceMut<'_>]) -> IoResult<usize> {
3638
}
3739
}
3840

41+
/// Usercall `read` with an uninitialized buffer. See the ABI documentation for
42+
/// more information.
43+
#[unstable(feature = "sgx_platform", issue = "56975")]
44+
pub fn read_buf(fd: Fd, mut buf: BorrowedCursor<'_>) -> IoResult<()> {
45+
unsafe {
46+
let mut userbuf = alloc::User::<[u8]>::uninitialized(buf.capacity());
47+
let len = raw::read(fd, userbuf.as_mut_ptr().cast(), userbuf.len()).from_sgx_result()?;
48+
userbuf[..len].copy_to_enclave_uninit(&mut buf.as_mut()[..len]);
49+
buf.advance_unchecked(len);
50+
Ok(())
51+
}
52+
}
53+
3954
/// Usercall `read_alloc`. See the ABI documentation for more information.
4055
#[unstable(feature = "sgx_platform", issue = "56975")]
4156
pub fn read_alloc(fd: Fd) -> IoResult<Vec<u8>> {

library/std/src/sys/pal/sgx/fd.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,7 @@ impl FileDesc {
2929
}
3030

3131
pub fn read_buf(&self, buf: BorrowedCursor<'_>) -> io::Result<()> {
32-
crate::io::default_read_buf(|b| self.read(b), buf)
32+
usercalls::read_buf(self.fd, buf)
3333
}
3434

3535
pub fn read_vectored(&self, bufs: &mut [IoSliceMut<'_>]) -> io::Result<usize> {

library/std/src/sys/pal/sgx/stdio.rs

+32-1
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
use fortanix_sgx_abi as abi;
22

3-
use crate::io;
3+
use crate::io::{self, BorrowedCursor, IoSlice, IoSliceMut};
44
#[cfg(not(test))]
55
use crate::slice;
66
#[cfg(not(test))]
@@ -28,6 +28,19 @@ impl io::Read for Stdin {
2828
fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
2929
with_std_fd(abi::FD_STDIN, |fd| fd.read(buf))
3030
}
31+
32+
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> io::Result<()> {
33+
with_std_fd(abi::FD_STDIN, |fd| fd.read_buf(buf))
34+
}
35+
36+
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> io::Result<usize> {
37+
with_std_fd(abi::FD_STDIN, |fd| fd.read_vectored(bufs))
38+
}
39+
40+
#[inline]
41+
fn is_read_vectored(&self) -> bool {
42+
true
43+
}
3144
}
3245

3346
impl Stdout {
@@ -44,6 +57,15 @@ impl io::Write for Stdout {
4457
fn flush(&mut self) -> io::Result<()> {
4558
with_std_fd(abi::FD_STDOUT, |fd| fd.flush())
4659
}
60+
61+
fn write_vectored(&mut self, bufs: &[IoSlice<'_>]) -> io::Result<usize> {
62+
with_std_fd(abi::FD_STDOUT, |fd| fd.write_vectored(bufs))
63+
}
64+
65+
#[inline]
66+
fn is_write_vectored(&self) -> bool {
67+
true
68+
}
4769
}
4870

4971
impl Stderr {
@@ -60,6 +82,15 @@ impl io::Write for Stderr {
6082
fn flush(&mut self) -> io::Result<()> {
6183
with_std_fd(abi::FD_STDERR, |fd| fd.flush())
6284
}
85+
86+
fn write_vectored(&mut self, bufs: &[IoSlice<'_>]) -> io::Result<usize> {
87+
with_std_fd(abi::FD_STDERR, |fd| fd.write_vectored(bufs))
88+
}
89+
90+
#[inline]
91+
fn is_write_vectored(&self) -> bool {
92+
true
93+
}
6394
}
6495

6596
pub const STDIN_BUF_SIZE: usize = crate::sys::io::DEFAULT_BUF_SIZE;

0 commit comments

Comments
 (0)