dr264275
67ca5444f4
Bump to 0.28.0
...
Signed-off-by: dr264275 <dr264275@antgroup.com>
2022-07-17 17:12:14 +08:00
zhubojun
338dda643b
[libos] Add PKU support
2022-07-17 17:12:14 +08:00
Zheng, Qi
526b6e1753
Update QvE ISV SVN threshold value
2022-07-17 17:12:14 +08:00
LI Qing
a2991cc9c0
Add seek support for stdin and stdout
2022-07-15 23:48:27 +08:00
Hui, Chunyang
0b824d3a98
Fix panic when build process VM failed
2022-07-13 16:35:04 +08:00
LI Qing
1dc2b517fc
Fix the issue about fsync on hostfs's dir
...
There are no sync methods about untrusted dir, so we do nothing.
2022-07-13 13:42:51 +08:00
LI Qing
98dd3e8af3
Modify hostfs to support mode and some ops for dir
2022-07-06 15:54:15 +08:00
LI Qing
6dab561327
Disable DCAP in hyper mode
2022-06-23 10:25:16 +08:00
volcano0dr
fac632122e
Bump to 0.27.3
...
Signed-off-by: volcano0dr <volcano_dr@163.com>
2022-06-06 09:32:50 +08:00
ClawSeven
40ad9d1648
[libos] Fix error handling of sendfile
2022-06-01 12:13:10 -07:00
Hui, Chunyang
2cd20d315e
Refactor merge_all_single_vma_chunks to reduce iteration
2022-05-18 00:02:20 +08:00
Hui, Chunyang
849e35f01e
Remove redundant sort logic for add_range_back_to_free_manager
2022-05-18 00:02:20 +08:00
Hui, Chunyang
70dbf84782
Fix single-VMA chunk range conflict due to mremap locking order
2022-05-17 23:58:00 +08:00
LI Qing
626ea3dc7c
[libos] Add status_flags support for stdio
2022-05-16 15:29:26 +08:00
Hui, Chunyang
cd5d9e6d57
Refactor rwlock implementation
...
1. Improve readability
2. Ease the restriction on memory ordering for better performance
2022-05-11 14:57:17 +08:00
Hui, Chunyang
fd950132ce
Fix chunk manager munmap range
...
When the munmap range is bigger than the Multi-VMA chunk's range, the
bound was wrong and the munmap will misbehave.
2022-05-10 23:30:29 +08:00
zhubojun
ed96ce55dd
[libos] Add support for SHM
2022-04-28 20:05:50 +08:00
ClawSeven
c84c3b7b88
Refine hosts parser
2022-04-27 22:10:54 +08:00
volcano0dr
7a2c5a1f41
Bump to 0.27.2
...
Signed-off-by: volcano0dr <volcano_dr@163.com>
2022-04-25 15:02:41 +08:00
ClawSeven
036eb08193
Deep copy host file
2022-04-24 10:52:33 +08:00
zongmin.gu
f0ef954398
Bump to 0.27.1
2022-04-07 12:13:55 +08:00
ClawSeven
ffdd4d95a4
Add parser for hostname and hosts
2022-04-06 15:18:08 +08:00
ClawSeven
15932a54b6
Add hosts and hostname file
2022-04-06 15:18:08 +08:00
Hui, Chunyang
3e15eb059c
Add support for mmap spans over two chunks with MAP_FIXED
2022-03-30 17:38:37 +08:00
Shaowei Song
8872acaeda
[libos] Add ENOENT&ENAMETOOLONG checks for path name
2022-03-28 15:20:16 +08:00
Shaowei Song
5be86d0058
[ci] Do not disable overflow_checks for code coverage build
2022-03-28 15:20:16 +08:00
Shaowei Song
64bdd71a50
[libos] Return error instead of overflow panic in vm
2022-03-24 14:54:43 +08:00
zhubojun
4fab368127
[libos] Add support for UTIME
2022-03-22 17:59:00 +08:00
LI Qing
66d1ebe918
[hyper mode] Add compile support
2022-03-19 15:32:45 +08:00
LI Qing
f611e9c008
[hyper mode] Dismiss the valiadation of QE report
2022-03-19 15:32:45 +08:00
LI Qing
1d1cbb0abf
[hyper mode] Add UntrustedSlice
2022-03-19 15:32:45 +08:00
LI Qing
f52bf0b514
Add support for FLOCK
2022-03-09 16:00:23 +08:00
LI Qing
b44390b883
Refactor range_lock in fs
2022-03-09 16:00:23 +08:00
zongmin.gu
cba8689bf3
Bump to 0.27.0
2022-03-04 11:37:13 +08:00
Hui, Chunyang
e0b47b3a76
Refactor futex wait with timeout
2022-03-04 11:37:13 +08:00
LI Qing
126562a3f7
Fix the wrong SGX exception conversion
2022-02-22 19:27:15 +08:00
Hui, Chunyang
ffaccedf95
Add support for clock_nanosleep
...
Also replace nanosleep implementation with clock_nanosleep
2022-02-22 16:05:36 +08:00
Hui, Chunyang
63db3e340c
Fix futex wait timeout with absolute time
2022-02-22 16:05:36 +08:00
zongmin.gu
e0cf6bd0a6
Bump to 0.26.4
2022-02-11 11:10:02 +08:00
Hui, Chunyang
5d38c8e553
Fix vfork child process not close opened files
2022-01-24 14:09:36 +08:00
LI Qing
b40408cb91
[libos] Change ROOT_INODE to ROOT_FS
...
Filesystem should be the owner of its root inode
2022-01-17 11:52:16 +08:00
xiaoli.zhang
6353817af8
Fix incompatible timespec convertion
2022-01-12 18:42:03 +08:00
Hui, Chunyang
1229de1fd1
Fix panic if user input invalid memory arguments
2021-12-30 15:19:36 +08:00
zongmin.gu
9d55882cd5
Bump to 0.26.3
2021-12-29 16:29:35 +08:00
Hui, Chunyang
f65bbdd924
Fix TCGETS/TCSETS using wrong termios type definition
2021-12-24 16:57:27 +08:00
Zheng, Qi
8efde3915c
Do not panic but return error for failed dcap ioctl
2021-12-22 08:08:49 +08:00
Hui, Chunyang
8aed759161
Clean clear_ctid when thread exits
2021-12-16 17:37:00 +08:00
zongmin.gu
765d019bbf
Bump to version 0.26.2
2021-12-14 10:58:09 +08:00
zongmin.gu
101256bf1e
Update Rust SGX SDK to enable rust-toolchain nightly-2021-11-01
2021-12-14 10:58:09 +08:00
zongmin.gu
6cff4bc30c
Bump to 0.26.1
2021-12-06 19:19:53 +08:00
zongmin.gu
e8f262808b
Fix Occlum building warnings
2021-12-06 19:19:53 +08:00
zongmin.gu
8fbb9b4796
Update SGX SDK 2.15.1
2021-12-06 19:19:53 +08:00
zongmin.gu
a428ea3409
Bump to 0.26.0
2021-11-29 18:42:15 +08:00
LI Qing
7bc2c336b6
Add mount and umount syscall
2021-11-29 15:11:37 +08:00
zongmin.gu
36918e42bf
Check the buffer address before copy the data from the buffer
...
This commit fixed an Occlum security issue. The researchers from KU
Leuven (Belgium) and the University of Birmingham (UK) found it and
reported it to Occlum team. Thank you, Jo Van Bulck, Frank Piessens,
Fritz Alder, David Oswald, Jesse Spielman and Sam Thomas.
2021-11-29 14:14:54 +08:00
LI Qing
fc7ba98ded
Add ppoll
2021-11-24 16:52:25 +08:00
LI Qing
b61188889d
Update mountfs
2021-11-24 10:50:45 +08:00
zongmin.gu
a01b35ff5e
Bump version to 0.25.0
2021-11-08 19:15:00 +08:00
Hui, Chunyang
56569e2b8e
Fix running user application with too many arguments
...
Also fix the VM drop process when creating process failure
2021-11-08 11:30:36 +08:00
Hui, Chunyang
fa69b3d0d1
Try reduce vma count on host to prevent panic because of too much mprotect
2021-11-08 11:29:42 +08:00
Hui, Chunyang
d9845235d3
Fix the error code and return logic for mmap failure
2021-10-26 17:51:52 +08:00
LI Qing
9f763f84b1
Add the check of pathname in rename syscall
2021-10-22 18:01:25 +08:00
Zheng, Qi
1eb58a5eb3
Add new_fd range check for dup2/dup3
...
Signed-off-by: Zheng, Qi <huaiqing.zq@antgroup.com>
2021-10-22 17:50:48 +08:00
Zheng, Qi
3c9e172550
Add RLIMIT_RTTIME to make it compatibale with latest Linux kernel
...
Signed-off-by: Zheng, Qi <huaiqing.zq@antgroup.com>
2021-10-22 17:50:48 +08:00
Zheng, Qi
a16ba58b31
Set default RLIMIT_NOFILE to 1024
...
Signed-off-by: Zheng, Qi <huaiqing.zq@antgroup.com>
2021-10-22 17:50:48 +08:00
zongmin.gu
59986df1a5
Bump version to 0.24.2
2021-10-22 17:16:52 +08:00
Hui, Chunyang
1745825e81
Add support for mprotect PROT_GROWSDOWN
2021-10-18 19:49:28 +08:00
Zheng, Qi
0eb3353b7c
Return current break if brk failed
...
Signed-off-by: Zheng, Qi <huaiqing.zq@antgroup.com>
2021-10-18 14:10:19 +08:00
LI Qing
030b1c7fdf
Fix the memory leak in procfs
2021-10-18 13:43:02 +08:00
Hui, Chunyang
bdb7825607
Add support for mremap
2021-10-17 15:58:29 +08:00
Hui, Chunyang
6dd73c64b5
Improve userspace VM management
...
Occlum is a single-address-space library OS. Previously, userspace memory are divided for each process.
And all the memory are allocated when the process is created, which leads to a lot of wasted space and
complicated configuration.
In the current implementation, the whole userspace is managed as a memory pool that consists of chunks. There
are two kinds of chunks:
(1) Single VMA chunk: a chunk with only one VMA. Should be owned by exactly one process.
(2) Multi VMA chunk: a chunk with default chunk size and there could be a lot of VMAs in this chunk. Can be used
by different processes.
This design can help to achieve mainly two goals:
(1) Simplify the configuration: Users don't need to configure the process.default_mmap_size anymore. And multiple processes
running in the same Occlum instance can use dramatically different sizes of memory.
(2) Gain better performance: Two-level management(chunks & VMAs) reduces the time for finding, inserting, deleting, and iterating.
2021-10-17 15:58:29 +08:00
zongmin.gu
c6d474bb7b
Bump version to 0.24.1
2021-10-01 08:29:25 +08:00
LI Qing
a8cd5eadba
Fix the type conversion in statfs with TryFrom trait
2021-09-22 15:11:48 +08:00
LI Qing
c9083c787c
Fix the return error code of file operations
2021-09-22 15:10:59 +08:00
zongmin.gu
85f9333fbe
Bump version to 0.24.0
2021-09-15 14:49:25 +08:00
LI Qing
8f4fbba220
Add file POSIX advisory range lock
2021-09-15 11:15:42 +08:00
LI Qing
d24f89fd9c
Add getrandom syscall
2021-09-06 19:20:51 +08:00
LI Qing
85d6977118
Modify the statfs on SEFS or UnionFS with ocall
2021-09-05 16:00:00 +08:00
LI Qing
29eed82a7e
Add support for the mode of fallocate
2021-09-01 19:24:22 +08:00
Hui, Chunyang
99688183f0
Add vfork support
2021-08-24 11:24:03 +08:00
Hui, Chunyang
88f04c8df9
Add process group implementation and support set/getpgid, set/getpgrp
2021-08-20 08:34:44 +08:00
zongmin.gu
35229d495e
Bump to 0.23.7
2021-08-11 16:13:26 +08:00
LI Qing
87c1c9a8b3
Add support for umask
2021-08-09 16:50:53 +08:00
zongmin.gu
7c170807bc
Bump to 0.23.6
2021-08-06 12:58:56 +08:00
LI Qing
b390ecaae9
Add creat syscall
2021-08-06 10:40:44 +08:00
LI Qing
c5c18ccd6d
Fix the event_monitor when updating host file events
...
When no events happen, the state of host file events will not be reset,
so the event_monitor should always update the state after polling files.
2021-08-06 10:29:25 +08:00
Hui, Chunyang
80a27bc0f9
Reap zombie children when exit
...
This can fix memory leakage when parent not wait4 children.
2021-08-05 17:52:45 +08:00
LI Qing
865e38258b
Add support for '/proc/[pid]/stat'
...
Many field values are displayed as 0
2021-08-05 16:10:54 +08:00
LI Qing
28c0d55c88
Re-organize the structure of procfs
2021-08-05 16:10:54 +08:00
Hui, Chunyang
b2b86b796a
Add support for /dev/fd
2021-08-03 21:30:15 +08:00
LI Qing
dc37995bf0
Add getdents support for procfs's inode
2021-08-03 20:40:07 +08:00
LI Qing
215e8ffbdf
Add support for robust futex syscalls
2021-07-30 10:25:24 +08:00
zongmin.gu
22af91b9e7
Bump version to 0.23.5
2021-07-29 14:09:36 +08:00
zongmin.gu
1e03b34a3f
Update Cargo lock file to align resolv-conf change
2021-07-29 14:09:36 +08:00
ClawSeven
d35d98d551
Add resolv-conf parser
2021-07-28 10:52:46 +08:00
Hui, Chunyang
1acfec6b12
Add support for fchdir and support cd for fish
2021-07-28 09:11:19 +08:00
LI Qing
a54de67431
Fix the wrong value returned from getcwd
...
`getcwd` should return the length of buffer filled
2021-07-27 13:05:35 +08:00
Hui, Chunyang
123369d6ce
Fix panic for empty file actions
2021-07-26 19:41:54 +08:00
Hui, Chunyang
5963b70b97
Don't allocate extra memory if already aligned
2021-07-23 13:52:31 +08:00
Hui, Chunyang
3612442adc
Fix an error when calculating elf memory usage
...
VMLayout was mistakenly used to calculate the memory usage. This
commit is to fix this and seperate VMLayout "add" and "extend"
methods.
2021-07-23 13:52:31 +08:00
Hui, Chunyang
f9bafa23a4
Fix uninitialized elf memory for loadable segment
2021-07-23 13:52:31 +08:00
Hui, Chunyang
7d54706a8e
Add signal check before sigtimedwait return with timeout
2021-07-22 20:24:35 +08:00
zongmin.gu
6adf171bf7
Bump version to 0.23.4
2021-07-21 21:19:31 +08:00
LI Qing
17e4810d3e
Add support for "/proc/[pid]/comm" and fix "/proc/[pid]/cmdline"
2021-07-20 19:56:12 +08:00
Hui, Chunyang
e0811a53d2
Bump version to 0.23.3
2021-07-19 19:08:01 +08:00
Shuocheng Wang
3e7fc94ca7
Fix the return value of sched_getaffinity.
2021-07-19 13:23:44 +08:00
ClawSeven
eb07b01ac0
Support timerfd-related syscall
2021-07-16 14:36:27 +08:00
Hui, Chunyang
1e7d258989
Bump version to 0.23.2
2021-07-15 10:03:59 +08:00
LI Qing
1e24dcea6a
Modify the protect-integrity tool to print result on file
2021-06-28 21:11:41 +08:00
Hui, Chunyang
6ff50da5be
Bump version to 0.23.1
2021-06-25 21:12:42 +08:00
zongmin.gu
f961b786da
Bump Occlum version to 0.23.0
2021-06-11 07:41:12 +08:00
Hui, Chunyang
c62b6d4091
Add support for execve
...
RFC: https://github.com/occlum/occlum/issues/429
2021-06-10 20:59:06 +08:00
Hui, Chunyang
bad2581a25
Add dummy implementation of getsockopt for unix domain socket
2021-06-10 20:50:30 +08:00
Hui, Chunyang
0dc85f8229
Add support for indexing unix domain socket file with inode
2021-06-10 20:50:30 +08:00
zongmin.gu
2cedafeacb
Add getgroups syscall
2021-06-10 20:14:37 +08:00
Hui, Chunyang
883f7b259f
Add support for ioctl FIONREAD, FIOCLEX, FIONCLEX for pipe and uds file
2021-06-07 08:28:51 +08:00
zongmin.gu
3756f0658c
Update rust-toolchain to nightly-2020-10-25
2021-06-04 11:59:11 +08:00
LI Qing
eb046d4241
Add O_TRUNC support in open syscall and rewrite the truncate test
2021-06-04 11:47:38 +08:00
LI Qing
001df6f309
Rewrite getdents syscall
2021-06-04 11:37:19 +08:00
LI Qing
789b57c6f7
Add statfs and fstatfs syscall
2021-06-04 11:36:47 +08:00
zongmin.gu
070bdf6f39
Add sendmmsg syscall
2021-06-03 16:24:34 +08:00
Hui, Chunyang
d15a75fafb
Add support for POSIX_SPAWN_SETSIGMASK and POSIX_SPAWN_SETSIGDEF
2021-06-01 20:34:51 +08:00
LI Qing
69c79d8252
Fix a potential deadlock when dereference procfs's symlink
2021-06-01 18:40:41 +08:00
LI Qing
9a76ca1888
Add support for '/proc/[pid]/root'
2021-05-25 12:04:50 +08:00
Hui, Chunyang
6d37dd2d90
Add support for mremap with file-backed memory
2021-05-23 15:14:06 +08:00
Hui, Chunyang
a95e26df42
Add support for WNOHANG of waitpid option
2021-05-10 10:11:24 +08:00
LI Qing
ba720dc346
Add fstat support for pipe
2021-05-08 11:25:08 +08:00
Hui, Chunyang
f77e2c5e89
Add support for ioctl TCGETS/TCSETS
2021-04-29 14:23:01 +08:00
zongmin.gu
47349c8d1b
Bump the Occlum version to 0.22.0
2021-04-16 09:34:26 +08:00
Hui, Chunyang
df73dd5d7b
Remove CLONE_PARENT_SETTID from clone mandatory flags
2021-04-13 20:22:02 +08:00
Hui, Chunyang
a9574ca22e
Fix ELF not running when load address not start from zero
2021-04-08 19:04:50 +08:00
Hui, Chunyang
09bac3d4b5
Fix panic for non-specified exec file path
...
This commit can prevent panic when user input:
occlum run /bin
2021-04-08 11:16:55 +08:00
LI Qing
8db6a55696
Mount ramfs at '/dev/shm'
2021-04-01 14:16:07 +08:00
LI Qing
64a980f529
Add time syscall and default localtime support
2021-03-26 16:56:57 +08:00
Hui, Chunyang
ef7b663c4d
Export error message when parsing Elf header
2021-03-22 18:53:22 +08:00
LI Qing
d1edb0e218
Release the check for maximum leaf in cpuid exception
2021-03-16 14:24:01 +08:00
zongmin.gu
17fcaf85e1
Bump version to 0.21.0
2021-03-03 16:07:51 +08:00
LI Qing
be62e2c65d
Add posix_fallocate
2021-03-03 11:06:09 +08:00
LI Qing
3dbf050904
Add sync_all, sync_data and poll for hostfs file
2021-03-02 13:47:02 +08:00
zongmin.gu
7122529b6b
Fix affinity array size incorrect issue
2021-03-02 13:45:07 +08:00
LI Qing
7deeccb03b
Fix the error of demos with encrypted fs image
2021-03-02 13:25:36 +08:00
LI Qing
c3a02ffc28
Add support for the encrypted fs image
2021-03-01 16:45:01 +08:00
Hui, Chunyang
a2959c17df
Reduce redundant mprotect ocall
2021-02-24 14:46:41 +08:00
Hui, Chunyang
79b264a6c8
Add support for Address Space Layout Randomization
...
ASLR is only enabled on release mode. Also manage the whole process
VM with VMManager.
2021-02-24 14:46:41 +08:00
LI Qing
d7b994bc7d
Fix getdents cannot output all entries in a directory
2021-02-24 13:24:54 +08:00
Hui, Chunyang
c4c3315c06
Fix false alarm on non-page-aligned size for mprotect
2021-02-23 20:59:17 +08:00
Hui, Chunyang
1fab79681b
Use goblin as elf parser and only load segments on demand
...
Libos now Only read in headers and needed segments. Also reduce a memory
copy.
2021-02-04 15:02:28 +08:00
zongmin.gu
fdde009e5d
Bump Occlum version to 0.20.0
2021-01-22 17:36:53 +08:00
He Sun
1788f94bfe
Fix the poll of channel according to gvisor pipe poll test
2021-01-22 13:22:02 +08:00
He Sun
2ea7fc1ad6
Add Unix socket support for poll
...
A relay notifier that observes the underlying endpoint is added as the
notifier for the socket. It broadcasts to its observers when either end
of the channel has IoEvents.
2021-01-21 23:45:36 +08:00