All of lore.kernel.org
 help / color / mirror / Atom feed
* [Xenomai-core] Comedi buffer management.
@ 2008-10-12 10:28 Gilles Chanteperdrix
  2008-10-12 12:51 ` Gilles Chanteperdrix
  2008-10-20 22:45 ` Alexis Berlemont
  0 siblings, 2 replies; 4+ messages in thread
From: Gilles Chanteperdrix @ 2008-10-12 10:28 UTC (permalink / raw)
  To: Alexis Berlemont; +Cc: Xenomai core


Hi Alex,

I commited in trunk a fix of Xenomai heap management for the highmem 
case. What the patch does is essentially replacing __va_to_kva (which 
does not work correctly with highmem) with vmalloc_to_page, which is 
available on all linux versions Xenomai supports.

However, I found that comedi buffer management also uses __va_to_kva. We 
can fix SetPageReserved and ClearPageReserved easily to use 
vmalloc_to_page, however, I do not see what pg_list is used for, so do 
not really know how to fix it. Here is a proposed patch:

Index: ksrc/drivers/comedi/buffer.c
===================================================================
--- ksrc/drivers/comedi/buffer.c	(revision 4211)
+++ ksrc/drivers/comedi/buffer.c	(working copy)
@@ -46,7 +46,7 @@ void comedi_free_buffer(comedi_buf_t * b
 		unsigned long vaddr, vabase = (unsigned long)buf_desc->buf;
 		for (vaddr = vabase; vaddr < vabase + buf_desc->size;
 		     vaddr += PAGE_SIZE)
-			ClearPageReserved(virt_to_page(__va_to_kva(vaddr)));
+			ClearPageReserved(vmalloc_to_page(vaddr));
 		vfree(buf_desc->buf);
 		buf_desc->buf = NULL;
 	}
@@ -73,7 +73,7 @@ int comedi_alloc_buffer(comedi_buf_t * b
 
 	for (vaddr = vabase; vaddr < vabase + buf_desc->size;
 	     vaddr += PAGE_SIZE)
-		SetPageReserved(virt_to_page(__va_to_kva(vaddr)));
+		SetPageReserved(vmalloc_to_page(vaddr));
 
 	buf_desc->pg_list = comedi_kmalloc(((buf_desc->size) >> PAGE_SHIFT) *
 					   sizeof(unsigned long));
@@ -85,7 +85,7 @@ int comedi_alloc_buffer(comedi_buf_t * b
 	for (vaddr = vabase; vaddr < vabase + buf_desc->size;
 	     vaddr += PAGE_SIZE)
 		buf_desc->pg_list[(vaddr - vabase) >> PAGE_SHIFT] =
-		    __va_to_kva(vaddr);
+			(unsigned long) vmalloc_to_page(vaddr);
 
       out_virt_contig_alloc:
 	if (ret != 0)

Cheers.

-- 
					    Gilles.


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2008-10-21 15:58 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-10-12 10:28 [Xenomai-core] Comedi buffer management Gilles Chanteperdrix
2008-10-12 12:51 ` Gilles Chanteperdrix
2008-10-20 22:45 ` Alexis Berlemont
2008-10-21 15:58   ` Gilles Chanteperdrix

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.