Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit b902fd15 authored by Andre Eisenbach's avatar Andre Eisenbach Committed by android-build-merger
Browse files

Merge "Bluetooth: Do not die quietly on binder death" am: e5796ef7 am: 810bb519

am: d50f39d0

Change-Id: I0db28e80bcc72de8023981c38cb5bdb84f02a57f
parents f8654fac d50f39d0
Loading
Loading
Loading
Loading
+36 −5
Original line number Original line Diff line number Diff line
@@ -30,6 +30,19 @@ static const uint8_t HCI_DATA_TYPE_COMMAND = 1;
static const uint8_t HCI_DATA_TYPE_ACL = 2;
static const uint8_t HCI_DATA_TYPE_ACL = 2;
static const uint8_t HCI_DATA_TYPE_SCO = 3;
static const uint8_t HCI_DATA_TYPE_SCO = 3;


class BluetoothDeathRecipient : public hidl_death_recipient {
 public:
  BluetoothDeathRecipient(const sp<IBluetoothHci> hci) : mHci(hci) {}

  virtual void serviceDied(
      uint64_t /*cookie*/,
      const wp<::android::hidl::base::V1_0::IBase>& /*who*/) {
    ALOGE("BluetoothDeathRecipient::serviceDied - Bluetooth service died");
    mHci->close();
  }
  sp<IBluetoothHci> mHci;
};

BluetoothHci::BluetoothHci()
BluetoothHci::BluetoothHci()
    : deathRecipient(new BluetoothDeathRecipient(this)) {}
    : deathRecipient(new BluetoothDeathRecipient(this)) {}


@@ -41,19 +54,37 @@ Return<void> BluetoothHci::initialize(


  bool rc = VendorInterface::Initialize(
  bool rc = VendorInterface::Initialize(
      [this](bool status) {
      [this](bool status) {
        event_cb_->initializationComplete(
        auto hidl_status = event_cb_->initializationComplete(
            status ? Status::SUCCESS : Status::INITIALIZATION_ERROR);
            status ? Status::SUCCESS : Status::INITIALIZATION_ERROR);
        if (!hidl_status.isOk()) {
          ALOGE("VendorInterface -> Unable to call initializationComplete()");
        }
      },
      },
      [this](const hidl_vec<uint8_t>& packet) {
      [this](const hidl_vec<uint8_t>& packet) {
        event_cb_->hciEventReceived(packet);
        auto hidl_status = event_cb_->hciEventReceived(packet);
        if (!hidl_status.isOk()) {
          ALOGE("VendorInterface -> Unable to call hciEventReceived()");
        }
      },
      },
      [this](const hidl_vec<uint8_t>& packet) {
      [this](const hidl_vec<uint8_t>& packet) {
        event_cb_->aclDataReceived(packet);
        auto hidl_status = event_cb_->aclDataReceived(packet);
        if (!hidl_status.isOk()) {
          ALOGE("VendorInterface -> Unable to call aclDataReceived()");
        }
      },
      },
      [this](const hidl_vec<uint8_t>& packet) {
      [this](const hidl_vec<uint8_t>& packet) {
        event_cb_->scoDataReceived(packet);
        auto hidl_status = event_cb_->scoDataReceived(packet);
        if (!hidl_status.isOk()) {
          ALOGE("VendorInterface -> Unable to call scoDataReceived()");
        }
      });
      });
  if (!rc) event_cb_->initializationComplete(Status::INITIALIZATION_ERROR);
  if (!rc) {
    auto hidl_status =
        event_cb_->initializationComplete(Status::INITIALIZATION_ERROR);
    if (!hidl_status.isOk()) {
      ALOGE("VendorInterface -> Unable to call initializationComplete(ERR)");
    }
  }
  return Void();
  return Void();
}
}


+1 −10
Original line number Original line Diff line number Diff line
@@ -30,16 +30,7 @@ namespace implementation {
using ::android::hardware::Return;
using ::android::hardware::Return;
using ::android::hardware::hidl_vec;
using ::android::hardware::hidl_vec;


struct BluetoothDeathRecipient : hidl_death_recipient {
class BluetoothDeathRecipient;
  BluetoothDeathRecipient(const sp<IBluetoothHci> hci) : mHci(hci) {}

  virtual void serviceDied(
      uint64_t /*cookie*/,
      const wp<::android::hidl::base::V1_0::IBase>& /*who*/) {
    mHci->close();
  }
  sp<IBluetoothHci> mHci;
};


class BluetoothHci : public IBluetoothHci {
class BluetoothHci : public IBluetoothHci {
 public:
 public: