diff mbox series

misc: uacce - add the null check for the input pointer and its pointer members

Message ID 20240329062655.3055646-1-huangchenghai2@huawei.com (mailing list archive)
State Not Applicable
Delegated to: Herbert Xu
Headers show
Series misc: uacce - add the null check for the input pointer and its pointer members | expand

Commit Message

Chenghai Huang March 29, 2024, 6:26 a.m. UTC
The uacce_alloc() is the member of the EXPORT_SYMBOL_GPL. Therefore, null
pointer verification is added on the pointer type input parameter and its
pointer members.

Signed-off-by: Chenghai Huang <huangchenghai2@huawei.com>
---
 drivers/misc/uacce/uacce.c | 3 +++
 1 file changed, 3 insertions(+)

Comments

Greg Kroah-Hartman March 29, 2024, 6:34 a.m. UTC | #1
On Fri, Mar 29, 2024 at 02:26:55PM +0800, Chenghai Huang wrote:
> The uacce_alloc() is the member of the EXPORT_SYMBOL_GPL. Therefore, null
> pointer verification is added on the pointer type input parameter and its
> pointer members.

I do not understand, why does the export type matter?  Just fix any
callers to use this properly and send proper parameters.  What in-tree
caller needs this?

thanks,

greg k-h
Greg Kroah-Hartman March 30, 2024, 7:01 a.m. UTC | #2
On Sat, Mar 30, 2024 at 11:34:24AM +0800, huangchenghai wrote:
> 
> On Fri, Mar 29, 2024 at2:34PM, Greg KH wrote:
> 
> > On Fri, Mar 29, 2024 at 02:26:55PM +0800, Chenghai Huang wrote:
> > > The uacce_alloc() is the member of the EXPORT_SYMBOL_GPL. Therefore, null
> > > pointer verification is added on the pointer type input parameter and its
> > > pointer members.
> > I do not understand, why does the export type matter?  Just fix any
> > callers to use this properly and send proper parameters.  What in-tree
> > caller needs this?
> > 
> > thanks,
> > 
> > greg k-h
> 
> The interface defined by the export type seems important and the input
> parameters need to be verified.

The export type does not matter at all.

> But I understand from your mail that this is the job of the caller.

Exactly.

> By the way, I still have a confusion. Interfaces like ioctrl, debugfs, read,
> or write require parameter validation. so what kind of kernel interfaces require
> parameter validation? Is there a definition?

Some do, some do not, it depends on the situation.  If data comes from
an untrusted source (i.e. outside the kernel), then it MUST be validated
(remember "all input is evil"), but if it's from within the kernel,
usually it does not.

thanks,

greg k-h
Chenghai Huang March 30, 2024, 7:10 a.m. UTC | #3
在 2024/3/30 15:01, Greg KH 写道:
> On Sat, Mar 30, 2024 at 11:34:24AM +0800, huangchenghai wrote:
>> On Fri, Mar 29, 2024 at2:34PM, Greg KH wrote:
>>
>>> On Fri, Mar 29, 2024 at 02:26:55PM +0800, Chenghai Huang wrote:
>>>> The uacce_alloc() is the member of the EXPORT_SYMBOL_GPL. Therefore, null
>>>> pointer verification is added on the pointer type input parameter and its
>>>> pointer members.
>>> I do not understand, why does the export type matter?  Just fix any
>>> callers to use this properly and send proper parameters.  What in-tree
>>> caller needs this?
>>>
>>> thanks,
>>>
>>> greg k-h
>> The interface defined by the export type seems important and the input
>> parameters need to be verified.
> The export type does not matter at all.
>
>> But I understand from your mail that this is the job of the caller.
> Exactly.
>
>> By the way, I still have a confusion. Interfaces like ioctrl, debugfs, read,
>> or write require parameter validation. so what kind of kernel interfaces require
>> parameter validation? Is there a definition?
> Some do, some do not, it depends on the situation.  If data comes from
> an untrusted source (i.e. outside the kernel), then it MUST be validated
> (remember "all input is evil"), but if it's from within the kernel,
> usually it does not.
>
> thanks,
>
> greg k-h

I get it, thank you very much.

thanks,

Chenghai
diff mbox series

Patch

diff --git a/drivers/misc/uacce/uacce.c b/drivers/misc/uacce/uacce.c
index bdc2e6fda782..964f1a6a16e0 100644
--- a/drivers/misc/uacce/uacce.c
+++ b/drivers/misc/uacce/uacce.c
@@ -514,6 +514,9 @@  struct uacce_device *uacce_alloc(struct device *parent,
 	struct uacce_device *uacce;
 	int ret;
 
+	if (!parent || !interface || !interface->ops)
+		return ERR_PTR(-EINVAL);
+
 	uacce = kzalloc(sizeof(struct uacce_device), GFP_KERNEL);
 	if (!uacce)
 		return ERR_PTR(-ENOMEM);