Comments (7)
I guess you're referring to:
However, some 32-bit and 16-bit platforms may successfully serve a request for more than isize::MAX bytes with things like Physical Address Extension. As such, memory acquired directly from allocators or memory mapped files may be too large to handle with this function.
An assertions would be too sporadic. I guess we should simply return an error and update the docs.
from memmap2-rs.
I cannot find how std::fs::read
handles this. It should have the exact issue.
from memmap2-rs.
@adamreichold Hi! Can you comment on this one? It fills like half of the bugs we had are 32-bit related. But disabling its support completely would be too much.
from memmap2-rs.
I cannot find how
std::fs::read
handles this. It should have the exact issue.
Following the call chain, std::fs::read()
- calls
<File as Read>::read_to_end()
, - which calls
Vec::<u8>::reserve()
, - which calls
RawVec::<u8>::reserve()
, - which calls
RawVec::reserve::do_reserve_and_handle::<u8, Global>()
, - which calls
RawVec::<u8>::grow_amortized()
, - which calls
alloc::raw_vec::finish_grow::<Global>()
, - which calls
alloc::raw_vec::alloc_guard()
, - which checks the size in bytes against
isize::MAX as usize
.
Even if it fails to get the file size, it
- calls
std::io::default_read_to_end()
, - which repeatedly calls
Vec::<u8>::extend_from_slice()
, - which calls
<Vec<u8> as SpecExtend<&u8, slice::Iter<'_, u8>>::spec_extend()
, - which calls
Vec::<u8>::append_elements()
, - which calls
Vec::<u8>::reserve()
, - which checks the size as before.
from memmap2-rs.
Nice find! I guess I will borrow this function.
from memmap2-rs.
@adamreichold Hi! Can you comment on this one? It fills like half of the bugs we had are 32-bit related. But disabling its support completely would be too much.
I think it is a straight-forward error on our side. We do have the necessary check for file-based mappings in MmapOptions::get_len
, but not in MmapOptions::len
.
from memmap2-rs.
I think our check in get_len
was actually too lenient as well. I still think this is a straight-forward bug though, as exposing mmap (2)
, we are in the memory allocator business need to take the same care as other implementors of such functionality. 😓
from memmap2-rs.
Related Issues (20)
- Migrate to `safer_owning_ref` HOT 1
- why does memmap2::Mmap::map need to be unsafe? HOT 4
- Implement AsRawFd, IntoRawFd, AsRawHandle, IntoRawHandle and Into<Stdio> for MMap HOT 2
- Composite memory maps currently impossible HOT 7
- mmap'd anon pages fail in io_uring IOSQE_BUFFER_SELECT usage HOT 2
- advise_writes_unsafely_to_part_of_map test fails on powerpc64le-unknown-linux-gnu HOT 2
- error[E0433]: failed to resolve: could not find `Advice` in `memmap2` HOT 1
- PermissionDenied, message: "Access is denied." at remove file after read on Github Action WIndows HOT 2
- Doesn't compile for freebsd HOT 3
- v0.9.2 build failed for android target. HOT 3
- Support for `MS_INVALIDATE`? HOT 8
- Mac osx support HOT 1
- Support `mremap(2)` HOT 1
- Mapping beyond 4GB offset if broken on 32 bit glibc (Linux) HOT 3
- Support multiple advice HOT 2
- Contributing a migration from rustix to libc HOT 9
- MSRV and edition HOT 5
- Merging changes with memmapix HOT 24
- memmap2 `advise` is unsound HOT 8
- Interest is supporting mbind HOT 10
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from memmap2-rs.