Received: by 2002:ab2:7a09:0:b0:1f8:46dc:890e with SMTP id k9csp225732lqo; Wed, 15 May 2024 12:27:07 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCV0p/o0KKHoJIbnLkKhCE0bxKyw13E8Q/mgPSUUe6i4fheQ8JMkFJyD+REQjv1Mucukpik3tto/j6oRx/P9qmv9HdmG8r/UP202iuapZA== X-Google-Smtp-Source: AGHT+IEGOfkqgMjtPjirJP0CR1p/vjnSVMO6jMvnU83eQkk8p5EXljT1KwZxXTteO/56WvSWDCms X-Received: by 2002:a05:6102:d91:b0:47b:b9cb:c7e9 with SMTP id ada2fe7eead31-48077e11068mr16465861137.16.1715801227298; Wed, 15 May 2024 12:27:07 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715801227; cv=pass; d=google.com; s=arc-20160816; b=Vb0R7EhMb8NQSUG4GjDmVI7gKJBIRcSY3uasqXLTH/RwVBcd7FtTbJbJU4TCkX4iUF 9dEPsAcsg+J1mRpE8lgjvtzypTNdpkA76KIWFeJ1mOs39dejEKAFj2+p1LSgNHEMcKe5 beN/PH1ZLUejGJ4rLUwR7jU/+zGNciViDlLRg+SHseoIVPmpE3EK5dVwtR5YGNhHfEPp MQrok/C6DPT0tGGeaIaTr99JFIA5mnPxyTxcs/oGtR7VYEKq9/QXuGTBvJBr6GcSNqKX WDzyip/5/rTCPGIhh/kXnfzfsi/gO1QkIV8vgxXUssPizv4JZi8/mGtrrbTSlcI2EdPv TY7A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:to:from :dkim-signature; bh=fRZpuxwFEOvg09p+Q2WE9kzA3AmLcczjNUFnxTkrxog=; fh=4lGQI6056MBa4/oovMyIYaKLn+Wz/24RGvUivMmQP8E=; b=hC97LVOxMMIUa9NDEZbWHSSIyCULdBysw9ewXGwbnsDIlN2/BSo9uv66GixJaS7QEz w4LtZgFMLyZ8RR7gIs0XIDlr+onmqlPOXhyTpbm2CROuXfFFYafnJFeNRqTvq0V1FE0F 3UqNMZKU6fgZKnGldJJexZX2aBHUk6vr9XJB0cHjRpyt7dag015H+IpIsmPy1D/W9uox ORD40C8mvk3wYHus3cpNe8QLidL+A92x3ysXMizyUrvnLGxyajVDSHt/CjvLP83c4UsX BctnTWW1u9fA9Zv9M+thDLoiHuH4yQjupClw9n8oiTkapNRuWAyMHPoWa7nJTwHo492x Mwbw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=jQ8tDums; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-bluetooth+bounces-4658-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-4658-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id a1e0cc1a2514c-7f9003e0afesi2376908241.227.2024.05.15.12.27.07 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 15 May 2024 12:27:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth+bounces-4658-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=jQ8tDums; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-bluetooth+bounces-4658-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-4658-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id CC2B51C20A66 for ; Wed, 15 May 2024 19:27:06 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id B29181598EC; Wed, 15 May 2024 19:27:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="jQ8tDums" X-Original-To: linux-bluetooth@vger.kernel.org Received: from mail-vs1-f46.google.com (mail-vs1-f46.google.com [209.85.217.46]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7661A3219F for ; Wed, 15 May 2024 19:26:59 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.217.46 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715801221; cv=none; b=VZX2PfnpPk44WI7FypTrbgdOYePY10LlqZByINLGzuDaCyUAYorm5breuFFRXYUdfm5+bRSmtSsdqG5uqkG50R9scfShqpLjg/h4GLFlEvlAkuU0N6EBwtBgMKdHvu3qKb0AP9pzrqm46DC0JzwXv/GMsMBN/bfU0KPx7C9jwnM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715801221; c=relaxed/simple; bh=KZpRgbYuxdWNcGavY9gyEHFBpjpl4ww0RmFQh403id4=; h=From:To:Subject:Date:Message-ID:MIME-Version; b=lUqnepxS4VaZq55/oakjFg2xDxt/IPZ1+oQ1wi+wa1MYwQq2t3b6dJIOyRYJHUPBPNaZaPJoVpqtVtrYQdyWQSwkwJaKnibVFY04axqImqaSMs9sXzbvREtarIGSImnqFzX+wZl8gf8gDBUZQfnHuu3utOkdDzu/fZoUwVvG7Rw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=jQ8tDums; arc=none smtp.client-ip=209.85.217.46 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-vs1-f46.google.com with SMTP id ada2fe7eead31-481e99a2c55so1364034137.3 for ; Wed, 15 May 2024 12:26:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1715801217; x=1716406017; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:from:to:cc:subject:date:message-id:reply-to; bh=fRZpuxwFEOvg09p+Q2WE9kzA3AmLcczjNUFnxTkrxog=; b=jQ8tDumsDDctEvf10Q+Hf54OVbQg3wmWygueTJy5E6ldEPc2fruY6CXUDu7uPUXr7n OtsO/NblOogLYyVWXHbl2RANB8xNBEOZUTiI1v+34xkeSeu3toUvX9YEmz3UJdvaxHlm n9grFcxfApYtQiMrvrJdYuaVrj9DDSG6zGAoUr0UcMgQwB3phE96R+iHeVEElIBWh1pr g9lT/VGLzFz6S1B0zQmqx+59MbRw7oUrplWzKPxcR69b6bKqejcIUT9slRwol5pFWJ82 c2P4J5pXaHPBRWAa01GIAe0JJ2AI2vJlJZfC+BaXLbTA7DsmBGIpHv1BfJ2djtTTxVd0 FlmA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1715801217; x=1716406017; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=fRZpuxwFEOvg09p+Q2WE9kzA3AmLcczjNUFnxTkrxog=; b=OydnFWyx8VtCmNW/f6I1HyKhCfGBgP6yZWYKXiMhvFcxDACrbxGqYKkyUaA+bfDJBV VjevFJDlIOmeYtH0m8qdKypMw6dhTYd8G/XssGiGKGQMIdA7VJ56VftrZwolCBWYEiPq vwC1rdWHgjK0viOZgVWvqBrtyMGKT/jz5teoTgPjHEM1F2ZGDSb2ooRh920TAxoHjbY1 v/DhPdHxZZYYNxY6ckCAaHN5+PELLYXLW4p5hN+dr4zDliUXQBcvUqCKWii0zOUIsNqK 08JzIuuj8lZq+MYoSyXP7tQDKLV63CIJJ7TrB1l3td5iXcI6m6bNJnQudQyQnWZ8ai9u XYcg== X-Gm-Message-State: AOJu0Yy0zkCWcimvbqQGvbsfhFRPVgs7/P887syewBfdRpZkNOzWO2uq rWF8drqkyBExjwiXTMEliNbOgYNdLy6NsEBxxLYuyE8yxJ/wiWVLTYrH3Q== X-Received: by 2002:a05:6102:2929:b0:47f:290:47e5 with SMTP id ada2fe7eead31-48077e15645mr16704413137.21.1715801217498; Wed, 15 May 2024 12:26:57 -0700 (PDT) Received: from lvondent-mobl4.. (syn-107-146-107-067.res.spectrum.com. [107.146.107.67]) by smtp.gmail.com with ESMTPSA id a1e0cc1a2514c-7f8ffec6f28sm1918025241.27.2024.05.15.12.26.56 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 15 May 2024 12:26:56 -0700 (PDT) From: Luiz Augusto von Dentz To: linux-bluetooth@vger.kernel.org Subject: [RFC BlueZ v1] doc: Add initial L2CAP(7) documentation Date: Wed, 15 May 2024 15:26:55 -0400 Message-ID: <20240515192655.1784475-1-luiz.dentz@gmail.com> X-Mailer: git-send-email 2.45.0 Precedence: bulk X-Mailing-List: linux-bluetooth@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Luiz Augusto von Dentz This adds initial documentation for L2CAP sockets. --- Makefile.am | 7 ++ doc/l2cap.rst | 222 ++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 229 insertions(+) create mode 100644 doc/l2cap.rst diff --git a/Makefile.am b/Makefile.am index 05d02932f205..8aedbb20d0d8 100644 --- a/Makefile.am +++ b/Makefile.am @@ -348,6 +348,7 @@ CLEANFILES += $(builtin_files) if MANPAGES man_MANS += src/bluetoothd.8 +man_MANS += doc/l2cap.7 man_MANS += doc/org.bluez.Adapter.5 doc/org.bluez.Device.5 \ doc/org.bluez.DeviceSet.5 doc/org.bluez.AgentManager.5 \ doc/org.bluez.Agent.5 doc/org.bluez.ProfileManager.5 \ @@ -380,6 +381,7 @@ man_MANS += doc/org.bluez.obex.Client.5 doc/org.bluez.obex.Session.5 \ doc/org.bluez.obex.AgentManager.5 doc/org.bluez.obex.Agent.5 endif manual_pages += src/bluetoothd.8 +manual_pages += doc/l2cap.7 manual_pages += doc/org.bluez.Adapter.5 doc/org.bluez.Device.5 \ doc/org.bluez.DeviceSet.5 doc/org.bluez.AgentManager.5 \ doc/org.bluez.Agent.5 doc/org.bluez.ProfileManager.5 \ @@ -457,6 +459,8 @@ EXTRA_DIST += doc/mgmt-api.txt \ doc/health-api.txt \ doc/sap-api.txt +EXTRA_DIST += doc/l2cap.rst + EXTRA_DIST += doc/org.bluez.Adapter.rst doc/org.bluez.Device.rst \ doc/org.bluez.DeviceSet.rst doc/org.bluez.AgentManager.rst \ doc/org.bluez.Agent.rst doc/org.bluez.ProfileManager.rst \ @@ -758,6 +762,9 @@ endif %.5: %.rst Makefile $(RST2MAN_PROCESS) +%.7: %.rst Makefile + $(RST2MAN_PROCESS) + %.8: %.rst Makefile $(RST2MAN_PROCESS) diff --git a/doc/l2cap.rst b/doc/l2cap.rst new file mode 100644 index 000000000000..b358515e4e75 --- /dev/null +++ b/doc/l2cap.rst @@ -0,0 +1,222 @@ +===== +l2cap +===== + +-------------- +L2CAP protocol +-------------- + +:Version: BlueZ +:Copyright: Free use of this software is granted under ther terms of the GNU + Lesser General Public Licenses (LGPL). +:Date: July 2023 +:Manual section: 7 +:Manual group: Linux System Administration + +SYNOPSIS +======== + +.. code-block:: c + + #include + #include + #include + + l2cap_socket = socket(AF_BLUETOOTH, SOCK_SEQPACKET, BTPROTO_L2CAP); + +DESCRIPTION +=========== + +L2CAP is a protocol that provides an interface for higher-level protocols to +send and receive data over a Bluetooth connection. L2CAP sits on top of the +Bluetooth Host Controller Interface (HCI) and provides a set of channels that +can be used by higher-level protocols to transmit data. + +L2CAP provides a number of services to higher-level protocols, including +segmentation and reassembly of large data packets and flow control to prevent +overloading of the receiver. L2CAP also supports multiple channels per +connection, allowing for concurrent data transmission using different protocols. + +SOCKET OPTIONS +============== + +The socket options listed below can be set by using **setsockopt(2)** and read +with **getsockopt(2)** with the socket level set to SOL_BLUETOOTH. + +BT_SECURITY (since Linux 2.6.30) +-------------------------------- + +Channel security level, possible values: + +.. csv-table:: + :header: "Value", "Security Level", "Link Key Type", "Encryption" + + **BT_SECURITY_SDP**, 0 (SDP Only), None, Not required + **BT_SECURITY_LOW**, 1 (Low), Unauthenticated, Not required + **BT_SECURITY_MEDIUM**, 2 (Medium - default), Unauthenticated, Desired + **BT_SECURITY_HIGH**, 3 (High), Authenticated, Required + **BT_SECURITY_FIPS** (since Linux 3.15), 4 (Secure Only), Authenticated (P-256 based Secure Simple Pairing and Secure Authentication), Required + +Example: + +.. code-block:: c + + int level = BT_SECURITY_HIGH; + int err = setsockopt(l2cap_socket, SOL_BLUETOOTH, BT_SECURITY, &level, + sizeof(level)); + if (err == -1) { + perror("setsockopt"); + return 1; + } + +BT_DEFER_SETUP (since Linux 2.6.30) +----------------------------------- + +Channel defer connection setup, this control if the connection procedure +needs to be authorized by userspace before responding which allows +authorization at profile level, possible values: + +.. csv-table:: + :align: left + :header: "Value", "Description" + + **0**, Disable (userspace authorization not required) + **1**, Enable (userspace authorization required) + +Example: + +.. code-block:: c + + int defer_setup = 1; + int err = setsockopt(l2cap_socket, SOL_BLUETOOTH, BT_DEFER_SETUP, + &defer_setup, sizeof(defer_setup)); + if (err == -1) { + perror("setsockopt"); + return err; + } + + err = listen(l2cap_socket, 5); + if (err) { + perror("listen"); + return err; + } + + struct sockaddr_l2 remote_addr = {0}; + socklen_t addr_len = sizeof(remote_addr); + int new_socket = accept(l2cap_socket, (struct sockaddr*)&remote_addr, + &addr_len); + if (new_socket < 0) { + perror("accept"); + return new_socket; + } + + /* To complete the connection setup of new_socket read 1 byte */ + char c; + struct pollfd pfd; + + memset(&pfd, 0, sizeof(pfd)); + pfd.fd = new_socket; + pfd.events = POLLOUT; + + err = poll(&pfd, 1, 0); + if (err) { + perror("poll"); + return err; + } + + if (!(pfd.revents & POLLOUT)) { + err = read(sk, &c, 1); + if (err < 0) { + perror("read"); + return err; + } + } + +BT_FLUSHABLE (since Linux 2.6.39) +--------------------------------- + +Channel flushable flag, this control if the channel data can be flushed or +not, possible values: + +.. csv-table:: + :align: left + :header: "Define", "Value", "Description" + + **BT_FLUSHABLE_OFF**, 0x00, Do not flush data + **BT_FLUSHABLE_ON**, 0x01, Flush data + +BT_POWER (since Linux 3.1) +-------------------------- + +Channel power policy, this control if the channel shall force exit of sniff +mode or not, possible values: + +.. csv-table:: + :align: left + :header: "Define", "Value", "Description" + + **BT_POWER_FORCE_ACTIVE_OFF**, 0x00, Don't force exit of sniff mode + **BT_POWER_FORCE_ACTIVE_ON**, 0x01, Force exit of sniff mode + +BT_CHANNEL_POLICY (since Linux 3.10) +------------------------------------ + +High-speed (AMP) channel policy, possible values: + +.. csv-table:: + :align: left + :header: "Define", "Value", "Description" + + **BT_CHANNEL_POLICY_BREDR_ONLY**, 0, BR/EDR only - default + **BT_CHANNEL_POLICY_BREDR_PREFERRED**, 1, BR/EDR Preferred + **BT_CHANNEL_POLICY_BREDR_PREFERRED**, 2, AMP Preferred + +BT_PHY (since Linux 5.10) +------------------------- + +Channel supported PHY(s), possible values: + +.. csv-table:: + :align: left + :header: "Define", "Value", "Description" + + **BT_PHY_BR_1M_1SLOT**, BIT 0, BR 1Mbps 1SLOT + **BT_PHY_BR_1M_3SLOT**, BIT 1, BR 1Mbps 3SLOT + **BT_PHY_BR_1M_5SLOT**, BIT 2, BR 1Mbps 5SLOT + **BT_PHY_BR_2M_1SLOT**, BIT 3, EDR 2Mbps 1SLOT + **BT_PHY_BR_2M_3SLOT**, BIT 4, EDR 2Mbps 3SLOT + **BT_PHY_BR_2M_5SLOT**, BIT 5, EDR 2Mbps 5SLOT + **BT_PHY_BR_3M_1SLOT**, BIT 6, EDR 3Mbps 1SLOT + **BT_PHY_BR_3M_3SLOT**, BIT 7, EDR 3Mbps 3SLOT + **BT_PHY_BR_3M_5SLOT**, BIT 8, EDR 3Mbps 5SLOT + **BT_PHY_LE_1M_TX**, BIT 9, LE 1Mbps TX + **BT_PHY_LE_1M_RX**, BIT 10, LE 1Mbps RX + **BT_PHY_LE_2M_TX**, BIT 11, LE 2Mbps TX + **BT_PHY_LE_2M_RX**, BIT 12, LE 2Mbps RX + **BT_PHY_LE_CODED_TX**, BIT 13, LE Coded TX + **BT_PHY_LE_CODED_RX**, BIT 14, LE Coded RX + +BT_MODE (since Linux 5.10) +-------------------------- + +Channel Mode, possible values: + +.. csv-table:: + :align: left + :header: "Define", "Value", "Description" + + **BT_MODE_BASIC**, 0x00, Basic mode - default + **BT_MODE_ERTM**, 0x01, Enhanced Retransmission mode - BR/EDR only + **BT_MODE_STREAM**, 0x02, Stream mode - BR/EDR only + **BT_MODE_LE_FLOWCTL**, 0x03, Credit based flow control mode - LE only + **BT_MODE_EXT_FLOWCTL**, 0x04, Extended Credit based flow control mode + +RESOURCES +========= + +http://www.bluez.org + +REPORTING BUGS +============== + +linux-bluetooth@vger.kernel.org -- 2.45.0