diff options
author | Tom <tomut@yahoo.com> | 2020-09-30 19:08:54 -0600 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2020-10-02 15:38:07 +0200 |
commit | 87f20f704cc66d3878c1a62f0a2ffe5a5e202274 (patch) | |
tree | e015f6cdeb081819fffe6c0ad184a6a128e53adf | |
parent | bb92eab9ce7de7ac204b8dcaa501aa30b8f15867 (diff) | |
download | serenity-87f20f704cc66d3878c1a62f0a2ffe5a5e202274.zip |
Kernel: Add checks for is_trivially_copyable to copy_to/from_user
If we're copying structures, we only ever want to copy trivially
copyable structures.
-rw-r--r-- | Kernel/StdLib.h | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/Kernel/StdLib.h b/Kernel/StdLib.h index fb64af7ab2..f900cb1571 100644 --- a/Kernel/StdLib.h +++ b/Kernel/StdLib.h @@ -61,48 +61,56 @@ inline u16 htons(u16 w) { return (w & 0xff) << 8 | ((w >> 8) & 0xff); } template<typename T> [[nodiscard]] inline bool copy_from_user(T* dest, const T* src) { + static_assert(is_trivially_copyable<T>()); return copy_from_user(dest, src, sizeof(T)); } template<typename T> [[nodiscard]] inline bool copy_to_user(T* dest, const T* src) { + static_assert(is_trivially_copyable<T>()); return copy_to_user(dest, src, sizeof(T)); } template<typename T> [[nodiscard]] inline bool copy_from_user(T* dest, Userspace<const T*> src) { + static_assert(is_trivially_copyable<T>()); return copy_from_user(dest, src.unsafe_userspace_ptr(), sizeof(T)); } template<typename T> [[nodiscard]] inline bool copy_from_user(T* dest, Userspace<T*> src) { + static_assert(is_trivially_copyable<T>()); return copy_from_user(dest, src.unsafe_userspace_ptr(), sizeof(T)); } template<typename T> [[nodiscard]] inline bool copy_to_user(Userspace<T*> dest, const T* src) { + static_assert(is_trivially_copyable<T>()); return copy_to_user(dest.unsafe_userspace_ptr(), src, sizeof(T)); } template<typename T> [[nodiscard]] inline bool copy_to_user(Userspace<T*> dest, const void* src, size_t size) { + static_assert(is_trivially_copyable<T>()); return copy_to_user(dest.unsafe_userspace_ptr(), src, size); } template<typename T> [[nodiscard]] inline bool copy_from_user(void* dest, Userspace<const T*> src, size_t size) { + static_assert(is_trivially_copyable<T>()); return copy_from_user(dest, src.unsafe_userspace_ptr(), size); } template<typename T> [[nodiscard]] inline bool copy_n_from_user(T* dest, const T* src, size_t count) { + static_assert(is_trivially_copyable<T>()); Checked size = sizeof(T); size *= count; if (size.has_overflow()) @@ -113,6 +121,7 @@ template<typename T> template<typename T> [[nodiscard]] inline bool copy_n_to_user(T* dest, const T* src, size_t count) { + static_assert(is_trivially_copyable<T>()); Checked size = sizeof(T); size *= count; if (size.has_overflow()) @@ -123,6 +132,7 @@ template<typename T> template<typename T> [[nodiscard]] inline bool copy_n_from_user(T* dest, Userspace<const T*> src, size_t count) { + static_assert(is_trivially_copyable<T>()); Checked size = sizeof(T); size *= count; if (size.has_overflow()) @@ -133,6 +143,7 @@ template<typename T> template<typename T> [[nodiscard]] inline bool copy_n_to_user(Userspace<T*> dest, const T* src, size_t count) { + static_assert(is_trivially_copyable<T>()); Checked size = sizeof(T); size *= count; if (size.has_overflow()) |