public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [RFC PATCH] Security: ignore private inode from security_file_receive
@ 2015-04-16 13:40 Seung-Woo Kim
  2015-04-16 13:48 ` Stephen Smalley
  2015-04-16 15:35 ` Casey Schaufler
  0 siblings, 2 replies; 4+ messages in thread
From: Seung-Woo Kim @ 2015-04-16 13:40 UTC (permalink / raw)
  To: james.l.morris, serge, linux-security-module, linux-kernel
  Cc: sw0312.kim, sumit.semwal, linaro-mm-sig, jy0922.shim

The dma-buf fd from anon_inode can be shared across processes, but
there is no way to set security permission for the fd. So this
patch fix just to ignore private inode from security_file_receive.

Signed-off-by: Seung-Woo Kim <sw0312.kim@samsung.com>
---

If security like smack is enabled, the dmabuf fd can not be shared between
processes via unix domain socket. I am not familiar with security, so I am
not sure that this kind of patch can be acceptable.

Is there other option to share dmabuf fd via socket with security check?

Best Regards,
- Seung-Woo Kim

---
 security/security.c |    3 +++
 1 files changed, 3 insertions(+), 0 deletions(-)

diff --git a/security/security.c b/security/security.c
index 730ac65..c57354c 100644
--- a/security/security.c
+++ b/security/security.c
@@ -810,6 +810,9 @@ int security_file_send_sigiotask(struct task_struct *tsk,
 
 int security_file_receive(struct file *file)
 {
+
+	if (unlikely(IS_PRIVATE(file->f_path.dentry->d_inode)))
+		return 0;
 	return security_ops->file_receive(file);
 }
 
-- 
1.7.4.1


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

* Re: [RFC PATCH] Security: ignore private inode from security_file_receive
  2015-04-16 13:40 [RFC PATCH] Security: ignore private inode from security_file_receive Seung-Woo Kim
@ 2015-04-16 13:48 ` Stephen Smalley
  2015-04-17  2:00   ` Seung-Woo Kim
  2015-04-16 15:35 ` Casey Schaufler
  1 sibling, 1 reply; 4+ messages in thread
From: Stephen Smalley @ 2015-04-16 13:48 UTC (permalink / raw)
  To: Seung-Woo Kim, james.l.morris, serge, linux-security-module,
	linux-kernel
  Cc: sumit.semwal, linaro-mm-sig, jy0922.shim

On 04/16/2015 09:40 AM, Seung-Woo Kim wrote:
> The dma-buf fd from anon_inode can be shared across processes, but
> there is no way to set security permission for the fd. So this
> patch fix just to ignore private inode from security_file_receive.
> 
> Signed-off-by: Seung-Woo Kim <sw0312.kim@samsung.com>
> ---
> 
> If security like smack is enabled, the dmabuf fd can not be shared between
> processes via unix domain socket. I am not familiar with security, so I am
> not sure that this kind of patch can be acceptable.
> 
> Is there other option to share dmabuf fd via socket with security check?
> 
> Best Regards,
> - Seung-Woo Kim
> 
> ---
>  security/security.c |    3 +++
>  1 files changed, 3 insertions(+), 0 deletions(-)
> 
> diff --git a/security/security.c b/security/security.c
> index 730ac65..c57354c 100644
> --- a/security/security.c
> +++ b/security/security.c
> @@ -810,6 +810,9 @@ int security_file_send_sigiotask(struct task_struct *tsk,
>  
>  int security_file_receive(struct file *file)
>  {
> +
> +	if (unlikely(IS_PRIVATE(file->f_path.dentry->d_inode)))
> +		return 0;
>  	return security_ops->file_receive(file);
>  }

SELinux handles this internally; see its inode_has_perm() function.
Doing it here would prevent any security module checking at all, even of
the struct file, which SELinux does presently do (selinux_file_receive
calls file_has_perm which applies the fd use check and then calls
inode_has_perm on the inode).  Unless you are saying that the
file->f_security field is also not being set correctly.



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

* Re: [RFC PATCH] Security: ignore private inode from security_file_receive
  2015-04-16 13:40 [RFC PATCH] Security: ignore private inode from security_file_receive Seung-Woo Kim
  2015-04-16 13:48 ` Stephen Smalley
@ 2015-04-16 15:35 ` Casey Schaufler
  1 sibling, 0 replies; 4+ messages in thread
From: Casey Schaufler @ 2015-04-16 15:35 UTC (permalink / raw)
  To: Seung-Woo Kim, james.l.morris, serge, linux-security-module,
	linux-kernel
  Cc: sumit.semwal, linaro-mm-sig, jy0922.shim, Casey Schaufler

On 4/16/2015 6:40 AM, Seung-Woo Kim wrote:
> The dma-buf fd from anon_inode can be shared across processes, but
> there is no way to set security permission for the fd. So this
> patch fix just to ignore private inode from security_file_receive.
>
> Signed-off-by: Seung-Woo Kim <sw0312.kim@samsung.com>
> ---
>
> If security like smack is enabled, the dmabuf fd can not be shared between
> processes via unix domain socket. I am not familiar with security, so I am
> not sure that this kind of patch can be acceptable.

If an IS_PRIVATE() check is appropriate, it should be in
smack_file_receive(), not security_file_receive(). Why are you
looking at file->f_path.dentry->d_inode? That's not used in the
Smack access check. You'd want file->f_inode if anything.

Naked-by: Casey Schaufler <casey@schaufler-ca.com>

>
> Is there other option to share dmabuf fd via socket with security check?
>
> Best Regards,
> - Seung-Woo Kim
>
> ---
>  security/security.c |    3 +++
>  1 files changed, 3 insertions(+), 0 deletions(-)
>
> diff --git a/security/security.c b/security/security.c
> index 730ac65..c57354c 100644
> --- a/security/security.c
> +++ b/security/security.c
> @@ -810,6 +810,9 @@ int security_file_send_sigiotask(struct task_struct *tsk,
>  
>  int security_file_receive(struct file *file)
>  {
> +
> +	if (unlikely(IS_PRIVATE(file->f_path.dentry->d_inode)))
> +		return 0;
>  	return security_ops->file_receive(file);
>  }
>  


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

* Re: [RFC PATCH] Security: ignore private inode from security_file_receive
  2015-04-16 13:48 ` Stephen Smalley
@ 2015-04-17  2:00   ` Seung-Woo Kim
  0 siblings, 0 replies; 4+ messages in thread
From: Seung-Woo Kim @ 2015-04-17  2:00 UTC (permalink / raw)
  To: Stephen Smalley
  Cc: james.l.morris, serge, linux-security-module, linux-kernel,
	sumit.semwal, linaro-mm-sig, jy0922.shim, Seung-Woo Kim

Hello,

On 2015년 04월 16일 22:48, Stephen Smalley wrote:
> On 04/16/2015 09:40 AM, Seung-Woo Kim wrote:
>> The dma-buf fd from anon_inode can be shared across processes, but
>> there is no way to set security permission for the fd. So this
>> patch fix just to ignore private inode from security_file_receive.
>>
>> Signed-off-by: Seung-Woo Kim <sw0312.kim@samsung.com>
>> ---
>>
>> If security like smack is enabled, the dmabuf fd can not be shared between
>> processes via unix domain socket. I am not familiar with security, so I am
>> not sure that this kind of patch can be acceptable.
>>
>> Is there other option to share dmabuf fd via socket with security check?
>>
>> Best Regards,
>> - Seung-Woo Kim
>>
>> ---
>>  security/security.c |    3 +++
>>  1 files changed, 3 insertions(+), 0 deletions(-)
>>
>> diff --git a/security/security.c b/security/security.c
>> index 730ac65..c57354c 100644
>> --- a/security/security.c
>> +++ b/security/security.c
>> @@ -810,6 +810,9 @@ int security_file_send_sigiotask(struct task_struct *tsk,
>>  
>>  int security_file_receive(struct file *file)
>>  {
>> +
>> +	if (unlikely(IS_PRIVATE(file->f_path.dentry->d_inode)))
>> +		return 0;
>>  	return security_ops->file_receive(file);
>>  }
> 
> SELinux handles this internally; see its inode_has_perm() function.
> Doing it here would prevent any security module checking at all, even of
> the struct file, which SELinux does presently do (selinux_file_receive
> calls file_has_perm which applies the fd use check and then calls
> inode_has_perm on the inode).  Unless you are saying that the
> file->f_security field is also not being set correctly.

Thanks for the suggestion. I will try to do on smack side.

Best Regards,
- Seung-Woo Kim

> 
> 
> 

-- 
Seung-Woo Kim
Samsung Software R&D Center
--


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

end of thread, other threads:[~2015-04-17  1:59 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-04-16 13:40 [RFC PATCH] Security: ignore private inode from security_file_receive Seung-Woo Kim
2015-04-16 13:48 ` Stephen Smalley
2015-04-17  2:00   ` Seung-Woo Kim
2015-04-16 15:35 ` Casey Schaufler

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox