summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_callback.h7
-rw-r--r--tv_input.cpp96
-rw-r--r--tvapi/android/include/ITv.h34
-rw-r--r--tvapi/android/include/ITvClient.h12
-rw-r--r--tvapi/android/include/ITvService.h18
-rw-r--r--tvapi/android/include/TvClient.h5
-rw-r--r--tvapi/android/include/tvcmd.h1180
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp64
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp666
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp246
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp78
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp56
-rw-r--r--tvapi/android/libtvbinder/TvClient.cpp54
-rw-r--r--tvapi/android/tv/TvPlay.cpp36
-rw-r--r--tvapi/android/tv/TvPlay.h2
-rw-r--r--tvapi/android/tvserver/TvService.cpp8700
-rw-r--r--tvapi/android/tvserver/TvService.h107
-rw-r--r--tvapi/android/tvserver/main.cpp12
-rw-r--r--tvapi/android/tvserver/tv_callback.h25
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp170
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h32
-rw-r--r--tvapi/libtv/audio/CTvAudio.h52
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp1004
-rw-r--r--tvapi/libtv/audio/audio_alsa.h164
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp82
-rw-r--r--tvapi/libtv/audio/audio_effect.h34
-rw-r--r--tvapi/libtv/include/amstream.h142
-rw-r--r--tvapi/libtv/include/cm.h188
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h492
-rw-r--r--tvapi/libtv/include/ve.h342
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp280
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h44
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp172
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h26
-rw-r--r--tvapi/libtv/tv/CAv.cpp612
-rw-r--r--tvapi/libtv/tv/CAv.h188
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2670
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h716
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp964
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h236
-rw-r--r--tvapi/libtv/tv/CTv.cpp2174
-rw-r--r--tvapi/libtv/tv/CTv.h1470
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp170
-rw-r--r--tvapi/libtv/tv/CTvBooking.h94
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h12
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp258
-rw-r--r--tvapi/libtv/tv/CTvEpg.h276
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h322
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp368
-rw-r--r--tvapi/libtv/tv/CTvRecord.h70
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1934
-rw-r--r--tvapi/libtv/tv/CTvScanner.h418
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1228
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h142
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp708
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h430
-rw-r--r--tvapi/libtv/tv/CTvTime.h134
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h40
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h104
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp638
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp558
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h76
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp28
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp408
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h478
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp302
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h112
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h134
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp322
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h112
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp4
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h14
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1322
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h988
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp228
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h30
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp438
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h76
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4452
-rw-r--r--tvapi/libtv/tvin/CTvin.h2116
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp6
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h72
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp12
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h48
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp66
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h20
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp146
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h40
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp2168
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h8
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp1792
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp958
-rw-r--r--tvapi/libtv/tvutils/CCondition.h84
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp261
-rw-r--r--tvapi/libtv/tvutils/CFile.h50
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h6
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp146
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h40
-rw-r--r--tvapi/libtv/tvutils/CMutex.h112
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h60
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h42
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h288
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h76
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp204
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h46
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h42
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp2813
-rw-r--r--tvapi/libtv/tvutils/tvutils.h44
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h54
-rw-r--r--tvapi/libtv/version/version.cpp50
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp618
-rw-r--r--tvapi/libtv/vpp/CPQdb.h232
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp724
-rw-r--r--tvapi/libtv/vpp/CVpp.h676
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp320
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp560
134 files changed, 31073 insertions, 30287 deletions
diff --git a/tvapi/libtv/tv/CTvSubtitle.cpp b/tvapi/libtv/tv/CTvSubtitle.cpp
index 4ee991c..bd84703 100644
--- a/tvapi/libtv/tv/CTvSubtitle.cpp
+++ b/tvapi/libtv/tv/CTvSubtitle.cpp
@@ -12,21 +12,21 @@
#include "am_dmx.h"
CTvSubtitle::CTvSubtitle()
{
- mpObser = NULL;
+ mpObser = NULL;
}
CTvSubtitle::~CTvSubtitle()
{
}
void CTvSubtitle::setObserver(IObserver *pObser)
{
- isSubOpen = false;
- mpObser = pObser;
+ isSubOpen = false;
+ mpObser = pObser;
}
void CTvSubtitle::setBuffer(char *share_mem)
{
- pthread_mutex_lock(&lock);
- buffer = (unsigned char *)share_mem;
- pthread_mutex_unlock(&lock);
+ pthread_mutex_lock(&lock);
+ buffer = (unsigned char *)share_mem;
+ pthread_mutex_unlock(&lock);
}
void CTvSubtitle::stopDecoder()
{
@@ -121,360 +121,360 @@ void CTvSubtitle::searchPrevious()
int CTvSubtitle::sub_init(int bmp_width, int bmp_height)
{
- pthread_mutex_init(&lock, NULL);
- bmp_w = bmp_width;
- bmp_h = bmp_height;
- sub_w = 720;
- sub_h = 576;
- bmp_pitch = bmp_w * 4;
- return 0;
+ pthread_mutex_init(&lock, NULL);
+ bmp_w = bmp_width;
+ bmp_h = bmp_height;
+ sub_w = 720;
+ sub_h = 576;
+ bmp_pitch = bmp_w * 4;
+ return 0;
}
int CTvSubtitle::sub_destroy()
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_lock()
{
- pthread_mutex_lock(&lock);
- return 0;
+ pthread_mutex_lock(&lock);
+ return 0;
}
int CTvSubtitle::sub_unlock()
{
- pthread_mutex_unlock(&lock);
- return 0;
+ pthread_mutex_unlock(&lock);
+ return 0;
}
int CTvSubtitle::sub_clear()
{
- return 0;
+ return 0;
}
static void clear_bitmap(CTvSubtitle *pSub)
{
- unsigned char *ptr = pSub->buffer;
- int y = pSub->bmp_h;
+ unsigned char *ptr = pSub->buffer;
+ int y = pSub->bmp_h;
- while (y--) {
- memset(ptr, 0, pSub->bmp_pitch);
- ptr += pSub->bmp_pitch;
- }
+ while (y--) {
+ memset(ptr, 0, pSub->bmp_pitch);
+ ptr += pSub->bmp_pitch;
+ }
}
static void show_sub_cb(AM_SUB2_Handle_t handle, AM_SUB2_Picture_t *pic)
{
- LOGD("dvb callback-----------");
-
- CTvSubtitle *pSub = ((CTvSubtitle *) AM_SUB2_GetUserData(handle));
- pthread_mutex_lock(&pSub->lock);
- clear_bitmap(pSub);
-
- if (pic) {
- AM_SUB2_Region_t *rgn = pic->p_region;
- pSub->sub_w = pic->original_width;
- pSub->sub_h = pic->original_height;
- while (rgn) {
- int sx, sy, dx, dy, rw, rh;
-
- // ensure we have a valid buffer
- if (! rgn->p_buf) {
- rgn = rgn->p_next;
- continue;
- }
-
- sx = 0;
- sy = 0;
- dx = pic->original_x + rgn->left;
- dy = pic->original_y + rgn->top;
- rw = rgn->width;
- rh = rgn->height;
-
- if (dx < 0) {
- sx = -dx;
- dx = 0;
- rw += dx;
- }
-
- if (dx + rw > pSub->bmp_w) {
- rw = pSub->bmp_w - dx;
- }
-
- if (dy < 0) {
- sy = -dy;
- dy = 0;
- rh += dy;
- }
-
- if (dy + rh > pSub->bmp_h) {
- rh = pSub->bmp_h - dy;
- }
-
- if ((rw > 0) && (rh > 0)) {
- unsigned char *sbegin = (unsigned char *)rgn->p_buf + sy * rgn->width + sx;
- unsigned char *dbegin = pSub->buffer + dy * pSub->bmp_pitch + dx * 4;
- unsigned char *src, *dst;
- int size;
-
- while (rh) {
- src = sbegin;
- dst = dbegin;
- size = rw;
- while (size--) {
- int c = src[0];
-
- if (c < (int)rgn->entry) {
- if (rgn->clut[c].a) {
- *dst++ = rgn->clut[c].r;
- *dst++ = rgn->clut[c].g;
- *dst++ = rgn->clut[c].b;
- } else {
- dst += 3;
- }
- *dst++ = rgn->clut[c].a;
- } else {
- dst += 4;
- }
- src ++;
- }
- sbegin += rgn->width;
- dbegin += pSub->bmp_pitch;
- rh--;
- }
- }
-
- rgn = rgn->p_next;
- }
- pSub->mpObser->updateSubtitle(pic->original_width, pic->original_height);
- }
- pthread_mutex_unlock(&pSub->lock);
+ LOGD("dvb callback-----------");
+
+ CTvSubtitle *pSub = ((CTvSubtitle *) AM_SUB2_GetUserData(handle));
+ pthread_mutex_lock(&pSub->lock);
+ clear_bitmap(pSub);
+
+ if (pic) {
+ AM_SUB2_Region_t *rgn = pic->p_region;
+ pSub->sub_w = pic->original_width;
+ pSub->sub_h = pic->original_height;
+ while (rgn) {
+ int sx, sy, dx, dy, rw, rh;
+
+ // ensure we have a valid buffer
+ if (! rgn->p_buf) {
+ rgn = rgn->p_next;
+ continue;
+ }
+
+ sx = 0;
+ sy = 0;
+ dx = pic->original_x + rgn->left;
+ dy = pic->original_y + rgn->top;
+ rw = rgn->width;
+ rh = rgn->height;
+
+ if (dx < 0) {
+ sx = -dx;
+ dx = 0;
+ rw += dx;
+ }
+
+ if (dx + rw > pSub->bmp_w) {
+ rw = pSub->bmp_w - dx;
+ }
+
+ if (dy < 0) {
+ sy = -dy;
+ dy = 0;
+ rh += dy;
+ }
+
+ if (dy + rh > pSub->bmp_h) {
+ rh = pSub->bmp_h - dy;
+ }
+
+ if ((rw > 0) && (rh > 0)) {
+ unsigned char *sbegin = (unsigned char *)rgn->p_buf + sy * rgn->width + sx;
+ unsigned char *dbegin = pSub->buffer + dy * pSub->bmp_pitch + dx * 4;
+ unsigned char *src, *dst;
+ int size;
+
+ while (rh) {
+ src = sbegin;
+ dst = dbegin;
+ size = rw;
+ while (size--) {
+ int c = src[0];
+
+ if (c < (int)rgn->entry) {
+ if (rgn->clut[c].a) {
+ *dst++ = rgn->clut[c].r;
+ *dst++ = rgn->clut[c].g;
+ *dst++ = rgn->clut[c].b;
+ } else {
+ dst += 3;
+ }
+ *dst++ = rgn->clut[c].a;
+ } else {
+ dst += 4;
+ }
+ src ++;
+ }
+ sbegin += rgn->width;
+ dbegin += pSub->bmp_pitch;
+ rh--;
+ }
+ }
+
+ rgn = rgn->p_next;
+ }
+ pSub->mpObser->updateSubtitle(pic->original_width, pic->original_height);
+ }
+ pthread_mutex_unlock(&pSub->lock);
}
static uint64_t get_pts_cb(void *handle, uint64_t pts)
{
- char buf[32];
- AM_ErrorCode_t ret;
- uint32_t v;
- uint64_t r;
+ char buf[32];
+ AM_ErrorCode_t ret;
+ uint32_t v;
+ uint64_t r;
- ret = AM_FileRead("/sys/class/tsync/pts_pcrscr", buf, sizeof(buf));
- if (!ret) {
- v = strtoul(buf, 0, 16);
- if (pts & (1LL << 32)) {
- r = ((uint64_t)v) | (1LL << 32);
- } else {
- r = (uint64_t)v;
- }
- } else {
- r = 0LL;
- }
+ ret = AM_FileRead("/sys/class/tsync/pts_pcrscr", buf, sizeof(buf));
+ if (!ret) {
+ v = strtoul(buf, 0, 16);
+ if (pts & (1LL << 32)) {
+ r = ((uint64_t)v) | (1LL << 32);
+ } else {
+ r = (uint64_t)v;
+ }
+ } else {
+ r = 0LL;
+ }
- return r;
+ return r;
}
static void pes_data_cb(int dev_no, int fhandle, const uint8_t *data, int len, void *user_data)
{
- CTvSubtitle *pSub = ((CTvSubtitle *) user_data);
- AM_PES_Decode(pSub->pes_handle, (uint8_t *)data, len);
+ CTvSubtitle *pSub = ((CTvSubtitle *) user_data);
+ AM_PES_Decode(pSub->pes_handle, (uint8_t *)data, len);
}
static int close_dmx(CTvSubtitle *pSub)
{
- AM_DMX_FreeFilter(pSub->dmx_id, pSub->filter_handle);
- AM_DMX_Close(pSub->dmx_id);
- pSub->dmx_id = -1;
- pSub->filter_handle = -1;
+ AM_DMX_FreeFilter(pSub->dmx_id, pSub->filter_handle);
+ AM_DMX_Close(pSub->dmx_id);
+ pSub->dmx_id = -1;
+ pSub->filter_handle = -1;
- return 0;
+ return 0;
}
static int open_dmx(CTvSubtitle *pSub, int dmx_id, int pid)
{
- close_dmx(pSub);
- AM_DMX_OpenPara_t op;
- struct dmx_pes_filter_params pesp;
- AM_ErrorCode_t ret;
-
- pSub->dmx_id = -1;
- pSub->filter_handle = -1;
- memset(&op, 0, sizeof(op));
-
- ret = AM_DMX_Open(dmx_id, &op);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_DMX_Open != AM_SUCCESS");
- goto error;
- }
- pSub->dmx_id = dmx_id;
-
- ret = AM_DMX_AllocateFilter(dmx_id, &pSub->filter_handle);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_DMX_AllocateFilter != AM_SUCCESS");
- goto error;
- }
-
- ret = AM_DMX_SetBufferSize(dmx_id, pSub->filter_handle, 0x80000);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_DMX_SetBufferSize != AM_SUCCESS");
- goto error;
- }
-
- memset(&pesp, 0, sizeof(pesp));
- pesp.pid = pid;
- pesp.output = DMX_OUT_TAP;
- pesp.pes_type = DMX_PES_TELETEXT0;
-
- ret = AM_DMX_SetPesFilter(dmx_id, pSub->filter_handle, &pesp);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_DMX_SetPesFilter != AM_SUCCESS, err = %d", strerror(errno));
- goto error;
- }
-
- ret = AM_DMX_SetCallback(dmx_id, pSub->filter_handle, pes_data_cb, pSub);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_DMX_SetCallback != AM_SUCCESS");
- goto error;
- }
-
- ret = AM_DMX_StartFilter(dmx_id, pSub->filter_handle);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_DMX_StartFilter != AM_SUCCESS,dmx_id=%d,filter_handle=%d, ret = %d", dmx_id, pSub->filter_handle, ret);
- goto error;
- }
-
- return 0;
+ close_dmx(pSub);
+ AM_DMX_OpenPara_t op;
+ struct dmx_pes_filter_params pesp;
+ AM_ErrorCode_t ret;
+
+ pSub->dmx_id = -1;
+ pSub->filter_handle = -1;
+ memset(&op, 0, sizeof(op));
+
+ ret = AM_DMX_Open(dmx_id, &op);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_DMX_Open != AM_SUCCESS");
+ goto error;
+ }
+ pSub->dmx_id = dmx_id;
+
+ ret = AM_DMX_AllocateFilter(dmx_id, &pSub->filter_handle);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_DMX_AllocateFilter != AM_SUCCESS");
+ goto error;
+ }
+
+ ret = AM_DMX_SetBufferSize(dmx_id, pSub->filter_handle, 0x80000);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_DMX_SetBufferSize != AM_SUCCESS");
+ goto error;
+ }
+
+ memset(&pesp, 0, sizeof(pesp));
+ pesp.pid = pid;
+ pesp.output = DMX_OUT_TAP;
+ pesp.pes_type = DMX_PES_TELETEXT0;
+
+ ret = AM_DMX_SetPesFilter(dmx_id, pSub->filter_handle, &pesp);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_DMX_SetPesFilter != AM_SUCCESS, err = %d", strerror(errno));
+ goto error;
+ }
+
+ ret = AM_DMX_SetCallback(dmx_id, pSub->filter_handle, pes_data_cb, pSub);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_DMX_SetCallback != AM_SUCCESS");
+ goto error;
+ }
+
+ ret = AM_DMX_StartFilter(dmx_id, pSub->filter_handle);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_DMX_StartFilter != AM_SUCCESS,dmx_id=%d,filter_handle=%d, ret = %d", dmx_id, pSub->filter_handle, ret);
+ goto error;
+ }
+
+ return 0;
error:
- if (pSub->filter_handle != -1) {
- AM_DMX_FreeFilter(dmx_id, pSub->filter_handle);
- }
- if (pSub->dmx_id != -1) {
- AM_DMX_Close(dmx_id);
- }
+ if (pSub->filter_handle != -1) {
+ AM_DMX_FreeFilter(dmx_id, pSub->filter_handle);
+ }
+ if (pSub->dmx_id != -1) {
+ AM_DMX_Close(dmx_id);
+ }
- return -1;
+ return -1;
}
static void pes_sub_cb(AM_PES_Handle_t handle, uint8_t *buf, int size)
{
- CTvSubtitle *pSub = ((CTvSubtitle *) AM_SUB2_GetUserData(handle));
- AM_SUB2_Decode(pSub->sub_handle, buf, size);
+ CTvSubtitle *pSub = ((CTvSubtitle *) AM_SUB2_GetUserData(handle));
+ AM_SUB2_Decode(pSub->sub_handle, buf, size);
}
int CTvSubtitle::sub_switch_status()
{
- return isSubOpen ? 1 : 0;
+ return isSubOpen ? 1 : 0;
}
int CTvSubtitle::sub_start_dvb_sub(int dmx_id, int pid, int page_id, int anc_page_id)
{
- LOGD("start dvb subtitle=----------------");
-
- AM_PES_Para_t pesp;
- AM_SUB2_Para_t subp;
- int ret;
-
- memset(&pesp, 0, sizeof(pesp));
- pesp.packet = pes_sub_cb;
- pesp.user_data = this;
- ret = AM_PES_Create(&pes_handle, &pesp);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_PES_Create != AM_SUCCESS");
- goto error;
- }
-
- memset(&subp, 0, sizeof(subp));
- subp.show = show_sub_cb;
- subp.get_pts = get_pts_cb;
- subp.composition_id = page_id;
- subp.ancillary_id = anc_page_id;
- subp.user_data = this;
- ret = AM_SUB2_Create(&sub_handle, &subp);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_SUB2_Create != AM_SUCCESS");
- goto error;
- }
-
- ret = AM_SUB2_Start(sub_handle);
- if (ret != AM_SUCCESS) {
- LOGD("error AM_SUB2_Start != AM_SUCCESS");
- goto error;
- }
-
- ret = open_dmx(this, dmx_id, pid);
- if (ret < 0) {
- LOGD("error open_dmx != AM_SUCCESS");
- goto error;
- }
- isSubOpen = true;
- return 0;
+ LOGD("start dvb subtitle=----------------");
+
+ AM_PES_Para_t pesp;
+ AM_SUB2_Para_t subp;
+ int ret;
+
+ memset(&pesp, 0, sizeof(pesp));
+ pesp.packet = pes_sub_cb;
+ pesp.user_data = this;
+ ret = AM_PES_Create(&pes_handle, &pesp);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_PES_Create != AM_SUCCESS");
+ goto error;
+ }
+
+ memset(&subp, 0, sizeof(subp));
+ subp.show = show_sub_cb;
+ subp.get_pts = get_pts_cb;
+ subp.composition_id = page_id;
+ subp.ancillary_id = anc_page_id;
+ subp.user_data = this;
+ ret = AM_SUB2_Create(&sub_handle, &subp);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_SUB2_Create != AM_SUCCESS");
+ goto error;
+ }
+
+ ret = AM_SUB2_Start(sub_handle);
+ if (ret != AM_SUCCESS) {
+ LOGD("error AM_SUB2_Start != AM_SUCCESS");
+ goto error;
+ }
+
+ ret = open_dmx(this, dmx_id, pid);
+ if (ret < 0) {
+ LOGD("error open_dmx != AM_SUCCESS");
+ goto error;
+ }
+ isSubOpen = true;
+ return 0;
error:
- if (sub_handle) {
- AM_SUB2_Destroy(sub_handle);
- sub_handle = NULL;
- }
- if (pes_handle) {
- AM_PES_Destroy(pes_handle);
- pes_handle = NULL;
- }
- return -1;
+ if (sub_handle) {
+ AM_SUB2_Destroy(sub_handle);
+ sub_handle = NULL;
+ }
+ if (pes_handle) {
+ AM_PES_Destroy(pes_handle);
+ pes_handle = NULL;
+ }
+ return -1;
}
int CTvSubtitle::sub_start_dtv_tt(int dmx_id, int region_id, int pid, int page, int sub_page, bool is_sub)
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_stop_dvb_sub()
{
- pthread_mutex_lock(&lock);
- close_dmx(this);
- AM_SUB2_Destroy(sub_handle);
- AM_PES_Destroy(pes_handle);
+ pthread_mutex_lock(&lock);
+ close_dmx(this);
+ AM_SUB2_Destroy(sub_handle);
+ AM_PES_Destroy(pes_handle);
- clear_bitmap(this);
- mpObser->updateSubtitle(0, 0);
+ clear_bitmap(this);
+ mpObser->updateSubtitle(0, 0);
- sub_handle = NULL;
- pes_handle = NULL;
- isSubOpen = false;
- pthread_mutex_unlock(&lock);
- return 0;
+ sub_handle = NULL;
+ pes_handle = NULL;
+ isSubOpen = false;
+ pthread_mutex_unlock(&lock);
+ return 0;
}
int CTvSubtitle::sub_stop_dtv_tt()
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_tt_goto(int page)
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_tt_color_link(int color)
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_tt_home_link()
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_tt_next(int dir)
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_tt_set_search_pattern(char *pattern, bool casefold)
{
- return 0;
+ return 0;
}
int CTvSubtitle::sub_tt_search(int dir)
{
- return 0;
+ return 0;
}
/*
@@ -524,92 +524,92 @@ program, no signal, blocked...*/
//else != 0
int CTvSubtitle::sub_start_atsc_cc(enum cc_param_country country, enum cc_param_source_type src_type, int channel_num, enum cc_param_caption_type caption_type)
{
- LOGD("----sub_start_atsc_cc-1--- country=%d,src=%d,ctype=%d", country, src_type, caption_type);
- switch (country) {
- case CC_PARAM_COUNTRY_USA:
- AM_CC_Cmd(CMD_SET_COUNTRY_USA);
- break;
- case CC_PARAM_COUNTRY_KOREA:
- AM_CC_Cmd(CMD_SET_COUNTRY_KOREA);
- break;
- default:
- AM_CC_Cmd(CMD_SET_COUNTRY_USA);
- break;
- }
-
- switch (src_type) {
- case CC_PARAM_SOURCE_VBIDATA:
- AM_CC_Cmd(CMD_CC_SET_VBIDATA);
- break;
- case CC_PARAM_SOURCE_USERDATA:
- AM_CC_Cmd(CMD_CC_SET_USERDATA);
- break;
- default:
- AM_CC_Cmd(CMD_CC_SET_USERDATA);
- break;
- }
-
- //just for test
- if (channel_num == 0) {
- } else {
- //AM_CC_Cmd(CMD_CC_SET_CHAN_NUM);
- }
-
- AM_CLOSECAPTION_cmd_t cc_t_cmd;
- switch (caption_type) {
- case CC_PARAM_ANALOG_CAPTION_TYPE_CC1:
- cc_t_cmd = CMD_CC_1;
- break;
- case CC_PARAM_ANALOG_CAPTION_TYPE_CC2:
- cc_t_cmd = CMD_CC_2;
- break;
- case CC_PARAM_ANALOG_CAPTION_TYPE_CC3:
- cc_t_cmd = CMD_CC_3;
- break;
- case CC_PARAM_ANALOG_CAPTION_TYPE_CC4:
- cc_t_cmd = CMD_CC_4;
- break;
- case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE1:
- cc_t_cmd = CMD_SERVICE_1;
- break;
- case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE2:
- cc_t_cmd = CMD_SERVICE_2;
- break;
- case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE3:
- cc_t_cmd = CMD_SERVICE_3;
- break;
- case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE4:
- cc_t_cmd = CMD_SERVICE_4;
- break;
- default:
- cc_t_cmd = CMD_SERVICE_1;
- break;
- }
- AM_CC_Cmd(cc_t_cmd);
-
- AM_CC_Set_CallBack(close_caption_callback, this);
- AM_VCHIP_Set_CallBack(atv_vchip_callback, this);
- //start
- AM_CC_Cmd(CMD_CC_START);
- LOGD("----sub_start_atsc_cc-2--- country=%d,src=%d,ctype=%d", country, src_type, caption_type);
- return 0;
+ LOGD("----sub_start_atsc_cc-1--- country=%d,src=%d,ctype=%d", country, src_type, caption_type);
+ switch (country) {
+ case CC_PARAM_COUNTRY_USA:
+ AM_CC_Cmd(CMD_SET_COUNTRY_USA);
+ break;
+ case CC_PARAM_COUNTRY_KOREA:
+ AM_CC_Cmd(CMD_SET_COUNTRY_KOREA);
+ break;
+ default:
+ AM_CC_Cmd(CMD_SET_COUNTRY_USA);
+ break;
+ }
+
+ switch (src_type) {
+ case CC_PARAM_SOURCE_VBIDATA:
+ AM_CC_Cmd(CMD_CC_SET_VBIDATA);
+ break;
+ case CC_PARAM_SOURCE_USERDATA:
+ AM_CC_Cmd(CMD_CC_SET_USERDATA);
+ break;
+ default:
+ AM_CC_Cmd(CMD_CC_SET_USERDATA);
+ break;
+ }
+
+ //just for test
+ if (channel_num == 0) {
+ } else {
+ //AM_CC_Cmd(CMD_CC_SET_CHAN_NUM);
+ }
+
+ AM_CLOSECAPTION_cmd_t cc_t_cmd;
+ switch (caption_type) {
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC1:
+ cc_t_cmd = CMD_CC_1;
+ break;
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC2:
+ cc_t_cmd = CMD_CC_2;
+ break;
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC3:
+ cc_t_cmd = CMD_CC_3;
+ break;
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC4:
+ cc_t_cmd = CMD_CC_4;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE1:
+ cc_t_cmd = CMD_SERVICE_1;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE2:
+ cc_t_cmd = CMD_SERVICE_2;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE3:
+ cc_t_cmd = CMD_SERVICE_3;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE4:
+ cc_t_cmd = CMD_SERVICE_4;
+ break;
+ default:
+ cc_t_cmd = CMD_SERVICE_1;
+ break;
+ }
+ AM_CC_Cmd(cc_t_cmd);
+
+ AM_CC_Set_CallBack(close_caption_callback, this);
+ AM_VCHIP_Set_CallBack(atv_vchip_callback, this);
+ //start
+ AM_CC_Cmd(CMD_CC_START);
+ LOGD("----sub_start_atsc_cc-2--- country=%d,src=%d,ctype=%d", country, src_type, caption_type);
+ return 0;
}
int CTvSubtitle::sub_stop_atsc_cc()
{
- LOGD("----sub_stop_atsc_cc----");
- AM_CC_Cmd(CMD_CC_STOP);
- return 0;
+ LOGD("----sub_stop_atsc_cc----");
+ AM_CC_Cmd(CMD_CC_STOP);
+ return 0;
}
int CTvSubtitle::ResetVchipChgStat()
{
- avchip_chg = 0;
- AM_CC_Cmd(CMD_VCHIP_RST_CHGSTAT);
- return 0;
+ avchip_chg = 0;
+ AM_CC_Cmd(CMD_VCHIP_RST_CHGSTAT);
+ return 0;
}
int CTvSubtitle::IsVchipChange()
{
- return avchip_chg;
+ return avchip_chg;
}
//cnt :data buf len
//databuf len is max 512
@@ -617,27 +617,27 @@ int CTvSubtitle::IsVchipChange()
void CTvSubtitle::close_caption_callback(char *str, int cnt, int data_buf[], int cmd_buf[], void *user_data)
{
- /*
- CTvSubtitle *pSub = (CTvSubtitle *)user_data;
+ /*
+ CTvSubtitle *pSub = (CTvSubtitle *)user_data;
- if (pSub == NULL)
- {
- LOGD("sub cc callback is null user data for this");
- return;
- }
+ if (pSub == NULL)
+ {
+ LOGD("sub cc callback is null user data for this");
+ return;
+ }
- if (pSub->mpObser == NULL) return;
+ if (pSub->mpObser == NULL) return;
- pSub->mCurCCEv.mDataBufSize = cnt;
- pSub->mCurCCEv.mpDataBuffer = data_buf;
- pSub->mCurCCEv.mCmdBufSize = 128;//max
- pSub->mCurCCEv.mpCmdBuffer = cmd_buf;
+ pSub->mCurCCEv.mDataBufSize = cnt;
+ pSub->mCurCCEv.mpDataBuffer = data_buf;
+ pSub->mCurCCEv.mCmdBufSize = 128;//max
+ pSub->mCurCCEv.mpCmdBuffer = cmd_buf;
- pSub->mpObser->onEvent(pSub->mCurCCEv);
- */
+ pSub->mpObser->onEvent(pSub->mCurCCEv);
+ */
}
void CTvSubtitle::atv_vchip_callback(int Is_chg, void *user_data)
{
- CTvSubtitle *pSub = (CTvSubtitle *)user_data;
- pSub->avchip_chg = Is_chg;
+ CTvSubtitle *pSub = (CTvSubtitle *)user_data;
+ pSub->avchip_chg = Is_chg;
}