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

Commit 05d81d4f authored by Android (Google) Code Review's avatar Android (Google) Code Review
Browse files

Merge change 20927

* changes:
  Workaround for issue 2046783.
parents 4bad4e2e 11c04c98
Loading
Loading
Loading
Loading
+12 −2
Original line number Diff line number Diff line
@@ -204,7 +204,7 @@ A2dpAudioInterface::A2dpAudioStreamOut::A2dpAudioStreamOut() :
    mFd(-1), mStandby(true), mStartCount(0), mRetryCount(0), mData(NULL),
    // assume BT enabled to start, this is safe because its only the
    // enabled->disabled transition we are worried about
    mBluetoothEnabled(true), mDevice(0)
    mBluetoothEnabled(true), mDevice(0), mClosing(false)
{
    // use any address by default
    strcpy(mA2dpAddress, "00:00:00:00:00:00");
@@ -258,7 +258,7 @@ ssize_t A2dpAudioInterface::A2dpAudioStreamOut::write(const void* buffer, size_t
    size_t remaining = bytes;
    status_t status = -1;

    if (!mBluetoothEnabled) {
    if (!mBluetoothEnabled || mClosing) {
        LOGW("A2dpAudioStreamOut::write(), but bluetooth disabled");
        goto Error;
    }
@@ -307,6 +307,11 @@ status_t A2dpAudioInterface::A2dpAudioStreamOut::standby()
{
    int result = 0;

    if (mClosing) {
        LOGV("Ignore standby, closing");
        return result;
    }

    Mutex::Autolock lock(mLock);

    if (!mStandby) {
@@ -335,6 +340,11 @@ status_t A2dpAudioInterface::A2dpAudioStreamOut::setParameters(const String8& ke
        }
        param.remove(key);
    }
    key = String8("closing");
    if (param.get(key, value) == NO_ERROR) {
        mClosing = (value == "true");
        param.remove(key);
    }
    key = AudioParameter::keyRouting;
    if (param.getInt(key, device) == NO_ERROR) {
        if (AudioSystem::isA2dpDevice((AudioSystem::audio_devices)device)) {
+1 −0
Original line number Diff line number Diff line
@@ -112,6 +112,7 @@ private:
                Mutex       mLock;
                bool        mBluetoothEnabled;
                uint32_t    mDevice;
                bool        mClosing;
    };

    friend class A2dpAudioStreamOut;