mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-18 03:23:53 -04:00
Merge tag 'uml-for-linux-6.15-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/uml/linux
Pull uml fix from Johannes Berg: "There's just a single fix here for the _nofault changes that were causing issues with clang, and then when we looked at it some other issues seemed to exist" * tag 'uml-for-linux-6.15-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/uml/linux: um: fix _nofault accesses
This commit is contained in:
@@ -55,6 +55,7 @@ do { \
|
|||||||
goto err_label; \
|
goto err_label; \
|
||||||
} \
|
} \
|
||||||
*((type *)dst) = get_unaligned((type *)(src)); \
|
*((type *)dst) = get_unaligned((type *)(src)); \
|
||||||
|
barrier(); \
|
||||||
current->thread.segv_continue = NULL; \
|
current->thread.segv_continue = NULL; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
@@ -66,6 +67,7 @@ do { \
|
|||||||
if (__faulted) \
|
if (__faulted) \
|
||||||
goto err_label; \
|
goto err_label; \
|
||||||
put_unaligned(*((type *)src), (type *)(dst)); \
|
put_unaligned(*((type *)src), (type *)(dst)); \
|
||||||
|
barrier(); \
|
||||||
current->thread.segv_continue = NULL; \
|
current->thread.segv_continue = NULL; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
|||||||
@@ -225,8 +225,7 @@ unsigned long segv(struct faultinfo fi, unsigned long ip, int is_user,
|
|||||||
panic("Failed to sync kernel TLBs: %d", err);
|
panic("Failed to sync kernel TLBs: %d", err);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
else if (current->mm == NULL) {
|
else if (current->pagefault_disabled) {
|
||||||
if (current->pagefault_disabled) {
|
|
||||||
if (!mc) {
|
if (!mc) {
|
||||||
show_regs(container_of(regs, struct pt_regs, regs));
|
show_regs(container_of(regs, struct pt_regs, regs));
|
||||||
panic("Segfault with pagefaults disabled but no mcontext");
|
panic("Segfault with pagefaults disabled but no mcontext");
|
||||||
@@ -239,6 +238,7 @@ unsigned long segv(struct faultinfo fi, unsigned long ip, int is_user,
|
|||||||
current->thread.segv_continue = NULL;
|
current->thread.segv_continue = NULL;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
else if (current->mm == NULL) {
|
||||||
show_regs(container_of(regs, struct pt_regs, regs));
|
show_regs(container_of(regs, struct pt_regs, regs));
|
||||||
panic("Segfault with no mm");
|
panic("Segfault with no mm");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,8 +31,8 @@ struct faultinfo {
|
|||||||
|
|
||||||
#define ___backtrack_faulted(_faulted) \
|
#define ___backtrack_faulted(_faulted) \
|
||||||
asm volatile ( \
|
asm volatile ( \
|
||||||
"mov $0, %0\n" \
|
|
||||||
"movl $__get_kernel_nofault_faulted_%=,%1\n" \
|
"movl $__get_kernel_nofault_faulted_%=,%1\n" \
|
||||||
|
"mov $0, %0\n" \
|
||||||
"jmp _end_%=\n" \
|
"jmp _end_%=\n" \
|
||||||
"__get_kernel_nofault_faulted_%=:\n" \
|
"__get_kernel_nofault_faulted_%=:\n" \
|
||||||
"mov $1, %0;" \
|
"mov $1, %0;" \
|
||||||
|
|||||||
@@ -31,8 +31,8 @@ struct faultinfo {
|
|||||||
|
|
||||||
#define ___backtrack_faulted(_faulted) \
|
#define ___backtrack_faulted(_faulted) \
|
||||||
asm volatile ( \
|
asm volatile ( \
|
||||||
"mov $0, %0\n" \
|
|
||||||
"movq $__get_kernel_nofault_faulted_%=,%1\n" \
|
"movq $__get_kernel_nofault_faulted_%=,%1\n" \
|
||||||
|
"mov $0, %0\n" \
|
||||||
"jmp _end_%=\n" \
|
"jmp _end_%=\n" \
|
||||||
"__get_kernel_nofault_faulted_%=:\n" \
|
"__get_kernel_nofault_faulted_%=:\n" \
|
||||||
"mov $1, %0;" \
|
"mov $1, %0;" \
|
||||||
|
|||||||
Reference in New Issue
Block a user