Skip to content

Commit

Permalink
intel-agp: fix sglist allocation to avoid vmalloc()
Browse files Browse the repository at this point in the history
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
  • Loading branch information
David Woodhouse authored and David Woodhouse committed Aug 3, 2009
1 parent 91b8e30 commit f692775
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 20 deletions.
29 changes: 10 additions & 19 deletions drivers/char/agp/intel-agp.c
Original file line number Diff line number Diff line change
Expand Up @@ -198,39 +198,30 @@ static void intel_agp_unmap_page(struct page *page, dma_addr_t dma)

static void intel_agp_free_sglist(struct agp_memory *mem)
{
struct sg_table st;

st.sgl = mem->sg_list;
st.orig_nents = st.nents = mem->page_count;

sg_free_table(&st);

if (mem->sg_vmalloc_flag)
vfree(mem->sg_list);
else
kfree(mem->sg_list);
mem->sg_vmalloc_flag = 0;
mem->sg_list = NULL;
mem->num_sg = 0;
}

static int intel_agp_map_memory(struct agp_memory *mem)
{
struct sg_table st;
struct scatterlist *sg;
int i;

DBG("try mapping %lu pages\n", (unsigned long)mem->page_count);

if ((mem->page_count * sizeof(*mem->sg_list)) < 2*PAGE_SIZE)
mem->sg_list = kcalloc(mem->page_count, sizeof(*mem->sg_list),
GFP_KERNEL);

if (mem->sg_list == NULL) {
mem->sg_list = vmalloc(mem->page_count * sizeof(*mem->sg_list));
mem->sg_vmalloc_flag = 1;
}

if (!mem->sg_list) {
mem->sg_vmalloc_flag = 0;
if (sg_alloc_table(&st, mem->page_count, GFP_KERNEL))
return -ENOMEM;
}
sg_init_table(mem->sg_list, mem->page_count);

sg = mem->sg_list;
mem->sg_list = sg = st.sgl;

for (i = 0 ; i < mem->page_count; i++, sg = sg_next(sg))
sg_set_page(sg, mem->pages[i], PAGE_SIZE, 0);

Expand Down
1 change: 0 additions & 1 deletion include/linux/agp_backend.h
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,6 @@ struct agp_memory {
bool is_bound;
bool is_flushed;
bool vmalloc_flag;
bool sg_vmalloc_flag;
/* list of agp_memory mapped to the aperture */
struct list_head mapped_list;
/* DMA-mapped addresses */
Expand Down

0 comments on commit f692775

Please sign in to comment.