Increase buffer size when reading executable, update libstd
This commit is contained in:
parent
d329f7c7d2
commit
2b915953c9
|
@ -9,7 +9,7 @@ use syscall::{convert_to_result, Call, Error, Result};
|
||||||
|
|
||||||
use super::Scheme;
|
use super::Scheme;
|
||||||
|
|
||||||
#[derive(Copy, Clone, Debug)]
|
#[derive(Copy, Clone, Debug, Default)]
|
||||||
#[repr(packed)]
|
#[repr(packed)]
|
||||||
pub struct Packet {
|
pub struct Packet {
|
||||||
pub id: usize,
|
pub id: usize,
|
||||||
|
|
|
@ -178,6 +178,8 @@ pub fn clone(flags: usize, stack_base: usize) -> Result<usize> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If not cloning files, dup to get a new number from scheme
|
||||||
|
// This has to be done outside the context lock to prevent deadlocks
|
||||||
if flags & CLONE_FILES == 0 {
|
if flags & CLONE_FILES == 0 {
|
||||||
for (fd, mut file_option) in files.lock().iter_mut().enumerate() {
|
for (fd, mut file_option) in files.lock().iter_mut().enumerate() {
|
||||||
let new_file_option = if let Some(file) = *file_option {
|
let new_file_option = if let Some(file) = *file_option {
|
||||||
|
@ -357,7 +359,7 @@ pub fn exec(path: &[u8], arg_ptrs: &[[usize; 2]]) -> Result<usize> {
|
||||||
//TODO: Only read elf header, not entire file. Then read required segments
|
//TODO: Only read elf header, not entire file. Then read required segments
|
||||||
let mut data = vec![];
|
let mut data = vec![];
|
||||||
loop {
|
loop {
|
||||||
let mut buf = [0; 4096];
|
let mut buf = [0; 16384];
|
||||||
let count = syscall::read(file, &mut buf)?;
|
let count = syscall::read(file, &mut buf)?;
|
||||||
if count > 0 {
|
if count > 0 {
|
||||||
data.extend_from_slice(&buf[..count]);
|
data.extend_from_slice(&buf[..count]);
|
||||||
|
|
2
libstd
2
libstd
|
@ -1 +1 @@
|
||||||
Subproject commit 3d771c76c4cbd82ad699c59d3bfb645556d90f39
|
Subproject commit ae80aff4d39b2d3a83f7d32bc95739e4e1169184
|
Loading…
Reference in a new issue