All of lore.kernel.org
 help / color / mirror / Atom feed
* CVE-2024-49995: tipc: guard against string buffer overrun
@ 2024-10-21 18:03 Greg Kroah-Hartman
  2025-04-24  6:11 ` Harshit Mogalapalli
  0 siblings, 1 reply; 6+ messages in thread
From: Greg Kroah-Hartman @ 2024-10-21 18:03 UTC (permalink / raw)
  To: linux-cve-announce; +Cc: Greg Kroah-Hartman

Description
===========

In the Linux kernel, the following vulnerability has been resolved:

tipc: guard against string buffer overrun

Smatch reports that copying media_name and if_name to name_parts may
overwrite the destination.

 .../bearer.c:166 bearer_name_validate() error: strcpy() 'media_name' too large for 'name_parts->media_name' (32 vs 16)
 .../bearer.c:167 bearer_name_validate() error: strcpy() 'if_name' too large for 'name_parts->if_name' (1010102 vs 16)

This does seem to be the case so guard against this possibility by using
strscpy() and failing if truncation occurs.

Introduced by commit b97bf3fd8f6a ("[TIPC] Initial merge")

Compile tested only.

The Linux kernel CVE team has assigned CVE-2024-49995 to this issue.


Affected and fixed versions
===========================

	Fixed in 5.10.227 with commit e2b2558971e0
	Fixed in 5.15.168 with commit 54dae0e9063e
	Fixed in 6.1.113 with commit 80c0be7bcf94
	Fixed in 6.6.55 with commit 12d26aa7fd3c
	Fixed in 6.10.14 with commit 2ed7f42dfd3e
	Fixed in 6.11.3 with commit a18c7b239d02
	Fixed in 6.12-rc1 with commit 6555a2a9212b

Please see https://www.kernel.org for a full list of currently supported
kernel versions by the kernel community.

Unaffected versions might change over time as fixes are backported to
older supported kernel versions.  The official CVE entry at
	https://cve.org/CVERecord/?id=CVE-2024-49995
will be updated if fixes are backported, please check that for the most
up to date information about this issue.


Affected files
==============

The file(s) affected by this issue are:
	net/tipc/bearer.c


Mitigation
==========

The Linux kernel CVE team recommends that you update to the latest
stable kernel version for this, and many other bugfixes.  Individual
changes are never tested alone, but rather are part of a larger kernel
release.  Cherry-picking individual commits is not recommended or
supported by the Linux kernel community at all.  If however, updating to
the latest release is impossible, the individual changes to resolve this
issue can be found at these commits:
	https://git.kernel.org/stable/c/e2b2558971e02ca33eb637a8350d68a48b3e8e46
	https://git.kernel.org/stable/c/54dae0e9063ed23c9acf8d5ab9b18d3426a8ac18
	https://git.kernel.org/stable/c/80c0be7bcf940ce9308311575c3aff8983c9b97a
	https://git.kernel.org/stable/c/12d26aa7fd3cbdbc5149b6e516563478d575026e
	https://git.kernel.org/stable/c/2ed7f42dfd3edb387034128ca5b0f639836d4ddd
	https://git.kernel.org/stable/c/a18c7b239d02aafb791ae2c45226f6bb40641792
	https://git.kernel.org/stable/c/6555a2a9212be6983d2319d65276484f7c5f431a

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

* Re: CVE-2024-49995: tipc: guard against string buffer overrun
  2024-10-21 18:03 CVE-2024-49995: tipc: guard against string buffer overrun Greg Kroah-Hartman
@ 2025-04-24  6:11 ` Harshit Mogalapalli
  2025-04-24  7:30   ` Simon Horman
  2025-04-24  8:17   ` Dan Carpenter
  0 siblings, 2 replies; 6+ messages in thread
From: Harshit Mogalapalli @ 2025-04-24  6:11 UTC (permalink / raw)
  To: cve, linux-kernel, linux-cve-announce, Simon Horman,
	Dan Carpenter
  Cc: Greg Kroah-Hartman

Hi,

On 21/10/24 23:33, Greg Kroah-Hartman wrote:
> Description
> ===========
> 
> In the Linux kernel, the following vulnerability has been resolved:
> 
> tipc: guard against string buffer overrun
> 
> Smatch reports that copying media_name and if_name to name_parts may
> overwrite the destination.
> 
>   .../bearer.c:166 bearer_name_validate() error: strcpy() 'media_name' too large for 'name_parts->media_name' (32 vs 16)
>   .../bearer.c:167 bearer_name_validate() error: strcpy() 'if_name' too large for 'name_parts->if_name' (1010102 vs 16)
> 
> This does seem to be the case so guard against this possibility by using
> strscpy() and failing if truncation occurs.
> 
> Introduced by commit b97bf3fd8f6a ("[TIPC] Initial merge")
> 
> Compile tested only.
> 
> The Linux kernel CVE team has assigned CVE-2024-49995 to this issue.
> 
> 

Looking at the fix commit with more lines around the fix:

https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=6555a2a9212be6983d2319d65276484f7c5f431a&context=30


  	/* validate component parts of bearer name */
  	if ((media_len <= 1) || (media_len > TIPC_MAX_MEDIA_NAME) ||
  	    (if_len <= 1) || (if_len > TIPC_MAX_IF_NAME))
  		return 0;

  	/* return bearer name components, if necessary */
  	if (name_parts) {
-		strcpy(name_parts->media_name, media_name);
-		strcpy(name_parts->if_name, if_name);
+		if (strscpy(name_parts->media_name, media_name,
+			    TIPC_MAX_MEDIA_NAME) < 0)
+			return 0;
+		if (strscpy(name_parts->if_name, if_name,
+			    TIPC_MAX_IF_NAME) < 0)
+			return 0;
  	}
  	return 1;



both media_len and if_len have validation checks above the 
if(name_parts) check. So I think this patch just silences the static 
checker warnings.

Simon/Dan , could you please help confirming that ?

Thanks,
Harshit

> Affected and fixed versions
> ===========================
> 
> 	Fixed in 5.10.227 with commit e2b2558971e0
> 	Fixed in 5.15.168 with commit 54dae0e9063e
> 	Fixed in 6.1.113 with commit 80c0be7bcf94
> 	Fixed in 6.6.55 with commit 12d26aa7fd3c
> 	Fixed in 6.10.14 with commit 2ed7f42dfd3e
> 	Fixed in 6.11.3 with commit a18c7b239d02
> 	Fixed in 6.12-rc1 with commit 6555a2a9212b
> 
> Please see https://www.kernel.org for a full list of currently supported
> kernel versions by the kernel community.
> 
> Unaffected versions might change over time as fixes are backported to
> older supported kernel versions.  The official CVE entry at
> 	https://cve.org/CVERecord/?id=CVE-2024-49995
> will be updated if fixes are backported, please check that for the most
> up to date information about this issue.
> 
> 
> Affected files
> ==============
> 
> The file(s) affected by this issue are:
> 	net/tipc/bearer.c
> 
> 
> Mitigation
> ==========
> 
> The Linux kernel CVE team recommends that you update to the latest
> stable kernel version for this, and many other bugfixes.  Individual
> changes are never tested alone, but rather are part of a larger kernel
> release.  Cherry-picking individual commits is not recommended or
> supported by the Linux kernel community at all.  If however, updating to
> the latest release is impossible, the individual changes to resolve this
> issue can be found at these commits:
> 	https://git.kernel.org/stable/c/e2b2558971e02ca33eb637a8350d68a48b3e8e46
> 	https://git.kernel.org/stable/c/54dae0e9063ed23c9acf8d5ab9b18d3426a8ac18
> 	https://git.kernel.org/stable/c/80c0be7bcf940ce9308311575c3aff8983c9b97a
> 	https://git.kernel.org/stable/c/12d26aa7fd3cbdbc5149b6e516563478d575026e
> 	https://git.kernel.org/stable/c/2ed7f42dfd3edb387034128ca5b0f639836d4ddd
> 	https://git.kernel.org/stable/c/a18c7b239d02aafb791ae2c45226f6bb40641792
> 	https://git.kernel.org/stable/c/6555a2a9212be6983d2319d65276484f7c5f431a


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

* Re: CVE-2024-49995: tipc: guard against string buffer overrun
  2025-04-24  6:11 ` Harshit Mogalapalli
@ 2025-04-24  7:30   ` Simon Horman
  2025-04-24  8:17   ` Dan Carpenter
  1 sibling, 0 replies; 6+ messages in thread
From: Simon Horman @ 2025-04-24  7:30 UTC (permalink / raw)
  To: Harshit Mogalapalli
  Cc: cve, linux-kernel, linux-cve-announce, Dan Carpenter,
	Greg Kroah-Hartman, netdev

- me at corigine.com
+ netdev

On Thu, Apr 24, 2025 at 11:41:01AM +0530, Harshit Mogalapalli wrote:
> Hi,
> 
> On 21/10/24 23:33, Greg Kroah-Hartman wrote:
> > Description
> > ===========
> > 
> > In the Linux kernel, the following vulnerability has been resolved:
> > 
> > tipc: guard against string buffer overrun
> > 
> > Smatch reports that copying media_name and if_name to name_parts may
> > overwrite the destination.
> > 
> >   .../bearer.c:166 bearer_name_validate() error: strcpy() 'media_name' too large for 'name_parts->media_name' (32 vs 16)
> >   .../bearer.c:167 bearer_name_validate() error: strcpy() 'if_name' too large for 'name_parts->if_name' (1010102 vs 16)
> > 
> > This does seem to be the case so guard against this possibility by using
> > strscpy() and failing if truncation occurs.
> > 
> > Introduced by commit b97bf3fd8f6a ("[TIPC] Initial merge")
> > 
> > Compile tested only.
> > 
> > The Linux kernel CVE team has assigned CVE-2024-49995 to this issue.
> > 
> > 
> 
> Looking at the fix commit with more lines around the fix:
> 
> https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=6555a2a9212be6983d2319d65276484f7c5f431a&context=30
> 
> 
>  	/* validate component parts of bearer name */
>  	if ((media_len <= 1) || (media_len > TIPC_MAX_MEDIA_NAME) ||
>  	    (if_len <= 1) || (if_len > TIPC_MAX_IF_NAME))
>  		return 0;
> 
>  	/* return bearer name components, if necessary */
>  	if (name_parts) {
> -		strcpy(name_parts->media_name, media_name);
> -		strcpy(name_parts->if_name, if_name);
> +		if (strscpy(name_parts->media_name, media_name,
> +			    TIPC_MAX_MEDIA_NAME) < 0)
> +			return 0;
> +		if (strscpy(name_parts->if_name, if_name,
> +			    TIPC_MAX_IF_NAME) < 0)
> +			return 0;
>  	}
>  	return 1;
> 
> 
> 
> both media_len and if_len have validation checks above the if(name_parts)
> check. So I think this patch just silences the static checker warnings.
> 
> Simon/Dan , could you please help confirming that ?

Thanks Harshit,

Looking over this with fresh eyes this morning I agree with your analysis.

I can't be sure what I was thinking regarding this being a bug when I
posted the patch in August. But that it was for net-next, rather than net,
and had no Fixes tag, indicates that I did not feel that it was a bug fix at
the time.

https://lore.kernel.org/netdev/20240801-tipic-overrun-v2-1-c5b869d1f074@kernel.org/

In any case, I don't think it is a bug fix now.


> 
> Thanks,
> Harshit
> 
> > Affected and fixed versions
> > ===========================
> > 
> > 	Fixed in 5.10.227 with commit e2b2558971e0
> > 	Fixed in 5.15.168 with commit 54dae0e9063e
> > 	Fixed in 6.1.113 with commit 80c0be7bcf94
> > 	Fixed in 6.6.55 with commit 12d26aa7fd3c
> > 	Fixed in 6.10.14 with commit 2ed7f42dfd3e
> > 	Fixed in 6.11.3 with commit a18c7b239d02
> > 	Fixed in 6.12-rc1 with commit 6555a2a9212b
> > 
> > Please see https://www.kernel.org for a full list of currently supported
> > kernel versions by the kernel community.
> > 
> > Unaffected versions might change over time as fixes are backported to
> > older supported kernel versions.  The official CVE entry at
> > 	https://cve.org/CVERecord/?id=CVE-2024-49995
> > will be updated if fixes are backported, please check that for the most
> > up to date information about this issue.
> > 
> > 
> > Affected files
> > ==============
> > 
> > The file(s) affected by this issue are:
> > 	net/tipc/bearer.c
> > 
> > 
> > Mitigation
> > ==========
> > 
> > The Linux kernel CVE team recommends that you update to the latest
> > stable kernel version for this, and many other bugfixes.  Individual
> > changes are never tested alone, but rather are part of a larger kernel
> > release.  Cherry-picking individual commits is not recommended or
> > supported by the Linux kernel community at all.  If however, updating to
> > the latest release is impossible, the individual changes to resolve this
> > issue can be found at these commits:
> > 	https://git.kernel.org/stable/c/e2b2558971e02ca33eb637a8350d68a48b3e8e46
> > 	https://git.kernel.org/stable/c/54dae0e9063ed23c9acf8d5ab9b18d3426a8ac18
> > 	https://git.kernel.org/stable/c/80c0be7bcf940ce9308311575c3aff8983c9b97a
> > 	https://git.kernel.org/stable/c/12d26aa7fd3cbdbc5149b6e516563478d575026e
> > 	https://git.kernel.org/stable/c/2ed7f42dfd3edb387034128ca5b0f639836d4ddd
> > 	https://git.kernel.org/stable/c/a18c7b239d02aafb791ae2c45226f6bb40641792
> > 	https://git.kernel.org/stable/c/6555a2a9212be6983d2319d65276484f7c5f431a
> 

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

* Re: CVE-2024-49995: tipc: guard against string buffer overrun
  2025-04-24  6:11 ` Harshit Mogalapalli
  2025-04-24  7:30   ` Simon Horman
@ 2025-04-24  8:17   ` Dan Carpenter
  2025-04-24  8:45     ` Harshit Mogalapalli
  1 sibling, 1 reply; 6+ messages in thread
From: Dan Carpenter @ 2025-04-24  8:17 UTC (permalink / raw)
  To: Harshit Mogalapalli
  Cc: cve, linux-kernel, linux-cve-announce, Simon Horman,
	Dan Carpenter, Greg Kroah-Hartman

On Thu, Apr 24, 2025 at 11:41:01AM +0530, Harshit Mogalapalli wrote:
> Hi,
> 
> On 21/10/24 23:33, Greg Kroah-Hartman wrote:
> > Description
> > ===========
> > 
> > In the Linux kernel, the following vulnerability has been resolved:
> > 
> > tipc: guard against string buffer overrun
> > 
> > Smatch reports that copying media_name and if_name to name_parts may
> > overwrite the destination.
> > 
> >   .../bearer.c:166 bearer_name_validate() error: strcpy() 'media_name' too large for 'name_parts->media_name' (32 vs 16)
> >   .../bearer.c:167 bearer_name_validate() error: strcpy() 'if_name' too large for 'name_parts->if_name' (1010102 vs 16)
> > 
> > This does seem to be the case so guard against this possibility by using
> > strscpy() and failing if truncation occurs.
> > 
> > Introduced by commit b97bf3fd8f6a ("[TIPC] Initial merge")
> > 
> > Compile tested only.
> > 
> > The Linux kernel CVE team has assigned CVE-2024-49995 to this issue.
> > 
> > 
> 
> Looking at the fix commit with more lines around the fix:
> 
> https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=6555a2a9212be6983d2319d65276484f7c5f431a&context=30
> 
> 
>  	/* validate component parts of bearer name */
>  	if ((media_len <= 1) || (media_len > TIPC_MAX_MEDIA_NAME) ||
>  	    (if_len <= 1) || (if_len > TIPC_MAX_IF_NAME))
>  		return 0;
> 
>  	/* return bearer name components, if necessary */
>  	if (name_parts) {
> -		strcpy(name_parts->media_name, media_name);
> -		strcpy(name_parts->if_name, if_name);
> +		if (strscpy(name_parts->media_name, media_name,
> +			    TIPC_MAX_MEDIA_NAME) < 0)
> +			return 0;
> +		if (strscpy(name_parts->if_name, if_name,
> +			    TIPC_MAX_IF_NAME) < 0)
> +			return 0;
>  	}
>  	return 1;
> 
> 
> 
> both media_len and if_len have validation checks above the if(name_parts)
> check. So I think this patch just silences the static checker warnings.
> 
> Simon/Dan , could you please help confirming that ?

Correct.  The "validate component parts of bearer name" checks are
sufficient.  This will not affect runtime.

regards,
dan carpenter


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

* Re: CVE-2024-49995: tipc: guard against string buffer overrun
  2025-04-24  8:17   ` Dan Carpenter
@ 2025-04-24  8:45     ` Harshit Mogalapalli
  2025-04-24 13:44       ` Greg Kroah-Hartman
  0 siblings, 1 reply; 6+ messages in thread
From: Harshit Mogalapalli @ 2025-04-24  8:45 UTC (permalink / raw)
  To: Dan Carpenter, Simon Horman, Greg Kroah-Hartman
  Cc: cve, linux-kernel, linux-cve-announce, Simon Horman,
	Dan Carpenter, netdev

Hi,


On 24/04/25 13:47, Dan Carpenter wrote:
> On Thu, Apr 24, 2025 at 11:41:01AM +0530, Harshit Mogalapalli wrote:
...
>>
>> https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=6555a2a9212be6983d2319d65276484f7c5f431a&context=30
>>
>>
>>   	/* validate component parts of bearer name */
>>   	if ((media_len <= 1) || (media_len > TIPC_MAX_MEDIA_NAME) ||
>>   	    (if_len <= 1) || (if_len > TIPC_MAX_IF_NAME))
>>   		return 0;
>>
>>   	/* return bearer name components, if necessary */
>>   	if (name_parts) {
>> -		strcpy(name_parts->media_name, media_name);
>> -		strcpy(name_parts->if_name, if_name);
>> +		if (strscpy(name_parts->media_name, media_name,
>> +			    TIPC_MAX_MEDIA_NAME) < 0)
>> +			return 0;
>> +		if (strscpy(name_parts->if_name, if_name,
>> +			    TIPC_MAX_IF_NAME) < 0)
>> +			return 0;
>>   	}
>>   	return 1;
>>
>>
>>
>> both media_len and if_len have validation checks above the if(name_parts)
>> check. So I think this patch just silences the static checker warnings.
>>
>> Simon/Dan , could you please help confirming that ?
> 
> Correct.  The "validate component parts of bearer name" checks are
> sufficient.  This will not affect runtime.
> 

Thanks a lot Dan and Simon for confirming this.

Greg: Should we get this CVE-2024-49995 revoked ?


Regards,
Harshit
> regards,
> dan carpenter
> 


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

* Re: CVE-2024-49995: tipc: guard against string buffer overrun
  2025-04-24  8:45     ` Harshit Mogalapalli
@ 2025-04-24 13:44       ` Greg Kroah-Hartman
  0 siblings, 0 replies; 6+ messages in thread
From: Greg Kroah-Hartman @ 2025-04-24 13:44 UTC (permalink / raw)
  To: Harshit Mogalapalli
  Cc: Dan Carpenter, Simon Horman, cve, linux-kernel,
	linux-cve-announce, Simon Horman, Dan Carpenter, netdev

On Thu, Apr 24, 2025 at 02:15:43PM +0530, Harshit Mogalapalli wrote:
> Hi,
> 
> 
> On 24/04/25 13:47, Dan Carpenter wrote:
> > On Thu, Apr 24, 2025 at 11:41:01AM +0530, Harshit Mogalapalli wrote:
> ...
> > > 
> > > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=6555a2a9212be6983d2319d65276484f7c5f431a&context=30
> > > 
> > > 
> > >   	/* validate component parts of bearer name */
> > >   	if ((media_len <= 1) || (media_len > TIPC_MAX_MEDIA_NAME) ||
> > >   	    (if_len <= 1) || (if_len > TIPC_MAX_IF_NAME))
> > >   		return 0;
> > > 
> > >   	/* return bearer name components, if necessary */
> > >   	if (name_parts) {
> > > -		strcpy(name_parts->media_name, media_name);
> > > -		strcpy(name_parts->if_name, if_name);
> > > +		if (strscpy(name_parts->media_name, media_name,
> > > +			    TIPC_MAX_MEDIA_NAME) < 0)
> > > +			return 0;
> > > +		if (strscpy(name_parts->if_name, if_name,
> > > +			    TIPC_MAX_IF_NAME) < 0)
> > > +			return 0;
> > >   	}
> > >   	return 1;
> > > 
> > > 
> > > 
> > > both media_len and if_len have validation checks above the if(name_parts)
> > > check. So I think this patch just silences the static checker warnings.
> > > 
> > > Simon/Dan , could you please help confirming that ?
> > 
> > Correct.  The "validate component parts of bearer name" checks are
> > sufficient.  This will not affect runtime.
> > 
> 
> Thanks a lot Dan and Simon for confirming this.
> 
> Greg: Should we get this CVE-2024-49995 revoked ?

Yup, now rejected, thanks for the review!

greg k-h

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

end of thread, other threads:[~2025-04-24 13:44 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-21 18:03 CVE-2024-49995: tipc: guard against string buffer overrun Greg Kroah-Hartman
2025-04-24  6:11 ` Harshit Mogalapalli
2025-04-24  7:30   ` Simon Horman
2025-04-24  8:17   ` Dan Carpenter
2025-04-24  8:45     ` Harshit Mogalapalli
2025-04-24 13:44       ` Greg Kroah-Hartman

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.