lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <95d7cf5c-6995-401a-b9de-08b82482b175@ti.com>
Date: Thu, 3 Jul 2025 10:53:37 +0530
From: Chintan Vankar <c-vankar@...com>
To: Jakub Kicinski <kuba@...nel.org>
CC: <andrew+netdev@...n.ch>, <davem@...emloft.net>, <edumazet@...gle.com>,
        <pabeni@...hat.com>, <rogerq@...nel.org>, <horms@...nel.org>,
        <mwalle@...nel.org>, <jacob.e.keller@...el.com>, <jpanis@...libre.com>,
        <s-vadapalli@...com>, <danishanwar@...com>, <netdev@...r.kernel.org>,
        <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH net v2] net: ethernet: ti: am65-cpsw-nuss: Fix skb size by
 accounting for skb_shared_info

Hello Jakub,

On 28/06/25 05:38, Jakub Kicinski wrote:
> On Thu, 26 Jun 2025 10:42:26 +0530 Chintan Vankar wrote:
>> While transitioning from netdev_alloc_ip_align() to build_skb(), memory
>> for the "skb_shared_info" member of an "skb" was not allocated. Fix this
>> by including sizeof(skb_shared_info) in the packet length during
>> allocation.
>>
>> Fixes: 8acacc40f733 ("net: ethernet: ti: am65-cpsw: Add minimal XDP support")
>> Signed-off-by: Chintan Vankar <c-vankar@...com>
>> ---
>>
>> This patch is based on the commit '9caca6ac0e26' of origin/main branch of
>> Linux-net repository.
>>
>> Link to v1:
>> https://lore.kernel.org/r/598f9e77-8212-426b-97ab-427cb8bd4910@ti.com/
>>
>> Changes from v1 to v2:
>> - Updated commit message and code change as suggested by Siddharth
>>    Vadapalli.
>>
>>   drivers/net/ethernet/ti/am65-cpsw-nuss.c | 2 +-
>>   1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/drivers/net/ethernet/ti/am65-cpsw-nuss.c b/drivers/net/ethernet/ti/am65-cpsw-nuss.c
>> index f20d1ff192ef..67fef2ea4900 100644
>> --- a/drivers/net/ethernet/ti/am65-cpsw-nuss.c
>> +++ b/drivers/net/ethernet/ti/am65-cpsw-nuss.c
>> @@ -856,7 +856,7 @@ static struct sk_buff *am65_cpsw_build_skb(void *page_addr,
>>   {
>>   	struct sk_buff *skb;
>>   
>> -	len += AM65_CPSW_HEADROOM;
>> +	len += AM65_CPSW_HEADROOM + SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
>>   
>>   	skb = build_skb(page_addr, len);
> 
> Looks to me like each packet is placed in a full page, isn't it?
> If that's the case the correct value for "buffer size" is PAGE_SIZE


Thanks for reviewing the patch and pointing this out. Since the maximum
packet size received from the wire is AM65_CPSW_MAX_PACKET_SIZE that is
2024 Bytes, after adding headroom and tailroom, the total Bytes will
remain below the minimum page size available that is 4096, it is better
to use PAGE_SIZE.

Regards,
Chintan.

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ