summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_input.cpp45
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h100
-rw-r--r--tvapi/android/include/ITvClient.h58
-rw-r--r--tvapi/android/include/ITvService.h68
-rw-r--r--tvapi/android/include/Tv.h161
-rw-r--r--tvapi/android/include/tvcmd.h1188
-rw-r--r--tvapi/android/jni/Android.mk132
-rw-r--r--tvapi/android/jni/android_amlogic_tv.cpp911
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp289
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp117
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp101
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tvserver/Android.mk162
-rw-r--r--tvapi/android/tvserver/TvService.cpp8755
-rw-r--r--tvapi/android/tvserver/TvService.h164
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rwxr-xr-x[-rw-r--r--]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk3
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2426
-rw-r--r--tvapi/libtv/audio/audio_alsa.h261
-rw-r--r--tvapi/libtv/audio/audio_android.cpp2070
-rw-r--r--tvapi/libtv/audio/audio_android.h157
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp1182
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h131
-rw-r--r--tvapi/libtv/audio/audio_api.cpp4940
-rw-r--r--tvapi/libtv/audio/audio_api.h647
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp456
-rw-r--r--tvapi/libtv/audio/audio_effect.h63
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h306
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h508
-rw-r--r--tvapi/libtv/include/ve.h438
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp426
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h47
-rw-r--r--tvapi/libtv/tv/CAv.cpp484
-rw-r--r--tvapi/libtv/tv/CAv.h194
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2326
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h680
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp838
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h227
-rw-r--r--tvapi/libtv/tv/CTv.cpp10755
-rw-r--r--tvapi/libtv/tv/CTv.h1269
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h167
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h15
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp260
-rw-r--r--tvapi/libtv/tv/CTvEpg.h280
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h314
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h93
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h43
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1417
-rw-r--r--tvapi/libtv/tv/CTvScanner.h319
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1060
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp272
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h469
-rw-r--r--tvapi/libtv/tv/CTvTime.h137
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h43
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h284
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h79
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf58
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp106
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h40
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp694
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h575
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp300
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h190
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h196
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp482
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h171
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h61
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1766
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1065
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h85
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp448
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4240
-rw-r--r--tvapi/libtv/tvin/CTvin.h2222
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h101
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp706
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h153
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h53
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h75
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4424
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h742
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h11
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2784
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp3706
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h338
-rw-r--r--tvapi/libtv/tvutils/CCondition.h87
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp250
-rw-r--r--tvapi/libtv/tvutils/CFile.h53
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h9
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp144
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h44
-rw-r--r--tvapi/libtv/tvutils/CMutex.h116
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h98
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h45
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h292
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h79
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp196
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h49
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h72
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3822
-rw-r--r--tvapi/libtv/tvutils/tvutils.h238
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h57
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3183
-rw-r--r--tvapi/libtv/vpp/CPQdb.h321
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp4772
-rw-r--r--tvapi/libtv/vpp/CVpp.h683
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp30
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
147 files changed, 55964 insertions, 55946 deletions
diff --git a/tvapi/libtv/tvutils/CMsgQueue.cpp b/tvapi/libtv/tvutils/CMsgQueue.cpp
index 16da460..09627b5 100644
--- a/tvapi/libtv/tvutils/CMsgQueue.cpp
+++ b/tvapi/libtv/tvutils/CMsgQueue.cpp
@@ -3,8 +3,8 @@
#include <utils/Timers.h>
CMessage::CMessage()
{
- mDelayMs = 0;
- mWhenMs = 0;
+ mDelayMs = 0;
+ mWhenMs = 0;
}
CMessage::~CMessage()
@@ -19,98 +19,98 @@ CMsgQueueThread::CMsgQueueThread()
CMsgQueueThread::~CMsgQueueThread()
{
- //请求退出处理线程,并阻塞
- requestExitAndWait();
+ //请求退出处理线程,并阻塞
+ requestExitAndWait();
}
nsecs_t CMsgQueueThread::getNowMs()
{
- return systemTime(SYSTEM_TIME_MONOTONIC) / 1000000;
+ return systemTime(SYSTEM_TIME_MONOTONIC) / 1000000;
}
void CMsgQueueThread::sendMsg(CMessage &msg)
{
- CMutex::Autolock _l(mLockQueue);
- msg.mWhenMs = getNowMs() + msg.mDelayMs;//
+ CMutex::Autolock _l(mLockQueue);
+ msg.mWhenMs = getNowMs() + msg.mDelayMs;//
- int i = 0;
- while (i < m_v_msg.size() && m_v_msg[i].mWhenMs <= msg.mWhenMs) i++; //find the index that will insert(i)
- m_v_msg.insertAt(msg, i);//insert at index i
- CMessage msg1 = m_v_msg[0];
- LOGD("sendmsg now2 = %lld i = %d", getNowMs(), i);
- LOGD("sendmsg now3 = %lld msg1 when = %lld", getNowMs(), msg1.mWhenMs);
- //
- //if(i == 0)// is empty or new whenMS is at index 0, low all ms in list. so ,need to wakeup loop, to get new delay time.
- mGetMsgCondition.signal();
+ int i = 0;
+ while(i < m_v_msg.size() && m_v_msg[i].mWhenMs <= msg.mWhenMs) i++;//find the index that will insert(i)
+ m_v_msg.insertAt(msg, i);//insert at index i
+ CMessage msg1 = m_v_msg[0];
+ LOGD("sendmsg now2 = %lld i = %d", getNowMs(), i);
+ LOGD("sendmsg now3 = %lld msg1 when = %lld", getNowMs(), msg1.mWhenMs);
+ //
+ //if(i == 0)// is empty or new whenMS is at index 0, low all ms in list. so ,need to wakeup loop, to get new delay time.
+ mGetMsgCondition.signal();
}
//有个缺陷,只能根据消息类型移除,同类型消息会全部移除,但足够用了
void CMsgQueueThread::removeMsg(CMessage &msg)
{
- CMutex::Autolock _l(mLockQueue);
- int beforeSize = m_v_msg.size();
- for (int i = 0; i < m_v_msg.size(); i++) {
- const CMessage &_msg = m_v_msg.itemAt(i);
- if (_msg.mType == msg.mType) {
- m_v_msg.removeAt(i);
- }
- }
- //some msg removeed
- if (beforeSize > m_v_msg.size())
- mGetMsgCondition.signal();
+ CMutex::Autolock _l(mLockQueue);
+ int beforeSize = m_v_msg.size();
+ for (int i = 0; i < m_v_msg.size(); i++) {
+ const CMessage &_msg = m_v_msg.itemAt(i);
+ if (_msg.mType == msg.mType) {
+ m_v_msg.removeAt(i);
+ }
+ }
+ //some msg removeed
+ if(beforeSize > m_v_msg.size())
+ mGetMsgCondition.signal();
}
int CMsgQueueThread::startMsgQueue()
{
- CMutex::Autolock _l(mLockQueue);
- this->run();
- return 0;
+ CMutex::Autolock _l(mLockQueue);
+ this->run();
+ return 0;
}
bool CMsgQueueThread::threadLoop()
{
- int sleeptime = 100;//ms
+ int sleeptime = 100;//ms
- while (!exitPending()) { //requietexit() or requietexitWait() not call
- mLockQueue.lock();
- while (m_v_msg.size() == 0) { //msg queue is empty
- mGetMsgCondition.wait(mLockQueue);//first unlock,when return,lock again,so need,call unlock
- }
- mLockQueue.unlock();
- //get delay time
- CMessage msg;
- nsecs_t delayMs = 0, nowMS = 0;
- do { //wait ,until , the lowest time msg's whentime is low nowtime, to go on
- if (m_v_msg.size() <= 0) {
- LOGD("msg size is 0, break");
- break;
- }
- mLockQueue.lock();//get msg ,first lock.
- msg = m_v_msg[0];//get first
- mLockQueue.unlock();
+ while(!exitPending()) { //requietexit() or requietexitWait() not call
+ mLockQueue.lock();
+ while(m_v_msg.size() == 0) { //msg queue is empty
+ mGetMsgCondition.wait(mLockQueue);//first unlock,when return,lock again,so need,call unlock
+ }
+ mLockQueue.unlock();
+ //get delay time
+ CMessage msg;
+ nsecs_t delayMs = 0, nowMS = 0;
+ do { //wait ,until , the lowest time msg's whentime is low nowtime, to go on
+ if(m_v_msg.size() <= 0) {
+ LOGD("msg size is 0, break");
+ break;
+ }
+ mLockQueue.lock();//get msg ,first lock.
+ msg = m_v_msg[0];//get first
+ mLockQueue.unlock();
- delayMs = msg.mWhenMs - getNowMs();
- LOGD("threadLoop now = %lld mswhen = %lld delayMs = %lld msg type = %d", getNowMs(), msg.mWhenMs, delayMs, msg.mType);
- if (delayMs > 0) {
- mLockQueue.lock();//get msg ,first lock.
- int ret = mGetMsgCondition.waitRelative(mLockQueue, delayMs);
- mLockQueue.unlock();
- LOGD("msg queue wait ret = %d", ret);
- } else {
- break;
- }
- } while (true); //msg[0], timeout
+ delayMs = msg.mWhenMs - getNowMs();
+ LOGD("threadLoop now = %lld mswhen = %lld delayMs = %lld msg type = %d", getNowMs(), msg.mWhenMs, delayMs, msg.mType);
+ if(delayMs > 0) {
+ mLockQueue.lock();//get msg ,first lock.
+ int ret = mGetMsgCondition.waitRelative(mLockQueue, delayMs);
+ mLockQueue.unlock();
+ LOGD("msg queue wait ret = %d", ret);
+ } else {
+ break;
+ }
+ } while(true); //msg[0], timeout
- if (m_v_msg.size() > 0) {
- mLockQueue.lock();//
- msg = m_v_msg[0];
- m_v_msg.removeAt(0);
- mLockQueue.unlock();//
- //handle it
- handleMessage(msg);
- }
+ if(m_v_msg.size() > 0) {
+ mLockQueue.lock();//
+ msg = m_v_msg[0];
+ m_v_msg.removeAt(0);
+ mLockQueue.unlock();//
+ //handle it
+ handleMessage(msg);
+ }
- //usleep(sleeptime * 1000);
- }
- //exit
- //return true, run again, return false,not run.
- return false;
+ //usleep(sleeptime * 1000);
+ }
+ //exit
+ //return true, run again, return false,not run.
+ return false;
}