From patchwork Fri Jun 5 03:00:41 2026 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Wei Deng X-Patchwork-Id: 89333 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id B4AD6CD6E75 for ; Fri, 5 Jun 2026 03:00:58 +0000 (UTC) Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) by mx.groups.io with SMTP id smtpd.msgproc01-g2.328.1780628448797538044 for ; Thu, 04 Jun 2026 20:00:49 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=@qualcomm.com header.s=qcppdkim1 header.b=VsUwfjaG; dkim=pass header.i=@oss.qualcomm.com header.s=google header.b=kHDoOBP6; spf=permerror, err=parse error for token &{10 18 %{ir}.%{v}.%{d}.spf.has.pphosted.com}: invalid domain name (domain: oss.qualcomm.com, ip: 205.220.180.131, mailfrom: wei.deng@oss.qualcomm.com) Received: from pps.filterd (m0279873.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 65518XjH1958779 for ; Fri, 5 Jun 2026 03:00:47 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:date:from:message-id:mime-version :subject:to; s=qcppdkim1; bh=BCt1Br881T2uXMcKXY9PnmpumyJW7TOgRh2 iyBHVdFo=; b=VsUwfjaGhJzTXTHXinmZukH82/RLT+5+vqNgWdE+QyYzr2oKrAk XXth68i8pZcjaKRJdnyTh+8cCNLGtx1G6r23KYAv9HXxIDR+SKoMNA1yqhuWxpqs Gen3qpLHAGr03quT2oX85HtSLxETPGrZXTh00Fh1qEaN+SlProI2bmpV1kHVgYgw gi8CjrV4VTfatNefXAKjRs8z9IJNHhez5uPuRGRqkwrTN2B9wTNIgAdCaEL4PWJX 8R04sPSQXg5Ri1zz1ZCszCsxIYJY6sGdPEVgcmgeLHQh5AFB5arutLu8OQXD+8Vn /tmKCKNlUbUhDGE68qKpG79YiKqQdpqk/pQ== Received: from mail-dl1-f69.google.com (mail-dl1-f69.google.com [74.125.82.69]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4ekckptjba-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Fri, 05 Jun 2026 03:00:47 +0000 (GMT) Received: by mail-dl1-f69.google.com with SMTP id a92af1059eb24-1370bd383f2so108119c88.0 for ; Thu, 04 Jun 2026 20:00:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1780628446; x=1781233246; darn=lists.openembedded.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=BCt1Br881T2uXMcKXY9PnmpumyJW7TOgRh2iyBHVdFo=; b=kHDoOBP6syd/wv1A6iuiQszpxZuVor+dVhtqP0OZacY6+pTce2tRbtcVBud7djEs6d HBdHmul3SQkTlTzk4W9QLi2OX0A30CaiPm5xHIE6jh0P7YHZ3BJkQGCyBc7FxrQp6TyW 2xTc84pzYb9KC5O/GL/aTDpalJhjRFWllgmISfbLV/eNisK19Elh9vHqoSR1URwJn6j5 SyBUgoOcBF8lQISY/dqo7WDHbyaWuAXVaVNDVk7lwqk8CZ866NK5cSad/LmAocxqjm5T ZuWJnyFfkziP/8G1FsIFJKOoazf2QTAJZGU8F14ACO2t5d45kZudbcxDmS5CveOFo8jp hP2A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1780628446; x=1781233246; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=BCt1Br881T2uXMcKXY9PnmpumyJW7TOgRh2iyBHVdFo=; b=qg/i4qbRMQwJdofUPFVZgK1Fi5PNXIRACnmNUGVk870HjxGx98R71eCX3FD9XG2/Fh uaGpB+WNq9qLnv5mFEhQBXv9pM955CO0pbPMYYt0hJKKV5QYwE71tErJ0yG0vmA/LqvT t22EAq+kYtP/KSivU64ROSeQxGYhT0ZGFWeEU1e8tfidDubX6NOoZNO0RrFJkQuUy8jB F8ER8ntOw4jQ/0a6JMDE/q1BBT9EQNMbIzO2W4KqCE7TTPnypE4OGoLOk5qJUdtPx6IM /+oR5m/CaTYzPsuPHdS6DvKmhHgp/ibhN2fcqQvkGaAS0YTuksFpwBZ52zK7FvgUtOi7 vSfw== X-Gm-Message-State: AOJu0YwZPLA3pj8jozQr8Avc+g5+DDIkhBaYZG5mKWBJDVdKzOozm1of BY7k5rwI6sSj+fOPUt025ahU4AKR+BZpyTPwVeQHiD8n4K8Cg8IfVy6x1/0G/BFmdqIyIBIpl21 UBqXhv1jPUb8hoMrdkR81sa2lMk5OCeeU+8CkQpMctxtj3yrliTiVrViDwjE1swt6Nnm70FeAgw RKEbED4/11YvV6eMffaA== X-Gm-Gg: Acq92OHSxj27IdI+ti+5yc3cU+RxC3HM8BvQs9QmPRfj7TRpWytohYR58ULk4vM2lzT UdoGJGo5Gx/b7A/qPBssmZLgqxrdwg2hwaP7kvsqPUgon9f/sC8P0qN2udF4sIAtkXp02/UEnBK SJVnJaoDzPWoxTEAIxCuXQyYP2W/Ici+Ep2TCGK2vTSn9itX67FY+KUYtAK/G9tJc+CHLOOepuc I0Fi5j26NeowfB5EMwx3pDEbGtqwgkPi3X0xaTIYSeXQES4Nc1f7LIMtCWSnugaGgcDL0mp0APP ghollP/u6L8YXRUiFPZPJ/wnHdx7DShsQHswo6Z4oaIwjsiE42ukPZRUb3RX/vKvMPX0BwGTmPI KhG9Z0B52k87ztYmYycr5CqtebeS27gL6keUvGW+d/d/6j1uPB8sGzcUJUfF+/FzVrlMFuw/SrF d0CZPdsgg= X-Received: by 2002:a05:7301:169a:b0:2ff:b29b:87b with SMTP id 5a478bee46e88-3077b5fe235mr352068eec.5.1780628446245; Thu, 04 Jun 2026 20:00:46 -0700 (PDT) X-Received: by 2002:a05:7301:169a:b0:2ff:b29b:87b with SMTP id 5a478bee46e88-3077b5fe235mr352047eec.5.1780628445561; Thu, 04 Jun 2026 20:00:45 -0700 (PDT) Received: from hu-weiden-sha.qualcomm.com (i-global052.qualcomm.com. [199.106.103.52]) by smtp.gmail.com with ESMTPSA id 5a478bee46e88-3074dea8e76sm6343643eec.18.2026.06.04.20.00.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 04 Jun 2026 20:00:45 -0700 (PDT) From: Wei Deng To: openembedded-core@lists.openembedded.org Cc: cheng.jiang@oss.qualcomm.com, quic_chezhou@quicinc.com, shuai.zhang@oss.qualcomm.com, mengshi.wu@oss.qualcomm.com, jinwang.li@oss.qualcomm.com, xiuzhuo.shang@oss.qualcomm.com Subject: [PATCH] bluez5: set L2CAP IMTU for OBEX profile listeners Date: Fri, 5 Jun 2026 08:30:41 +0530 Message-Id: <20260605030041.232943-1-wei.deng@oss.qualcomm.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 X-Proofpoint-GUID: D0S9ZMPTR-IpH3yUS_iZZhFJ1YvLf7oL X-Proofpoint-ORIG-GUID: D0S9ZMPTR-IpH3yUS_iZZhFJ1YvLf7oL X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNjA1MDAyNiBTYWx0ZWRfXwtsyi+MatGBm ExuI8f6Z5ni/VdUO6tXWIwiFBiGyfY/VyqcQ2cSXo/M+3XtIbFJXdBnwvXWOngvZntRMkXarTC8 JKddhUNB4YhhzAwd8SDGJ93jS5dUyCjtP/0rCpRO7WAGeTIrRcIFHyGRCxnb3RvY453Ta0Q1/Qu KPKfeNiUiBo09BZJMyH5axTjyjaIETHVmHKfXsgLvieG0T8K9ppAlubiGF2+LsgGwTGto0BWGbe XxMCFuSulPcxQA70Edj7PwqUaK+KUBXzmUsjAqEGTB530q+pxy14LjX5SQeOpD6dY8F8P20cm3n DkaCS+d94l7EM8Ffkad6OORbj7GudgpEVw5mXY4cJpJnVVECODf9UHOo2SmR8J9GaRdYk8g3BUL QYMEwpKyZJy3huzoAjHMoGq94uWYKMoscKzEwd9bHonACeB4hg37gIeEsybLbMczbL691iuPkQe J7TSVJmADuILb05QO/w== X-Authority-Analysis: v=2.4 cv=H9jrBeYi c=1 sm=1 tr=0 ts=6a223bdf cx=c_pps a=kVLUcbK0zfr7ocalXnG1qA==:117 a=b9+bayejhc3NMeqCNyeLQQ==:17 a=FelO9ux0wxsA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=rJkE3RaqiGZ5pbrm-msn:22 a=NEAV23lmAAAA:8 a=EUspDBNiAAAA:8 a=dOK3wYaXzV_A1W3SHmkA:9 a=vr4QvYf-bLy2KjpDp97w:22 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.125,FMLib:17.12.100.49 definitions=2026-06-04_07,2026-05-28_03,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 adultscore=0 phishscore=0 bulkscore=0 lowpriorityscore=0 spamscore=0 clxscore=1015 impostorscore=0 suspectscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605210000 definitions=main-2606050026 List-Id: X-Webhook-Received: from 45-33-107-173.ip.linodeusercontent.com [45.33.107.173] by aws-us-west-2-korg-lkml-1.web.codeaurora.org with HTTPS for ; Fri, 05 Jun 2026 03:00:58 -0000 X-Groupsio-URL: https://lists.openembedded.org/g/openembedded-core/message/238137 Backport upstream fix that adds an imtu field to default_settings for OBEX profiles (OPP, FTP, PBAP, MAS, MNS) and applies it to the L2CAP listening socket via bt_io_set(). Without this, the listening socket advertises the L2CAP minimum of 672 bytes in L2CAP_CONFIGURATION_RSP, limiting the peer's outgoing PDU size and degrading Rx throughput. Upstream-Status: Backport [bluez/bluez@646014a] Signed-off-by: Wei Deng --- meta/recipes-connectivity/bluez5/bluez5.inc | 1 + ...2CAP-IMTU-for-OBEX-profile-listeners.patch | 118 ++++++++++++++++++ 2 files changed, 119 insertions(+) create mode 100644 meta/recipes-connectivity/bluez5/bluez5/0001-profile-Set-L2CAP-IMTU-for-OBEX-profile-listeners.patch diff --git a/meta/recipes-connectivity/bluez5/bluez5.inc b/meta/recipes-connectivity/bluez5/bluez5.inc index e827d0a6d7..71bceddb21 100644 --- a/meta/recipes-connectivity/bluez5/bluez5.inc +++ b/meta/recipes-connectivity/bluez5/bluez5.inc @@ -72,6 +72,7 @@ SRC_URI = "${KERNELORG_MIRROR}/linux/bluetooth/bluez-${PV}.tar.xz \ file://0001-tools-Work-around-broken-stdin-handling-in-home-made.patch \ file://0001-gatt-client-Fix-use-after-free-caused-by-reentrant-c.patch \ file://0001-transport-Fix-set-volume-failure-with-invalid-device.patch \ + file://0001-profile-Set-L2CAP-IMTU-for-OBEX-profile-listeners.patch \ " S = "${UNPACKDIR}/bluez-${PV}" diff --git a/meta/recipes-connectivity/bluez5/bluez5/0001-profile-Set-L2CAP-IMTU-for-OBEX-profile-listeners.patch b/meta/recipes-connectivity/bluez5/bluez5/0001-profile-Set-L2CAP-IMTU-for-OBEX-profile-listeners.patch new file mode 100644 index 0000000000..332b11464e --- /dev/null +++ b/meta/recipes-connectivity/bluez5/bluez5/0001-profile-Set-L2CAP-IMTU-for-OBEX-profile-listeners.patch @@ -0,0 +1,118 @@ +From 646014a6a246fe99df27da12d2de7bcd2e04d0df Mon Sep 17 00:00:00 2001 +From: Wei Deng +Date: Thu, 4 Jun 2026 15:00:24 +0530 +Subject: [PATCH] profile: Set L2CAP IMTU for OBEX profile listeners + +The default_settings entries for OBEX profiles (OPP, FTP, PBAP, MAS, +MNS) have no imtu field, so ext_start_servers() creates the L2CAP +listening socket without an explicit IMTU. This causes the socket to +advertise the L2CAP minimum of 672 bytes in L2CAP_CONFIGURATION_RSP, +limiting the peer's outgoing PDU size and degrading Rx throughput. + +Add an imtu field to default_settings and set it to 32767 for all +OBEX profiles that use L2CAP. Copy the value in ext_set_defaults() +and apply it to the listening socket via bt_io_set() after +bt_io_listen() succeeds. + +Signed-off-by: Wei Deng +Upstream-Status: Backport [https://github.com/bluez/bluez/commit/646014a6a246fe99df27da12d2de7bcd2e04d0df] +--- + src/profile.c | 19 +++++++++++++++++-- + 1 file changed, 17 insertions(+), 2 deletions(-) + +diff --git a/src/profile.c b/src/profile.c +index dfc5f7161..65df0f7a0 100644 +--- a/src/profile.c ++++ b/src/profile.c +@@ -55,6 +55,8 @@ + #define MAS_DEFAULT_CHANNEL 16 + #define MNS_DEFAULT_CHANNEL 17 + ++#define BT_RX_MTU 32767 ++ + #define BTD_PROFILE_PSM_AUTO -1 + #define BTD_PROFILE_CHAN_AUTO -1 + +@@ -678,6 +680,7 @@ struct ext_profile { + + uint16_t version; + uint16_t features; ++ uint16_t imtu; + + GSList *records; + GSList *servers; +@@ -1423,6 +1426,9 @@ static uint32_t ext_start_servers(struct ext_profile *ext, + if (psm == 0) + bt_io_get(io, NULL, BT_IO_OPT_PSM, &psm, + BT_IO_OPT_INVALID); ++ if (ext->imtu) ++ bt_io_set(io, NULL, BT_IO_OPT_IMTU, ext->imtu, ++ BT_IO_OPT_INVALID); + l2cap->io = io; + l2cap->proto = BTPROTO_L2CAP; + l2cap->psm = psm; +@@ -2075,6 +2081,7 @@ static struct default_settings { + struct ext_io *rfcomm); + uint16_t version; + uint16_t features; ++ uint16_t imtu; + } defaults[] = { + { + .uuid = SPP_UUID, +@@ -2142,6 +2149,7 @@ static struct default_settings { + .authorize = false, + .get_record = get_opp_record, + .version = 0x0102, ++ .imtu = BT_RX_MTU, + }, { + .uuid = OBEX_FTP_UUID, + .name = "File Transfer", +@@ -2151,6 +2159,7 @@ static struct default_settings { + .authorize = true, + .get_record = get_ftp_record, + .version = 0x0103, ++ .imtu = BT_RX_MTU, + }, { + .uuid = OBEX_SYNC_UUID, + .name = "Synchronization", +@@ -2167,6 +2176,7 @@ static struct default_settings { + .authorize = true, + .get_record = get_pse_record, + .version = 0x0101, ++ .imtu = BT_RX_MTU, + }, { + .uuid = OBEX_PCE_UUID, + .name = "Phone Book Access Client", +@@ -2182,7 +2192,8 @@ static struct default_settings { + .mode = BT_IO_MODE_ERTM, + .authorize = true, + .get_record = get_mas_record, +- .version = 0x0100 ++ .version = 0x0100, ++ .imtu = BT_RX_MTU, + }, { + .uuid = OBEX_MNS_UUID, + .name = "Message Notification", +@@ -2191,7 +2202,8 @@ static struct default_settings { + .mode = BT_IO_MODE_ERTM, + .authorize = true, + .get_record = get_mns_record, +- .version = 0x0104 ++ .version = 0x0104, ++ .imtu = BT_RX_MTU, + }, + }; + +@@ -2249,6 +2261,9 @@ static void ext_set_defaults(struct ext_profile *ext) + if (settings->features) + ext->features = settings->features; + ++ if (settings->imtu) ++ ext->imtu = settings->imtu; ++ + if (settings->name) + ext->name = g_strdup(settings->name); + } +-- +2.34.1 +