summaryrefslogtreecommitdiff
path: root/system/stack/arbiter/acl_arbiter.h
blob: 263ec99d770c5dff7e22966342fe65eab8463207 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*
 * Copyright 2022 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/// This class intercepts incoming connection requests and data packets, and
/// decides whether to intercept them or pass them to the legacy stack
///
/// It allows us to easily gate changes to the datapath and roll back to legacy
/// behavior if needed.

#pragma once

#include "rust/cxx.h"
#include "stack/include/bt_hdr.h"
#include "types/raw_address.h"

namespace bluetooth {
namespace shim {
namespace arbiter {

enum class InterceptAction {
  /// The packet should be forwarded to the legacy stack
  FORWARD,
  /// The packet should be dropped and not sent to legacy
  DROP
};

class AclArbiter {
public:
  void OnLeConnect(uint8_t tcb_idx, uint16_t advertiser_id);
  void OnLeDisconnect(uint8_t tcb_idx);
  InterceptAction InterceptAttPacket(uint8_t tcb_idx, const BT_HDR* packet);

  void OnOutgoingMtuReq(uint8_t tcb_idx);
  void OnIncomingMtuResp(uint8_t tcb_idx, size_t mtu);
  void OnIncomingMtuReq(uint8_t tcb_idx, size_t mtu);

  void SendPacketToPeer(uint8_t tcb_idx, ::rust::Vec<uint8_t> buffer);

  AclArbiter() = default;
  AclArbiter(AclArbiter&& other) = default;
  AclArbiter& operator=(AclArbiter&& other) = default;
  ~AclArbiter() = default;
};

void StoreCallbacksFromRust(
        ::rust::Fn<void(uint8_t tcb_idx, uint8_t advertiser)> on_le_connect,
        ::rust::Fn<void(uint8_t tcb_idx)> on_le_disconnect,
        ::rust::Fn<InterceptAction(uint8_t tcb_idx, ::rust::Vec<uint8_t> buffer)> intercept_packet,
        ::rust::Fn<void(uint8_t tcb_idx)> on_outgoing_mtu_req,
        ::rust::Fn<void(uint8_t tcb_idx, size_t mtu)> on_incoming_mtu_resp,
        ::rust::Fn<void(uint8_t tcb_idx, size_t mtu)> on_incoming_mtu_req);

void SendPacketToPeer(uint8_t tcb_idx, ::rust::Vec<uint8_t> buffer);

AclArbiter& GetArbiter();

}  // namespace arbiter
}  // namespace shim
}  // namespace bluetooth