blob: 5276695376ddac6f57b1733f5da2f5bbd8a35467 [file] [log] [blame]
Saurabh Shah56f610d2012-08-07 15:27:06 -07001/*
Arun Kumar K.Rf15adc02014-01-21 21:26:25 -08002 * Copyright (c) 2012-2014, The Linux Foundation. All rights reserved.
Saurabh Shah56f610d2012-08-07 15:27:06 -07003 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above
10 * copyright notice, this list of conditions and the following
11 * disclaimer in the documentation and/or other materials provided
12 * with the distribution.
Duy Truong73d36df2013-02-09 20:33:23 -080013 * * Neither the name of The Linux Foundation nor the names of its
Saurabh Shah56f610d2012-08-07 15:27:06 -070014 * contributors may be used to endorse or promote products derived
15 * from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30#include <QService.h>
Naseer Ahmede2e19632014-05-29 18:24:20 -040031#include <binder/Parcel.h>
32#include <binder/IPCThreadState.h>
Saurabh Shah56f610d2012-08-07 15:27:06 -070033
34#define QSERVICE_DEBUG 0
35
36using namespace android;
37
38namespace qService {
39
40QService* QService::sQService = NULL;
41// ----------------------------------------------------------------------------
Saurabh Shah86c17292013-02-08 15:24:13 -080042QService::QService()
Saurabh Shah56f610d2012-08-07 15:27:06 -070043{
44 ALOGD_IF(QSERVICE_DEBUG, "QService Constructor invoked");
45}
46
47QService::~QService()
48{
49 ALOGD_IF(QSERVICE_DEBUG,"QService Destructor invoked");
50}
51
Saurabh Shah86c17292013-02-08 15:24:13 -080052void QService::connect(const sp<qClient::IQClient>& client) {
Naseer Ahmed7a7b66d2014-07-23 17:56:26 -040053 ALOGD_IF(QSERVICE_DEBUG,"HWC client connected");
Saurabh Shah86c17292013-02-08 15:24:13 -080054 mClient = client;
55}
56
Naseer Ahmed7a7b66d2014-07-23 17:56:26 -040057void QService::connect(const sp<qClient::IQHDMIClient>& client) {
58 ALOGD_IF(QSERVICE_DEBUG,"HWC client connected");
59 mHDMIClient = client;
60}
61
Naseer Ahmed4957c522013-11-12 18:07:15 -050062status_t QService::dispatch(uint32_t command, const Parcel* inParcel,
63 Parcel* outParcel) {
Arun Kumar K.Rf15adc02014-01-21 21:26:25 -080064 status_t err = (status_t) FAILED_TRANSACTION;
Naseer Ahmede2e19632014-05-29 18:24:20 -040065 IPCThreadState* ipc = IPCThreadState::self();
66 //Rewind parcel in case we're calling from the same process
67 if (ipc->getCallingPid() == getpid())
68 inParcel->setDataPosition(0);
Naseer Ahmed4957c522013-11-12 18:07:15 -050069 if (mClient.get()) {
70 ALOGD_IF(QSERVICE_DEBUG, "Dispatching command: %d", command);
71 err = mClient->notifyCallback(command, inParcel, outParcel);
Jeykumar Sankaran9f59a762013-02-28 10:45:56 -080072 }
Naseer Ahmed4957c522013-11-12 18:07:15 -050073 return err;
Arun Kumar K.Rfb5bfa62013-07-25 03:10:51 -070074}
75
Naseer Ahmed7a7b66d2014-07-23 17:56:26 -040076void QService::onHdmiHotplug(int connected) {
77 if(mHDMIClient.get()) {
78 ALOGD_IF(QSERVICE_DEBUG, "%s: HDMI hotplug", __FUNCTION__);
79 mHDMIClient->onHdmiHotplug(connected);
80 } else {
81 ALOGE("%s: Failed to get a valid HDMI client", __FUNCTION__);
82 }
83}
84
85void QService::onCECMessageReceived(char *msg, ssize_t len) {
86 if(mHDMIClient.get()) {
87 ALOGD_IF(QSERVICE_DEBUG, "%s: CEC message received", __FUNCTION__);
88 mHDMIClient->onCECMessageRecieved(msg, len);
89 } else {
90 ALOGE("%s: Failed to get a valid HDMI client", __FUNCTION__);
91 }
92}
93
94
Saurabh Shah86c17292013-02-08 15:24:13 -080095void QService::init()
Saurabh Shah56f610d2012-08-07 15:27:06 -070096{
97 if(!sQService) {
Saurabh Shah86c17292013-02-08 15:24:13 -080098 sQService = new QService();
Saurabh Shah56f610d2012-08-07 15:27:06 -070099 sp<IServiceManager> sm = defaultServiceManager();
100 sm->addService(String16("display.qservice"), sQService);
101 if(sm->checkService(String16("display.qservice")) != NULL)
102 ALOGD_IF(QSERVICE_DEBUG, "adding display.qservice succeeded");
103 else
104 ALOGD_IF(QSERVICE_DEBUG, "adding display.qservice failed");
105 }
Saurabh Shah56f610d2012-08-07 15:27:06 -0700106}
107
108}