Comments (2)
I guess to supress the first warning, padding bytes in structs also need to be initialized.
from drm-rs.
Things like mem::zeroed()
and MaybeUninit::zeroed()
don't seem to actually initialize padding bytes either. But ptr::write_bytes
can be used to memset the bytes to 0. #197 does this for the dynamic allocations, where it is fairly clean.
This is more awkward with the stack allocated ioctl parameters. This seems to work, but is not... ideal:
pub struct ZeroInit<T: Copy> {
inner: Box<std::mem::MaybeUninit<T>>,
}
impl<T: Copy> ZeroInit<T> {
pub unsafe fn new() -> Self {
// Using `MaybeUninit::zeroed` doesn't initialize padding bytes
let mut inner = Box::new(std::mem::MaybeUninit::uninit());
(inner.as_mut_ptr() as *mut _ as *mut u8).write_bytes(0, std::mem::size_of::<T>());
Self { inner }
}
}
impl<T: Copy> ops::Deref for ZeroInit<T> {
type Target = T;
fn deref(&self) -> &T {
unsafe { &*self.inner.as_ptr() }
}
}
impl<T: Copy> ops::DerefMut for ZeroInit<T> {
fn deref_mut(&mut self) -> &mut T {
unsafe { &mut *self.inner.as_mut_ptr() }
}
}
I think Box
is necessary to do this and also abstract it, since copying won't initialize the padding. Otherwise I guess a macro could work...
With the change in #197, there seems to only be the Syscall param ioctl(generic) points to uninitialised byte(s)
errors. Not sure if valgrind has a way to supress those.
Well, at least I have something to test Smithay/cosmic-comp in valgrind. I'll see what else I find doing that.
from drm-rs.
Related Issues (20)
- Support for driver-specific APIs HOT 1
- Missing zero in control/mod.rs? HOT 2
- thread 'main' panicked at 'Could not set CRTC: InvalidArgument' in Examples/legacy_modeset.rs HOT 13
- Atomic mode setting compatibility with libdrm HOT 2
- transmuting Vec might lead to undefined behavior HOT 9
- Failing to get encoders for connector HOT 4
- Atomic modesetting on RPi HOT 12
- Expose drm_sys::drm_clip_rect in the main crate HOT 2
- invalid link HOT 1
- Automate binding updates + Use kernel rather than libdrm HOT 3
- Export drm RDWR/CLOEXEC flags HOT 1
- Async atomic flips
- Consider replacing drm-sys with linux-raw-sys HOT 5
- Taking screenshot HOT 1
- No license file HOT 1
- 0.3.x stable Rust support HOT 4
- Continuous integration using Github Actions HOT 2
- Is the main branch abandoned ? HOT 2
- [Question] Failed to create framebuffer HOT 4
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 drm-rs.