/*
* Copyright (c) 2014 The Linux Foundation. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* * Neither the name of The Linux Foundation. nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
* IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef QHDMI_CEC_H
#define QHDMI_CEC_H
#include <hardware/hdmi_cec.h>
#include <utils/RefBase.h>
namespace qClient {
class QHDMIClient;
};
namespace qhdmicec {
#define SYSFS_BASE "/sys/class/graphics/fb"
#define MAX_PATH_LENGTH 128
struct cec_callback_t {
// Function in HDMI service to call back on CEC messages
event_callback_t callback_func;
// This stores the object to pass back to the framework
void* callback_arg;
};
struct cec_context_t {
hdmi_cec_device_t device; // Device for HW module
cec_callback_t callback; // Struct storing callback object
bool enabled;
bool arc_enabled;
bool system_control; // If true, HAL/driver handle CEC messages
int fb_num; // Framebuffer node for HDMI
char fb_sysfs_path[MAX_PATH_LENGTH];
hdmi_port_info *port_info; // HDMI port info
// Logical address is stored in an array, the index of the array is the
// logical address and the value in the index shows whether it is set or not
int logical_address[CEC_ADDR_BROADCAST];
int version;
uint32_t vendor_id;
android::sp<qClient::QHDMIClient> disp_client;
};
void cec_receive_message(cec_context_t *ctx, char *msg, ssize_t len);
void cec_hdmi_hotplug(cec_context_t *ctx, int connected);
}; //namespace
#endif /* end of include guard: QHDMI_CEC_H */