diff options
author | Shaohua Li <shaohua.li@intel.com> | 2009-04-20 10:08:35 +1000 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2009-04-20 10:08:35 +1000 |
commit | 59de2bebabc5027f93df999d59cc65df591c3e6e (patch) | |
tree | b4f9f209c254c4e830f10605054dddf52e472184 /drivers/char | |
parent | 07f1c7a7f6736d9ec2eba57d209c5f48888d841e (diff) | |
download | op-kernel-dev-59de2bebabc5027f93df999d59cc65df591c3e6e.zip op-kernel-dev-59de2bebabc5027f93df999d59cc65df591c3e6e.tar.gz |
agp: zero pages before sending to userspace
AGP pages might be mapped into userspace finally, so the pages should be
set to zero before userspace can use it. Otherwise there is potential
information leakage.
Signed-off-by: Shaohua Li <shaohua.li@intel.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/char')
-rw-r--r-- | drivers/char/agp/generic.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/char/agp/generic.c b/drivers/char/agp/generic.c index 10d6cbd..2224b76 100644 --- a/drivers/char/agp/generic.c +++ b/drivers/char/agp/generic.c @@ -1226,7 +1226,7 @@ int agp_generic_alloc_pages(struct agp_bridge_data *bridge, struct agp_memory *m int i, ret = -ENOMEM; for (i = 0; i < num_pages; i++) { - page = alloc_page(GFP_KERNEL | GFP_DMA32); + page = alloc_page(GFP_KERNEL | GFP_DMA32 | __GFP_ZERO); /* agp_free_memory() needs gart address */ if (page == NULL) goto out; @@ -1257,7 +1257,7 @@ void *agp_generic_alloc_page(struct agp_bridge_data *bridge) { struct page * page; - page = alloc_page(GFP_KERNEL | GFP_DMA32); + page = alloc_page(GFP_KERNEL | GFP_DMA32 | __GFP_ZERO); if (page == NULL) return NULL; |