* [PATCH 1/1] use more compatible code in special_mapping_restore
@ 2010-01-29 3:30 Serge E. Hallyn
[not found] ` <20100129033041.GA21071-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
0 siblings, 1 reply; 2+ messages in thread
From: Serge E. Hallyn @ 2010-01-29 3:30 UTC (permalink / raw)
To: Oren Laadan; +Cc: Linux Containers
(Also remove some unused vars in my do_unmap helper)
Signed-off-by: Serge E. Hallyn <serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
---
mm/mmap.c | 12 +++++-------
1 files changed, 5 insertions(+), 7 deletions(-)
diff --git a/mm/mmap.c b/mm/mmap.c
index 15afae6..468c8e2 100644
--- a/mm/mmap.c
+++ b/mm/mmap.c
@@ -30,6 +30,7 @@
#include <linux/mmu_notifier.h>
#include <linux/perf_event.h>
#include <linux/checkpoint.h>
+#include <linux/compat.h>
#include <asm/uaccess.h>
#include <asm/cacheflush.h>
@@ -1960,9 +1961,6 @@ int do_munmap_nocheck(struct mm_struct *mm, unsigned long start, size_t len)
int do_munmap(struct mm_struct *mm, unsigned long start, size_t len)
{
- unsigned long end;
- struct vm_area_struct *vma, *prev, *last;
-
if ((start & ~PAGE_MASK) || start > TASK_SIZE || len > TASK_SIZE-start)
return -EINVAL;
@@ -2354,10 +2352,10 @@ int special_mapping_restore(struct ckpt_ctx *ctx,
* Even that, is very basic - call arch_setup_additional_pages
* requiring the same mapping (start address) as before.
*/
-#ifdef CONFIG_X86_64 && CONFIG_COMPAT
- if (test_thread_flag(TIF_IA32))
- return syscall32_setup_pages(NULL, h->vm_start, 0);
-#endif
+#ifdef CONFIG_COMPAT
+ if (is_compat_task())
+ return compat_arch_setup_additional_pages(NULL, h->vm_start, 0);
+#endif
return arch_setup_additional_pages(NULL, h->vm_start, 0);
}
#else /* !CONFIG_CHECKPOINT */
--
1.6.0.6
^ permalink raw reply related [flat|nested] 2+ messages in thread[parent not found: <20100129033041.GA21071-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 1/1] use more compatible code in special_mapping_restore [not found] ` <20100129033041.GA21071-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org> @ 2010-02-01 4:42 ` Serge E. Hallyn 0 siblings, 0 replies; 2+ messages in thread From: Serge E. Hallyn @ 2010-02-01 4:42 UTC (permalink / raw) To: Oren Laadan; +Cc: Linux Containers Quoting Serge E. Hallyn (serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org): > (Also remove some unused vars in my do_unmap helper) > > Signed-off-by: Serge E. Hallyn <serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org> Please don't apply this. It wasn't supposed to change behavior, but it does, for the worse. > --- > mm/mmap.c | 12 +++++------- > 1 files changed, 5 insertions(+), 7 deletions(-) > > diff --git a/mm/mmap.c b/mm/mmap.c > index 15afae6..468c8e2 100644 > --- a/mm/mmap.c > +++ b/mm/mmap.c > @@ -30,6 +30,7 @@ > #include <linux/mmu_notifier.h> > #include <linux/perf_event.h> > #include <linux/checkpoint.h> > +#include <linux/compat.h> > > #include <asm/uaccess.h> > #include <asm/cacheflush.h> > @@ -1960,9 +1961,6 @@ int do_munmap_nocheck(struct mm_struct *mm, unsigned long start, size_t len) > > int do_munmap(struct mm_struct *mm, unsigned long start, size_t len) > { > - unsigned long end; > - struct vm_area_struct *vma, *prev, *last; > - > if ((start & ~PAGE_MASK) || start > TASK_SIZE || len > TASK_SIZE-start) > return -EINVAL; > > @@ -2354,10 +2352,10 @@ int special_mapping_restore(struct ckpt_ctx *ctx, > * Even that, is very basic - call arch_setup_additional_pages > * requiring the same mapping (start address) as before. > */ > -#ifdef CONFIG_X86_64 && CONFIG_COMPAT > - if (test_thread_flag(TIF_IA32)) > - return syscall32_setup_pages(NULL, h->vm_start, 0); > -#endif > +#ifdef CONFIG_COMPAT > + if (is_compat_task()) > + return compat_arch_setup_additional_pages(NULL, h->vm_start, 0); > +#endif > return arch_setup_additional_pages(NULL, h->vm_start, 0); > } > #else /* !CONFIG_CHECKPOINT */ > -- > 1.6.0.6 > > _______________________________________________ > Containers mailing list > Containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org > https://lists.linux-foundation.org/mailman/listinfo/containers ^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2010-02-01 4:42 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-01-29 3:30 [PATCH 1/1] use more compatible code in special_mapping_restore Serge E. Hallyn
[not found] ` <20100129033041.GA21071-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
2010-02-01 4:42 ` Serge E. Hallyn
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.