From: Jerome Glisse <jglisse@redhat.com>
To: Igor Stoppa <igor.stoppa@huawei.com>
Cc: Michal Hocko <mhocko@kernel.org>, Linux-MM <linux-mm@kvack.org>,
LKML <linux-kernel@vger.kernel.org>,
linux-security-module@vger.kernel.org,
"kernel-hardening@lists.openwall.com"
<kernel-hardening@lists.openwall.com>,
Kees Cook <keescook@google.com>
Subject: [kernel-hardening] Re: [RFC] Tagging of vmalloc pages for supporting the pmalloc allocator
Date: Mon, 7 Aug 2017 09:31:07 -0400 [thread overview]
Message-ID: <20170807133107.GA16616@redhat.com> (raw)
In-Reply-To: <7733852a-67c9-17a3-4031-cb08520b9ad2@huawei.com>
On Mon, Aug 07, 2017 at 02:26:21PM +0300, Igor Stoppa wrote:
> On 04/08/17 11:12, Michal Hocko wrote:
> > On Fri 04-08-17 11:02:46, Igor Stoppa wrote:
>
> [...]
>
> >> struct page {
> >> /* First double word block */
> >> unsigned long flags; /* Atomic flags, some possibly
> >> * updated asynchronously */
> >> union {
> >> struct address_space *mapping; /* If low bit clear, points to
> >> * inode address_space, or NULL.
> >> * If page mapped as anonymous
> >> * memory, low bit is set, and
> >> * it points to anon_vma object:
> >> * see PAGE_MAPPING_ANON below.
> >> */
> >> ...
> >> }
> >>
> >> mapping seems to be used exclusively in 2 ways, based on the value of
> >> its lower bit.
> >
> > Not really. The above applies to LRU pages. Please note that Slab pages
> > use s_mem and huge pages use compound_mapcount. If vmalloc pages are
> > using none of those already you can add a new field there.
>
> Yes, both from reading the code and some experimentation, it seems that
> vmalloc is not using either field.
>
> I'll add a vm_area field as you advised.
>
> Is this something I could send as standalone patch?
Note that vmalloc() is not the only thing that use vmalloc address
space. There is also vmap() and i know one set of drivers that use
vmap() and also use the mapping field of struct page namely GPU
drivers.
So like i said previously i would store a flag inside vm_struct to
know if page you are looking at are pmalloc or not. Again do you
need to store something per page ? Would storing it per vm_struct
not be enough ?
Cheers,
Jérôme
WARNING: multiple messages have this Message-ID (diff)
From: jglisse@redhat.com (Jerome Glisse)
To: linux-security-module@vger.kernel.org
Subject: [RFC] Tagging of vmalloc pages for supporting the pmalloc allocator
Date: Mon, 7 Aug 2017 09:31:07 -0400 [thread overview]
Message-ID: <20170807133107.GA16616@redhat.com> (raw)
In-Reply-To: <7733852a-67c9-17a3-4031-cb08520b9ad2@huawei.com>
On Mon, Aug 07, 2017 at 02:26:21PM +0300, Igor Stoppa wrote:
> On 04/08/17 11:12, Michal Hocko wrote:
> > On Fri 04-08-17 11:02:46, Igor Stoppa wrote:
>
> [...]
>
> >> struct page {
> >> /* First double word block */
> >> unsigned long flags; /* Atomic flags, some possibly
> >> * updated asynchronously */
> >> union {
> >> struct address_space *mapping; /* If low bit clear, points to
> >> * inode address_space, or NULL.
> >> * If page mapped as anonymous
> >> * memory, low bit is set, and
> >> * it points to anon_vma object:
> >> * see PAGE_MAPPING_ANON below.
> >> */
> >> ...
> >> }
> >>
> >> mapping seems to be used exclusively in 2 ways, based on the value of
> >> its lower bit.
> >
> > Not really. The above applies to LRU pages. Please note that Slab pages
> > use s_mem and huge pages use compound_mapcount. If vmalloc pages are
> > using none of those already you can add a new field there.
>
> Yes, both from reading the code and some experimentation, it seems that
> vmalloc is not using either field.
>
> I'll add a vm_area field as you advised.
>
> Is this something I could send as standalone patch?
Note that vmalloc() is not the only thing that use vmalloc address
space. There is also vmap() and i know one set of drivers that use
vmap() and also use the mapping field of struct page namely GPU
drivers.
So like i said previously i would store a flag inside vm_struct to
know if page you are looking at are pmalloc or not. Again do you
need to store something per page ? Would storing it per vm_struct
not be enough ?
Cheers,
J?r?me
--
To unsubscribe from this list: send the line "unsubscribe linux-security-module" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
WARNING: multiple messages have this Message-ID (diff)
From: Jerome Glisse <jglisse@redhat.com>
To: Igor Stoppa <igor.stoppa@huawei.com>
Cc: Michal Hocko <mhocko@kernel.org>, Linux-MM <linux-mm@kvack.org>,
LKML <linux-kernel@vger.kernel.org>,
linux-security-module@vger.kernel.org,
"kernel-hardening@lists.openwall.com"
<kernel-hardening@lists.openwall.com>,
Kees Cook <keescook@google.com>
Subject: Re: [RFC] Tagging of vmalloc pages for supporting the pmalloc allocator
Date: Mon, 7 Aug 2017 09:31:07 -0400 [thread overview]
Message-ID: <20170807133107.GA16616@redhat.com> (raw)
In-Reply-To: <7733852a-67c9-17a3-4031-cb08520b9ad2@huawei.com>
On Mon, Aug 07, 2017 at 02:26:21PM +0300, Igor Stoppa wrote:
> On 04/08/17 11:12, Michal Hocko wrote:
> > On Fri 04-08-17 11:02:46, Igor Stoppa wrote:
>
> [...]
>
> >> struct page {
> >> /* First double word block */
> >> unsigned long flags; /* Atomic flags, some possibly
> >> * updated asynchronously */
> >> union {
> >> struct address_space *mapping; /* If low bit clear, points to
> >> * inode address_space, or NULL.
> >> * If page mapped as anonymous
> >> * memory, low bit is set, and
> >> * it points to anon_vma object:
> >> * see PAGE_MAPPING_ANON below.
> >> */
> >> ...
> >> }
> >>
> >> mapping seems to be used exclusively in 2 ways, based on the value of
> >> its lower bit.
> >
> > Not really. The above applies to LRU pages. Please note that Slab pages
> > use s_mem and huge pages use compound_mapcount. If vmalloc pages are
> > using none of those already you can add a new field there.
>
> Yes, both from reading the code and some experimentation, it seems that
> vmalloc is not using either field.
>
> I'll add a vm_area field as you advised.
>
> Is this something I could send as standalone patch?
Note that vmalloc() is not the only thing that use vmalloc address
space. There is also vmap() and i know one set of drivers that use
vmap() and also use the mapping field of struct page namely GPU
drivers.
So like i said previously i would store a flag inside vm_struct to
know if page you are looking at are pmalloc or not. Again do you
need to store something per page ? Would storing it per vm_struct
not be enough ?
Cheers,
Jerome
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
WARNING: multiple messages have this Message-ID (diff)
From: Jerome Glisse <jglisse@redhat.com>
To: Igor Stoppa <igor.stoppa@huawei.com>
Cc: Michal Hocko <mhocko@kernel.org>, Linux-MM <linux-mm@kvack.org>,
LKML <linux-kernel@vger.kernel.org>,
linux-security-module@vger.kernel.org,
"kernel-hardening@lists.openwall.com"
<kernel-hardening@lists.openwall.com>,
Kees Cook <keescook@google.com>
Subject: Re: [RFC] Tagging of vmalloc pages for supporting the pmalloc allocator
Date: Mon, 7 Aug 2017 09:31:07 -0400 [thread overview]
Message-ID: <20170807133107.GA16616@redhat.com> (raw)
In-Reply-To: <7733852a-67c9-17a3-4031-cb08520b9ad2@huawei.com>
On Mon, Aug 07, 2017 at 02:26:21PM +0300, Igor Stoppa wrote:
> On 04/08/17 11:12, Michal Hocko wrote:
> > On Fri 04-08-17 11:02:46, Igor Stoppa wrote:
>
> [...]
>
> >> struct page {
> >> /* First double word block */
> >> unsigned long flags; /* Atomic flags, some possibly
> >> * updated asynchronously */
> >> union {
> >> struct address_space *mapping; /* If low bit clear, points to
> >> * inode address_space, or NULL.
> >> * If page mapped as anonymous
> >> * memory, low bit is set, and
> >> * it points to anon_vma object:
> >> * see PAGE_MAPPING_ANON below.
> >> */
> >> ...
> >> }
> >>
> >> mapping seems to be used exclusively in 2 ways, based on the value of
> >> its lower bit.
> >
> > Not really. The above applies to LRU pages. Please note that Slab pages
> > use s_mem and huge pages use compound_mapcount. If vmalloc pages are
> > using none of those already you can add a new field there.
>
> Yes, both from reading the code and some experimentation, it seems that
> vmalloc is not using either field.
>
> I'll add a vm_area field as you advised.
>
> Is this something I could send as standalone patch?
Note that vmalloc() is not the only thing that use vmalloc address
space. There is also vmap() and i know one set of drivers that use
vmap() and also use the mapping field of struct page namely GPU
drivers.
So like i said previously i would store a flag inside vm_struct to
know if page you are looking at are pmalloc or not. Again do you
need to store something per page ? Would storing it per vm_struct
not be enough ?
Cheers,
Jérôme
next prev parent reply other threads:[~2017-08-07 13:31 UTC|newest]
Thread overview: 84+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-08-02 15:14 [kernel-hardening] [RFC] Tagging of vmalloc pages for supporting the pmalloc allocator Igor Stoppa
2017-08-02 15:14 ` Igor Stoppa
2017-08-02 15:14 ` Igor Stoppa
2017-08-02 15:14 ` Igor Stoppa
2017-08-02 17:08 ` [kernel-hardening] " Jerome Glisse
2017-08-02 17:08 ` Jerome Glisse
2017-08-02 17:08 ` Jerome Glisse
2017-08-02 17:08 ` Jerome Glisse
2017-08-03 10:11 ` [kernel-hardening] " Igor Stoppa
2017-08-03 10:11 ` Igor Stoppa
2017-08-03 10:11 ` Igor Stoppa
2017-08-03 10:11 ` Igor Stoppa
2017-08-03 11:48 ` [kernel-hardening] " Michal Hocko
2017-08-03 11:48 ` Michal Hocko
2017-08-03 11:48 ` Michal Hocko
2017-08-03 11:48 ` Michal Hocko
2017-08-03 12:20 ` [kernel-hardening] " Igor Stoppa
2017-08-03 12:20 ` Igor Stoppa
2017-08-03 12:20 ` Igor Stoppa
2017-08-03 12:20 ` Igor Stoppa
2017-08-03 13:55 ` [kernel-hardening] " Michal Hocko
2017-08-03 13:55 ` Michal Hocko
2017-08-03 13:55 ` Michal Hocko
2017-08-03 13:55 ` Michal Hocko
2017-08-03 14:41 ` [kernel-hardening] " Igor Stoppa
2017-08-03 14:41 ` Igor Stoppa
2017-08-03 14:41 ` Igor Stoppa
2017-08-03 14:41 ` Igor Stoppa
2017-08-03 14:47 ` [kernel-hardening] " Jerome Glisse
2017-08-03 14:47 ` Jerome Glisse
2017-08-03 14:47 ` Jerome Glisse
2017-08-03 14:47 ` Jerome Glisse
2017-08-03 15:06 ` [kernel-hardening] " Igor Stoppa
2017-08-03 15:06 ` Igor Stoppa
2017-08-03 15:06 ` Igor Stoppa
2017-08-03 15:06 ` Igor Stoppa
2017-08-03 15:15 ` [kernel-hardening] " Michal Hocko
2017-08-03 15:15 ` Michal Hocko
2017-08-03 15:15 ` Michal Hocko
2017-08-03 15:15 ` Michal Hocko
2017-08-04 8:02 ` [kernel-hardening] " Igor Stoppa
2017-08-04 8:02 ` Igor Stoppa
2017-08-04 8:02 ` Igor Stoppa
2017-08-04 8:02 ` Igor Stoppa
2017-08-04 8:12 ` [kernel-hardening] " Michal Hocko
2017-08-04 8:12 ` Michal Hocko
2017-08-04 8:12 ` Michal Hocko
2017-08-04 8:12 ` Michal Hocko
2017-08-07 11:26 ` [kernel-hardening] " Igor Stoppa
2017-08-07 11:26 ` Igor Stoppa
2017-08-07 11:26 ` Igor Stoppa
2017-08-07 11:26 ` Igor Stoppa
2017-08-07 11:34 ` [kernel-hardening] " Michal Hocko
2017-08-07 11:34 ` Michal Hocko
2017-08-07 11:34 ` Michal Hocko
2017-08-07 11:34 ` Michal Hocko
2017-08-07 13:31 ` Jerome Glisse [this message]
2017-08-07 13:31 ` Jerome Glisse
2017-08-07 13:31 ` Jerome Glisse
2017-08-07 13:31 ` Jerome Glisse
2017-08-07 14:13 ` [kernel-hardening] " Igor Stoppa
2017-08-07 14:13 ` Igor Stoppa
2017-08-07 14:13 ` Igor Stoppa
2017-08-07 14:13 ` Igor Stoppa
2017-08-07 19:12 ` [kernel-hardening] " Jerome Glisse
2017-08-07 19:12 ` Jerome Glisse
2017-08-07 19:12 ` Jerome Glisse
2017-08-07 19:12 ` Jerome Glisse
2017-08-08 12:59 ` [kernel-hardening] " Igor Stoppa
2017-08-08 12:59 ` Igor Stoppa
2017-08-08 12:59 ` Igor Stoppa
2017-08-08 12:59 ` Igor Stoppa
2017-08-08 23:15 ` [kernel-hardening] " Jerome Glisse
2017-08-08 23:15 ` Jerome Glisse
2017-08-08 23:15 ` Jerome Glisse
2017-08-08 23:15 ` Jerome Glisse
2017-08-09 7:27 ` [kernel-hardening] " Igor Stoppa
2017-08-09 7:27 ` Igor Stoppa
2017-08-09 7:27 ` Igor Stoppa
2017-08-09 7:27 ` Igor Stoppa
2017-08-10 7:14 ` [kernel-hardening] " Michal Hocko
2017-08-10 7:14 ` Michal Hocko
2017-08-10 7:14 ` Michal Hocko
2017-08-10 7:14 ` Michal Hocko
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170807133107.GA16616@redhat.com \
--to=jglisse@redhat.com \
--cc=igor.stoppa@huawei.com \
--cc=keescook@google.com \
--cc=kernel-hardening@lists.openwall.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=linux-security-module@vger.kernel.org \
--cc=mhocko@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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.