Remove the __user annotations in the struct definitions in comedi.h. These structs are used to pass information from user-space to kernel-space. The copy_from_user and copy_to_user functions are used to transfer the data between the address spaces. The drivers then use the information internally under the assumption that they are kernel-space objects. Having the __user annotations inside the structs produces a number of sparse warnings of the type: warning: dereference of noderef expression According to Grek Kroah-Hartman: "When the kernel exports .h files, stuff like this should work "automatically", so there is no need to not put __user markings." Signed-off-by: H Hartley Sweeten <hsweeten@xxxxxxxxxxxxxxxxxxx> Cc: Ian Abbott <abbotti@xxxxxxxxx> Cc: Mori Hess <fmhess@xxxxxxxxxxxxxxxxxxxxx> Cc: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- v2: update commit message Note: This patch exposes some new warnings about different address space. These will be addressed. diff --git a/drivers/staging/comedi/comedi.h b/drivers/staging/comedi/comedi.h index 8ea55ae..2e2f366 100644 --- a/drivers/staging/comedi/comedi.h +++ b/drivers/staging/comedi/comedi.h @@ -335,7 +335,7 @@ struct comedi_insn { unsigned int insn; unsigned int n; - unsigned int __user *data; + unsigned int *data; unsigned int subdev; unsigned int chanspec; unsigned int unused[3]; @@ -343,7 +343,7 @@ struct comedi_insnlist { unsigned int n_insns; - struct comedi_insn __user *insns; + struct comedi_insn *insns; }; struct comedi_cmd { @@ -365,24 +365,24 @@ unsigned int stop_src; unsigned int stop_arg; - unsigned int __user *chanlist; /* channel/range list */ + unsigned int *chanlist; /* channel/range list */ unsigned int chanlist_len; - short __user *data; /* data list, size depends on subd flags */ + short *data; /* data list, size depends on subd flags */ unsigned int data_len; }; struct comedi_chaninfo { unsigned int subdev; - unsigned int __user *maxdata_list; - unsigned int __user *flaglist; - unsigned int __user *rangelist; + unsigned int *maxdata_list; + unsigned int *flaglist; + unsigned int *rangelist; unsigned int unused[4]; }; struct comedi_rangeinfo { unsigned int range_type; - void __user *range_ptr; + void *range_ptr; }; struct comedi_krange { _______________________________________________ devel mailing list devel@xxxxxxxxxxxxxxxxxxxxxx http://driverdev.linuxdriverproject.org/mailman/listinfo/devel