Test: Kill media.extractor or mediaswcodec and observe logcat Bug: 130071409 Change-Id: Ie785642da99dfe4ff13e78d878817dae3de9f34agugelfrei
parent
8263e3519b
commit
270dd6a1a6
@ -0,0 +1,80 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2019 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//#define LOG_NDEBUG 0
|
||||||
|
#define LOG_TAG "MediaPlayerService-DeathNotifier"
|
||||||
|
#include <android-base/logging.h>
|
||||||
|
|
||||||
|
#include "DeathNotifier.h"
|
||||||
|
|
||||||
|
namespace android {
|
||||||
|
|
||||||
|
class DeathNotifier::DeathRecipient :
|
||||||
|
public IBinder::DeathRecipient,
|
||||||
|
public hardware::hidl_death_recipient {
|
||||||
|
public:
|
||||||
|
using Notify = DeathNotifier::Notify;
|
||||||
|
|
||||||
|
DeathRecipient(Notify const& notify): mNotify{notify} {
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void binderDied(wp<IBinder> const&) override {
|
||||||
|
mNotify();
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void serviceDied(uint64_t, wp<HBase> const&) override {
|
||||||
|
mNotify();
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
Notify mNotify;
|
||||||
|
};
|
||||||
|
|
||||||
|
DeathNotifier::DeathNotifier(sp<IBinder> const& service, Notify const& notify)
|
||||||
|
: mService{std::in_place_index<1>, service},
|
||||||
|
mDeathRecipient{new DeathRecipient(notify)} {
|
||||||
|
service->linkToDeath(mDeathRecipient);
|
||||||
|
}
|
||||||
|
|
||||||
|
DeathNotifier::DeathNotifier(sp<HBase> const& service, Notify const& notify)
|
||||||
|
: mService{std::in_place_index<2>, service},
|
||||||
|
mDeathRecipient{new DeathRecipient(notify)} {
|
||||||
|
service->linkToDeath(mDeathRecipient, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
DeathNotifier::DeathNotifier(DeathNotifier&& other)
|
||||||
|
: mService{other.mService}, mDeathRecipient{other.mDeathRecipient} {
|
||||||
|
other.mService.emplace<0>();
|
||||||
|
other.mDeathRecipient = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
DeathNotifier::~DeathNotifier() {
|
||||||
|
switch (mService.index()) {
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
std::get<1>(mService)->unlinkToDeath(mDeathRecipient);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
std::get<2>(mService)->unlinkToDeath(mDeathRecipient);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
CHECK(false) << "Corrupted service type during destruction.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace android
|
||||||
|
|
@ -0,0 +1,48 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2019 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef ANDROID_MEDIASERVICE_DEATHNOTIFIER_H
|
||||||
|
#define ANDROID_MEDIASERVICE_DEATHNOTIFIER_H
|
||||||
|
|
||||||
|
#include <android/hidl/base/1.0/IBase.h>
|
||||||
|
#include <binder/Binder.h>
|
||||||
|
#include <hidl/HidlSupport.h>
|
||||||
|
|
||||||
|
#include <variant>
|
||||||
|
|
||||||
|
namespace android {
|
||||||
|
|
||||||
|
class DeathNotifier {
|
||||||
|
public:
|
||||||
|
using HBase = hidl::base::V1_0::IBase;
|
||||||
|
using Notify = std::function<void()>;
|
||||||
|
|
||||||
|
DeathNotifier(sp<IBinder> const& service, Notify const& notify);
|
||||||
|
DeathNotifier(sp<HBase> const& service, Notify const& notify);
|
||||||
|
DeathNotifier(DeathNotifier&& other);
|
||||||
|
~DeathNotifier();
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::variant<std::monostate, sp<IBinder>, sp<HBase>> mService;
|
||||||
|
|
||||||
|
class DeathRecipient;
|
||||||
|
sp<DeathRecipient> mDeathRecipient;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace android
|
||||||
|
|
||||||
|
#endif // ANDROID_MEDIASERVICE_DEATHNOTIFIER_H
|
||||||
|
|
@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2019 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef ANDROID_MEDIASERVICE_DEATHRECIPIENT_H
|
||||||
|
#define ANDROID_MEDIASERVICE_DEATHRECIPIENT_H
|
||||||
|
|
||||||
|
#include <binder/binder.h>
|
||||||
|
#include <hidl/HidlSupport.h>
|
||||||
|
|
||||||
|
#include <variant>
|
||||||
|
|
||||||
|
class DeathNotifier :
|
||||||
|
public IBinder::DeathRecipient,
|
||||||
|
public ::android::hardware::hidl_death_recipient {
|
||||||
|
public:
|
||||||
|
using Service = std::variant<
|
||||||
|
sp<IBinder> const&,
|
||||||
|
sp<android::hidl::base::V1_0::IBase> const&>;
|
||||||
|
|
||||||
|
DeathNotifier(std::variant<sp<IBinder> const&,
|
||||||
|
const sp<IBinder>& service,
|
||||||
|
const sp<MediaPlayerBase>& listener,
|
||||||
|
int which,
|
||||||
|
const std::string& name);
|
||||||
|
DeathNotifier(
|
||||||
|
const sp<android::hidl::base::V1_0::IBase>& hService,
|
||||||
|
const sp<MediaPlayerBase>& listener,
|
||||||
|
int which,
|
||||||
|
const std::string& name);
|
||||||
|
virtual ~DeathNotifier() = default;
|
||||||
|
virtual void binderDied(const wp<IBinder>& who);
|
||||||
|
virtual void serviceDied(
|
||||||
|
uint64_t cookie,
|
||||||
|
const wp<::android::hidl::base::V1_0::IBase>& who);
|
||||||
|
void unlinkToDeath();
|
||||||
|
|
||||||
|
private:
|
||||||
|
sp<IBinder> mService;
|
||||||
|
sp<android::hidl::base::V1_0::IBase> mHService; // HIDL service
|
||||||
|
wp<MediaPlayerBase> mListener;
|
||||||
|
int mWhich;
|
||||||
|
std::string mName;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // ANDROID_MEDIASERVICE_DEATHRECIPIENT_H
|
||||||
|
|
Loading…
Reference in new issue