summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk26
-rw-r--r--tv_input.cpp246
-rw-r--r--tvapi/Android.mk1
-rw-r--r--tvapi/android/Android.mk1
-rw-r--r--tvapi/android/include/ITv.h51
-rw-r--r--tvapi/android/include/ITvClient.h30
-rw-r--r--tvapi/android/include/ITvService.h35
-rw-r--r--tvapi/android/include/Tv.h82
-rw-r--r--tvapi/android/include/tvcmd.h594
-rw-r--r--tvapi/android/jni/Android.mk66
-rw-r--r--tvapi/android/jni/android_amlogic_tv.cpp456
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp167
-rw-r--r--tvapi/android/jni/cfbc_test.cpp43
-rw-r--r--tvapi/android/libtvbinder/Android.mk24
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp145
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp59
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp51
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp189
-rw-r--r--tvapi/android/tvserver/Android.mk85
-rw-r--r--tvapi/android/tvserver/TvService.cpp4375
-rw-r--r--tvapi/android/tvserver/TvService.h83
-rw-r--r--tvapi/android/tvserver/main.cpp23
-rw-r--r--tvapi/build/include/.gitignore0
-rw-r--r--tvapi/build/include/xxxconfig.h1
-rw-r--r--tvapi/docs/TVMiddleware初期.wps252
-rw-r--r--tvapi/docs/tv.uml6093
-rw-r--r--tvapi/libtv/Android.mk224
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp1213
-rw-r--r--tvapi/libtv/audio/audio_alsa.h131
-rw-r--r--tvapi/libtv/audio/audio_android.cpp1035
-rw-r--r--tvapi/libtv/audio/audio_android.h79
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp591
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h66
-rw-r--r--tvapi/libtv/audio/audio_api.cpp2470
-rw-r--r--tvapi/libtv/audio/audio_api.h324
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp228
-rw-r--r--tvapi/libtv/audio/audio_effect.h32
-rw-r--r--tvapi/libtv/include/amstream.h263
-rw-r--r--tvapi/libtv/include/amvecm.h68
-rw-r--r--tvapi/libtv/include/cm.h153
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h331
-rw-r--r--tvapi/libtv/include/ve.h219
-rw-r--r--tvapi/libtv/projects/Android.mk1
-rw-r--r--tvapi/libtv/projects/haier_360_v1/CTvHaierDtmb360.cpp83
-rw-r--r--tvapi/libtv/projects/haier_360_v1/CTvHaierDtmb360.h18
-rw-r--r--tvapi/libtv/projects/haier_360_v1/haier_360_v1.h0
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/Android.mk48
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/CTvRefN300.cpp12
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/CTvRefN300.h8
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/ref_n300_v1.h1
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/Android.mk48
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/CTvSkyworthDtmbN310.cpp88
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/CTvSkyworthDtmbN310.h18
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/skyworth_n310_v1.h1
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp213
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h49
-rw-r--r--tvapi/libtv/tv/CAv.cpp381
-rw-r--r--tvapi/libtv/tv/CAv.h148
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp1700
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h382
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp568
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h160
-rw-r--r--tvapi/libtv/tv/CTv.cpp5385
-rw-r--r--tvapi/libtv/tv/CTv.h636
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp162
-rw-r--r--tvapi/libtv/tv/CTvBooking.h84
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp24
-rw-r--r--tvapi/libtv/tv/CTvDmx.h18
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp216
-rw-r--r--tvapi/libtv/tv/CTvEpg.h160
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp11
-rw-r--r--tvapi/libtv/tv/CTvEv.h192
-rw-r--r--tvapi/libtv/tv/CTvLog.cpp20
-rw-r--r--tvapi/libtv/tv/CTvLog.h35
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp276
-rw-r--r--tvapi/libtv/tv/CTvRecord.h47
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h22
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1146
-rw-r--r--tvapi/libtv/tv/CTvScanner.h183
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp530
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h177
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp348
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h236
-rw-r--r--tvapi/libtv/tv/CTvTime.cpp15
-rw-r--r--tvapi/libtv/tv/CTvTime.h102
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp161
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h50
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp556
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h143
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp353
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h73
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf30
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp53
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h20
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp347
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h288
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp259
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h96
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp644
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h99
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp241
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h86
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp44
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h31
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp883
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h536
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp183
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h43
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp654
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp312
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp3292
-rw-r--r--tvapi/libtv/tvin/CTvin.h1379
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp27
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h51
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp353
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h77
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp80
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h27
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp129
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h38
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp2212
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.h251
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h371
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp187
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h23
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp1392
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.h62
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp1853
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h169
-rw-r--r--tvapi/libtv/tvutils/CCondition.h91
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp191
-rw-r--r--tvapi/libtv/tvutils/CFile.h47
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp15
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h10
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp116
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h54
-rw-r--r--tvapi/libtv/tvutils/CMutex.h116
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h50
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp357
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h55
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp152
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h186
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp165
-rw-r--r--tvapi/libtv/tvutils/CThread.h62
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp156
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h39
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp466
-rw-r--r--tvapi/libtv/tvutils/serial_base.h17
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp229
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h36
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp1912
-rw-r--r--tvapi/libtv/tvutils/tvutils.h119
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp88
-rw-r--r--tvapi/libtv/tvutils/zepoll.h49
-rw-r--r--tvapi/libtv/version/version.cpp94
-rw-r--r--tvapi/libtv/version/version.h11
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp1535
-rw-r--r--tvapi/libtv/vpp/CPQdb.h161
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp3711
-rw-r--r--tvapi/libtv/vpp/CVpp.h438
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp143
-rw-r--r--tvapi/libtv/vpp/pqdata.h30
-rw-r--r--tvapi/script/setenv.sh54
-rw-r--r--tvapi/tvtests/Android.mk49
-rw-r--r--tvapi/tvtests/android_tvtest.cpp33
-rw-r--r--tvapi/tvtests/comm_test.cpp33
-rw-r--r--tvapi/tvtests/ssm_test.cpp210
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp427
169 files changed, 64432 insertions, 116 deletions
diff --git a/tv_input.cpp b/tv_input.cpp
index ea709de..822c7c8 100644
--- a/tv_input.cpp
+++ b/tv_input.cpp
@@ -22,7 +22,8 @@
#include <cutils/native_handle.h>
#include <hardware/tv_input.h>
-
+#include <tv/CTv.h>
+#include <tvserver/TvService.h>
/*****************************************************************************/
#define ATV_DEV_ID 1
@@ -32,19 +33,20 @@
#define HDMI2_DEV_ID 5
#define HDMI3_DEV_ID 6
-typedef struct tv_input_private
-{
+typedef struct tv_input_private {
tv_input_device_t device;
// Callback related data
- const tv_input_callback_ops_t* callback;
- void* callback_data;
+ const tv_input_callback_ops_t *callback;
+ void *callback_data;
+ //TvService* pTvService;
+ CTv *pTv;
} tv_input_private_t;
-static int notify_ATV_device_available(tv_input_private_t* priv)
+static int notify_ATV_device_available(tv_input_private_t *priv)
{
- tv_input_event_t event;
- event.device_info.device_id =ATV_DEV_ID;
+ tv_input_event_t event;
+ event.device_info.device_id = ATV_DEV_ID;
event.device_info.type = TV_INPUT_TYPE_TUNER;
event.type = TV_INPUT_EVENT_DEVICE_AVAILABLE;
event.device_info.audio_type = AUDIO_DEVICE_NONE;
@@ -52,10 +54,10 @@ static int notify_ATV_device_available(tv_input_private_t* priv)
return 0;
}
-static int notify_DTV_device_available(tv_input_private_t* priv)
+static int notify_DTV_device_available(tv_input_private_t *priv)
{
- tv_input_event_t event;
- event.device_info.device_id =DTV_DEV_ID;
+ tv_input_event_t event;
+ event.device_info.device_id = DTV_DEV_ID;
event.device_info.type = TV_INPUT_TYPE_TUNER;
event.type = TV_INPUT_EVENT_DEVICE_AVAILABLE;
event.device_info.audio_type = AUDIO_DEVICE_NONE;
@@ -63,10 +65,10 @@ static int notify_DTV_device_available(tv_input_private_t* priv)
return 0;
}
-static int notify_AV_device_available(tv_input_private_t* priv)
+static int notify_AV_device_available(tv_input_private_t *priv)
{
- tv_input_event_t event;
- event.device_info.device_id =AV_DEV_ID;
+ tv_input_event_t event;
+ event.device_info.device_id = AV_DEV_ID;
event.device_info.type = TV_INPUT_TYPE_COMPONENT;
event.type = TV_INPUT_EVENT_DEVICE_AVAILABLE;
event.device_info.audio_type = AUDIO_DEVICE_NONE;
@@ -74,10 +76,10 @@ static int notify_AV_device_available(tv_input_private_t* priv)
return 0;
}
-static int notify_hdmi_device_available(tv_input_private_t* priv, int dev_id, uint32_t port_id)
+static int notify_hdmi_device_available(tv_input_private_t *priv, int dev_id, uint32_t port_id)
{
- tv_input_event_t event;
- event.device_info.device_id =dev_id;
+ tv_input_event_t event;
+ event.device_info.device_id = dev_id;
event.device_info.type = TV_INPUT_TYPE_HDMI;
event.type = TV_INPUT_EVENT_DEVICE_AVAILABLE;
event.device_info.hdmi.port_id = port_id;
@@ -86,144 +88,151 @@ static int notify_hdmi_device_available(tv_input_private_t* priv, int dev_id, ui
return 0;
}
-static int get_stream_configs(int dev_id, int* num_configurations, const tv_stream_config_t** configs)
+static int get_stream_configs(int dev_id, int *num_configurations, const tv_stream_config_t **configs)
{
- tv_stream_config_t* mconfig = (tv_stream_config_t*)malloc(sizeof(mconfig));
- if (!mconfig) {
- return -1;
- }
- switch (dev_id) {
- case ATV_DEV_ID:
- mconfig->stream_id=ATV_DEV_ID;
- mconfig->type =TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
- mconfig->max_video_width = 1920;
- mconfig->max_video_height = 1080;
- *num_configurations = 1;
- *configs = mconfig;
- break;
- case DTV_DEV_ID:
- mconfig->stream_id=DTV_DEV_ID;
- mconfig->type =TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
- mconfig->max_video_width = 1920;
- mconfig->max_video_height = 1080;
- *num_configurations = 1;
- *configs = mconfig;
- break;
- case AV_DEV_ID:
- mconfig->stream_id=AV_DEV_ID;
- mconfig->type =TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
- mconfig->max_video_width = 1920;
- mconfig->max_video_height = 1080;
- *num_configurations = 1;
- *configs = mconfig;
- break;
- case HDMI1_DEV_ID:
- mconfig->stream_id=HDMI1_DEV_ID;
- mconfig->type =TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
- mconfig->max_video_width = 1920;
- mconfig->max_video_height = 1080;
- *num_configurations = 1;
- *configs = mconfig;
- break;
- case HDMI2_DEV_ID:
- mconfig->stream_id=HDMI2_DEV_ID;
- mconfig->type =TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
- mconfig->max_video_width = 1920;
- mconfig->max_video_height = 1080;
- *num_configurations = 1;
- *configs = mconfig;
- break;
- case HDMI3_DEV_ID:
- mconfig->stream_id=HDMI3_DEV_ID;
- mconfig->type =TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
- mconfig->max_video_width = 1920;
- mconfig->max_video_height = 1080;
- *num_configurations = 1;
- *configs = mconfig;
- break;
- default:
- break;
- }
- return 0;
+ tv_stream_config_t *mconfig = (tv_stream_config_t *)malloc(sizeof(mconfig));
+ if (!mconfig) {
+ return -1;
+ }
+ switch (dev_id) {
+ case ATV_DEV_ID:
+ mconfig->stream_id = ATV_DEV_ID;
+ mconfig->type = TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
+ mconfig->max_video_width = 1920;
+ mconfig->max_video_height = 1080;
+ *num_configurations = 1;
+ *configs = mconfig;
+ break;
+ case DTV_DEV_ID:
+ mconfig->stream_id = DTV_DEV_ID;
+ mconfig->type = TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
+ mconfig->max_video_width = 1920;
+ mconfig->max_video_height = 1080;
+ *num_configurations = 1;
+ *configs = mconfig;
+ break;
+ case AV_DEV_ID:
+ mconfig->stream_id = AV_DEV_ID;
+ mconfig->type = TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
+ mconfig->max_video_width = 1920;
+ mconfig->max_video_height = 1080;
+ *num_configurations = 1;
+ *configs = mconfig;
+ break;
+ case HDMI1_DEV_ID:
+ mconfig->stream_id = HDMI1_DEV_ID;
+ mconfig->type = TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
+ mconfig->max_video_width = 1920;
+ mconfig->max_video_height = 1080;
+ *num_configurations = 1;
+ *configs = mconfig;
+ break;
+ case HDMI2_DEV_ID:
+ mconfig->stream_id = HDMI2_DEV_ID;
+ mconfig->type = TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
+ mconfig->max_video_width = 1920;
+ mconfig->max_video_height = 1080;
+ *num_configurations = 1;
+ *configs = mconfig;
+ break;
+ case HDMI3_DEV_ID:
+ mconfig->stream_id = HDMI3_DEV_ID;
+ mconfig->type = TV_STREAM_TYPE_INDEPENDENT_VIDEO_SOURCE ;
+ mconfig->max_video_width = 1920;
+ mconfig->max_video_height = 1080;
+ *num_configurations = 1;
+ *configs = mconfig;
+ break;
+ default:
+ break;
+ }
+ return 0;
}
-static int tv_input_device_open(const struct hw_module_t* module,
- const char* name, struct hw_device_t** device);
+static int tv_input_device_open(const struct hw_module_t *module,
+ const char *name, struct hw_device_t **device);
static struct hw_module_methods_t tv_input_module_methods = {
- open: tv_input_device_open
+open:
+ tv_input_device_open
};
tv_input_module_t HAL_MODULE_INFO_SYM = {
- common: {
- tag: HARDWARE_MODULE_TAG,
+common:
+ {
+tag:
+ HARDWARE_MODULE_TAG,
version_major: 0,
version_minor: 1,
- id: TV_INPUT_HARDWARE_MODULE_ID,
- name: "TVInput module",
- author: "Amlogic",
- methods: &tv_input_module_methods,
+id:
+ TV_INPUT_HARDWARE_MODULE_ID,
+name: "TVInput module"
+ ,
+author: "Amlogic"
+ ,
+methods:
+ &tv_input_module_methods,
}
};
/*****************************************************************************/
-static int tv_input_initialize(struct tv_input_device* dev,
- const tv_input_callback_ops_t* callback, void* data)
+static int tv_input_initialize(struct tv_input_device *dev,
+ const tv_input_callback_ops_t *callback, void *data)
{
if (dev == NULL || callback == NULL) {
return -EINVAL;
}
- tv_input_private_t* priv = (tv_input_private_t*)dev;
+ tv_input_private_t *priv = (tv_input_private_t *)dev;
if (priv->callback != NULL) {
return -EEXIST;
}
priv->callback = callback;
priv->callback_data = data;
-/* ATV_DEVICE_AVAILABLE */
- notify_ATV_device_available(priv);
-/* DTV_DEVICE_AVAILABLE */
- notify_DTV_device_available(priv);
-/* AV_DEVICE_AVAILABLE */
- notify_AV_device_available(priv);
-/* HDMI1_DEVICE_AVAILABLE */
- notify_hdmi_device_available(priv, HDMI1_DEV_ID, 1);
-/* HDMI2_DEVICE_AVAILABLE */
- notify_hdmi_device_available(priv, HDMI2_DEV_ID, 2);
-/* HDMI3_DEVICE_AVAILABLE */
- notify_hdmi_device_available(priv, HDMI3_DEV_ID, 3);
+ /* ATV_DEVICE_AVAILABLE */
+ notify_ATV_device_available(priv);
+ /* DTV_DEVICE_AVAILABLE */
+ notify_DTV_device_available(priv);
+ /* AV_DEVICE_AVAILABLE */
+ notify_AV_device_available(priv);
+ /* HDMI1_DEVICE_AVAILABLE */
+ notify_hdmi_device_available(priv, HDMI1_DEV_ID, 1);
+ /* HDMI2_DEVICE_AVAILABLE */
+ notify_hdmi_device_available(priv, HDMI2_DEV_ID, 2);
+ /* HDMI3_DEVICE_AVAILABLE */
+ notify_hdmi_device_available(priv, HDMI3_DEV_ID, 3);
return 0;
}
-static int tv_input_get_stream_configurations(const struct tv_input_device* dev,
- int device_id, int* num_configurations,
- const tv_stream_config_t** configs)
+static int tv_input_get_stream_configurations(const struct tv_input_device *dev,
+ int device_id, int *num_configurations,
+ const tv_stream_config_t **configs)
{
- if (get_stream_configs(device_id, num_configurations, configs) == 0) {
- return 0;
- }
+ if (get_stream_configs(device_id, num_configurations, configs) == 0) {
+ return 0;
+ }
return -EINVAL;
}
-static int tv_input_open_stream(struct tv_input_device*, int, tv_stream_t*)
+static int tv_input_open_stream(struct tv_input_device *, int, tv_stream_t *)
{
return -EINVAL;
}
-static int tv_input_close_stream(struct tv_input_device*, int, int)
+static int tv_input_close_stream(struct tv_input_device *, int, int)
{
return -EINVAL;
}
static int tv_input_request_capture(
- struct tv_input_device*, int, int, buffer_handle_t, uint32_t)
+ struct tv_input_device *, int, int, buffer_handle_t, uint32_t)
{
return -EINVAL;
}
-static int tv_input_cancel_capture(struct tv_input_device*, int, int, uint32_t)
+static int tv_input_cancel_capture(struct tv_input_device *, int, int, uint32_t)
{
return -EINVAL;
}
@@ -232,7 +241,10 @@ static int tv_input_cancel_capture(struct tv_input_device*, int, int, uint32_t)
static int tv_input_device_close(struct hw_device_t *dev)
{
- tv_input_private_t* priv = (tv_input_private_t*)dev;
+ tv_input_private_t *priv = (tv_input_private_t *)dev;
+ if (priv->pTv != NULL) {
+ delete priv->pTv;
+ }
if (priv) {
free(priv);
}
@@ -241,25 +253,27 @@ static int tv_input_device_close(struct hw_device_t *dev)
/*****************************************************************************/
-static int tv_input_device_open(const struct hw_module_t* module,
- const char* name, struct hw_device_t** device)
+static int tv_input_device_open(const struct hw_module_t *module,
+ const char *name, struct hw_device_t **device)
{
int status = -EINVAL;
if (!strcmp(name, TV_INPUT_DEFAULT_DEVICE)) {
- tv_input_private_t* dev = (tv_input_private_t*)malloc(sizeof(*dev));
+ tv_input_private_t *dev = (tv_input_private_t *)malloc(sizeof(*dev));
/* initialize our state here */
memset(dev, 0, sizeof(*dev));
-
+ /*intialize tv*/
+ dev->pTv = new CTv();
+ TvService::instantiate(dev->pTv);
/* initialize the procs */
dev->device.common.tag = HARDWARE_DEVICE_TAG;
dev->device.common.version = TV_INPUT_DEVICE_API_VERSION_0_1;
- dev->device.common.module = const_cast<hw_module_t*>(module);
+ dev->device.common.module = const_cast<hw_module_t *>(module);
dev->device.common.close = tv_input_device_close;
dev->device.initialize = tv_input_initialize;
dev->device.get_stream_configurations =
- tv_input_get_stream_configurations;
+ tv_input_get_stream_configurations;
dev->device.open_stream = tv_input_open_stream;
dev->device.close_stream = tv_input_close_stream;
dev->device.request_capture = tv_input_request_capture;