summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk14
-rw-r--r--screen_source/Android.mk31
-rw-r--r--screen_source/aml_screen.cpp296
-rw-r--r--screen_source/v4l2_vdin.cpp676
-rw-r--r--screen_source/v4l2_vdin.h144
-rw-r--r--tv_callback.h18
-rw-r--r--tv_input.cpp263
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h98
-rw-r--r--tvapi/android/include/ITvClient.h56
-rw-r--r--tvapi/android/include/ITvService.h66
-rw-r--r--tvapi/android/include/Tv.h158
-rw-r--r--tvapi/android/include/tvcmd.h1212
-rw-r--r--tvapi/android/jni/Android.mk135
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp18
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp (renamed from tvapi/android/jni/android_amlogic_tv.cpp)929
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp292
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp116
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp100
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tv/Android.mk23
-rw-r--r--tvapi/android/tv/CTv.cpp104
-rw-r--r--tvapi/android/tv/CTv.h54
-rw-r--r--tvapi/android/tvserver/Android.mk164
-rw-r--r--tvapi/android/tvserver/TvService.cpp8911
-rw-r--r--tvapi/android/tvserver/TvService.h170
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rw-r--r--tvapi/android/tvserver/tv_callback.h18
-rw-r--r--[-rwxr-xr-x]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/build/include/xxxconfig.h1
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk12
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp126
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h31
-rw-r--r--tvapi/libtv/audio/CTvAudio.cpp30
-rw-r--r--tvapi/libtv/audio/CTvAudio.h76
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2073
-rw-r--r--tvapi/libtv/audio/audio_alsa.h257
-rw-r--r--tvapi/libtv/audio/audio_android.cpp1035
-rw-r--r--tvapi/libtv/audio/audio_android.h78
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp591
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h65
-rw-r--r--tvapi/libtv/audio/audio_api.cpp2470
-rw-r--r--tvapi/libtv/audio/audio_api.h323
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp356
-rw-r--r--tvapi/libtv/audio/audio_effect.h58
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h308
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h316
-rw-r--r--tvapi/libtv/include/ve.h461
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp425
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp150
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h41
-rw-r--r--tvapi/libtv/tv/CAv.cpp116
-rw-r--r--tvapi/libtv/tv/CAv.h24
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp443
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h25
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp198
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h19
-rw-r--r--tvapi/libtv/tv/CTv.cpp13003
-rw-r--r--tvapi/libtv/tv/CTv.h1453
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h166
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp24
-rw-r--r--tvapi/libtv/tv/CTvEv.h12
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h92
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h42
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp335
-rw-r--r--tvapi/libtv/tv/CTvScanner.h26
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1279
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp361
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h484
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp6
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp4
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h282
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp379
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-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.h574
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp25
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h188
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp86
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h194
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp483
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h170
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h60
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1806
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1066
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h84
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp38
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp478
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h73
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp203
-rw-r--r--tvapi/libtv/tvin/CTvin.h191
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h100
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp403
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h152
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h52
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h74
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4658
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.h30
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h782
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp10
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2726
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.h64
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp2575
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h239
-rw-r--r--tvapi/libtv/tvutils/CCondition.h2
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp65
-rw-r--r--tvapi/libtv/tvutils/CFile.h3
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp2
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp31
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h3
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h96
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp18
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp8
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h12
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp2
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp25
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h4
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp66
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h70
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3931
-rw-r--r--tvapi/libtv/tvutils/tvutils.h222
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp2
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3509
-rw-r--r--tvapi/libtv/vpp/CPQdb.h340
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp5602
-rw-r--r--tvapi/libtv/vpp/CVpp.h230
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp2
-rw-r--r--tvapi/tvtests/comm_test.cpp4
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
151 files changed, 45277 insertions, 47437 deletions
diff --git a/tvapi/android/libtvbinder/ITv.cpp b/tvapi/android/libtvbinder/ITv.cpp
index f32a1af..0be4f87 100644
--- a/tvapi/android/libtvbinder/ITv.cpp
+++ b/tvapi/android/libtvbinder/ITv.cpp
@@ -1,144 +1,148 @@
-//#define LOG_NDEBUG 0
-#define LOG_TAG "ITv"
-#include <utils/Log.h>
-#include <stdint.h>
-#include <sys/types.h>
-#include <binder/Parcel.h>
-#include <include/ITv.h>
-
-enum {
- DISCONNECT = IBinder::FIRST_CALL_TRANSACTION,
- START_PREVIEW,
- SEND_COMMAND,
- CONNECT,
- LOCK,
- UNLOCK,
- TV_CMD,
- TV_CREATE_SUBTITLE,
- TV_CREATE_VIDEO_FRAME,
-};
-
-class BpTv: public BpInterface<ITv> {
-public:
- BpTv(const sp<IBinder> &impl)
- : BpInterface<ITv>(impl)
- {
- }
-
- // disconnect from tv service
- void disconnect()
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- remote()->transact(DISCONNECT, data, &reply);
- }
-
- status_t processCmd(const Parcel &p, Parcel *r)
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- data.write(p.data(), p.dataSize());
- remote()->transact(TV_CMD, data, &reply);
- r->write(reply.data(), reply.dataSize());
- r->setDataPosition(0);
- return 0;
- }
-
- virtual status_t createVideoFrame(const sp<IMemory> &share_mem)
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- data.writeStrongBinder(share_mem->asBinder());
- remote()->transact(TV_CREATE_VIDEO_FRAME, data, &reply);
- return reply.readInt32();
- }
-
- virtual status_t createSubtitle(const sp<IMemory> &share_mem)
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- data.writeStrongBinder(share_mem->asBinder());
- remote()->transact(TV_CREATE_SUBTITLE, data, &reply);
- return reply.readInt32();
- }
- virtual status_t connect(const sp<ITvClient> &tvClient)
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- data.writeStrongBinder(tvClient->asBinder());
- remote()->transact(CONNECT, data, &reply);
- return reply.readInt32();
- }
- virtual status_t lock()
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- remote()->transact(LOCK, data, &reply);
- return reply.readInt32();
- }
- virtual status_t unlock()
- {
- Parcel data, reply;
- data.writeInterfaceToken(ITv::getInterfaceDescriptor());
- remote()->transact(UNLOCK, data, &reply);
- return reply.readInt32();
- }
-};
-
-IMPLEMENT_META_INTERFACE(Tv, "android.amlogic.ITv");
-
-status_t BnTv::onTransact(
- uint32_t code, const Parcel &data, Parcel *reply, uint32_t flags)
-{
- switch(code) {
- case DISCONNECT: {
- CHECK_INTERFACE(ITv, data, reply);
- disconnect();
- return NO_ERROR;
- }
- break;
- case CONNECT: {
- CHECK_INTERFACE(ITv, data, reply);
- sp<ITvClient> tvClient = interface_cast<ITvClient>(data.readStrongBinder());
- reply->writeInt32(connect(tvClient));
- return NO_ERROR;
- }
- break;
- case LOCK: {
- CHECK_INTERFACE(ITv, data, reply);
- reply->writeInt32(lock());
- return NO_ERROR;
- }
- break;
- case UNLOCK: {
- CHECK_INTERFACE(ITv, data, reply);
- reply->writeInt32(unlock());
- return NO_ERROR;
- }
- break;
- case TV_CMD: {
- CHECK_INTERFACE(ITv, data, reply);
- processCmd(data, reply);
- //reply->write(tmp.data(), tmp.dataSize());
- return NO_ERROR;
- }
- case TV_CREATE_SUBTITLE: {
- CHECK_INTERFACE(ITv, data, reply);
- sp<IMemory> buffer = interface_cast<IMemory>(data.readStrongBinder());
- createSubtitle(buffer);
- //reply->write(tmp.data(), tmp.dataSize());
- return NO_ERROR;
- }
- case TV_CREATE_VIDEO_FRAME: {
- CHECK_INTERFACE(ITv, data, reply);
- sp<IMemory> buffer = interface_cast<IMemory>(data.readStrongBinder());
- createVideoFrame(buffer);
- //reply->write(tmp.data(), tmp.dataSize());
- return NO_ERROR;
- }
- break;
- default:
- return BBinder::onTransact(code, data, reply, flags);
- }
-}
-
+//#define LOG_NDEBUG 0
+#define LOG_TAG "ITv"
+#include <utils/Log.h>
+#include <stdint.h>
+#include <sys/types.h>
+#include <binder/Parcel.h>
+#include <include/ITv.h>
+
+enum {
+ DISCONNECT = IBinder::FIRST_CALL_TRANSACTION,
+ START_PREVIEW,
+ SEND_COMMAND,
+ CONNECT,
+ LOCK,
+ UNLOCK,
+ TV_CMD,
+ TV_CREATE_SUBTITLE,
+ TV_CREATE_VIDEO_FRAME,
+};
+
+class BpTv: public BpInterface<ITv> {
+public:
+ BpTv(const sp<IBinder> &impl)
+ : BpInterface<ITv>(impl)
+ {
+ }
+
+ // disconnect from tv service
+ void disconnect()
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ remote()->transact(DISCONNECT, data, &reply);
+ }
+
+ status_t processCmd(const Parcel &p, Parcel *r)
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ data.write(p.data(), p.dataSize());
+ remote()->transact(TV_CMD, data, &reply);
+ r->write(reply.data(), reply.dataSize());
+ r->setDataPosition(0);
+ return 0;
+ }
+
+ virtual status_t createVideoFrame(const sp<IMemory> &share_mem, int iSourceMode, int iCapVideoLayerOnly)
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ data.writeStrongBinder(IInterface::asBinder(share_mem));
+ data.writeInt32(iSourceMode);
+ data.writeInt32(iCapVideoLayerOnly);
+ remote()->transact(TV_CREATE_VIDEO_FRAME, data, &reply);
+ return reply.readInt32();
+ }
+
+ virtual status_t createSubtitle(const sp<IMemory> &share_mem)
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ data.writeStrongBinder(IInterface::asBinder(share_mem));
+ remote()->transact(TV_CREATE_SUBTITLE, data, &reply);
+ return reply.readInt32();
+ }
+ virtual status_t connect(const sp<ITvClient> &tvClient)
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ data.writeStrongBinder(IInterface::asBinder(tvClient));
+ remote()->transact(CONNECT, data, &reply);
+ return reply.readInt32();
+ }
+ virtual status_t lock()
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ remote()->transact(LOCK, data, &reply);
+ return reply.readInt32();
+ }
+ virtual status_t unlock()
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ITv::getInterfaceDescriptor());
+ remote()->transact(UNLOCK, data, &reply);
+ return reply.readInt32();
+ }
+};
+
+IMPLEMENT_META_INTERFACE(Tv, "android.amlogic.ITv");
+
+status_t BnTv::onTransact(
+ uint32_t code, const Parcel &data, Parcel *reply, uint32_t flags)
+{
+ switch (code) {
+ case DISCONNECT: {
+ CHECK_INTERFACE(ITv, data, reply);
+ disconnect();
+ return NO_ERROR;
+ }
+ break;
+ case CONNECT: {
+ CHECK_INTERFACE(ITv, data, reply);
+ sp<ITvClient> tvClient = interface_cast<ITvClient>(data.readStrongBinder());
+ reply->writeInt32(connect(tvClient));
+ return NO_ERROR;
+ }
+ break;
+ case LOCK: {
+ CHECK_INTERFACE(ITv, data, reply);
+ reply->writeInt32(lock());
+ return NO_ERROR;
+ }
+ break;
+ case UNLOCK: {
+ CHECK_INTERFACE(ITv, data, reply);
+ reply->writeInt32(unlock());
+ return NO_ERROR;
+ }
+ break;
+ case TV_CMD: {
+ CHECK_INTERFACE(ITv, data, reply);
+ processCmd(data, reply);
+ //reply->write(tmp.data(), tmp.dataSize());
+ return NO_ERROR;
+ }
+ case TV_CREATE_SUBTITLE: {
+ CHECK_INTERFACE(ITv, data, reply);
+ sp<IMemory> buffer = interface_cast<IMemory>(data.readStrongBinder());
+ createSubtitle(buffer);
+ //reply->write(tmp.data(), tmp.dataSize());
+ return NO_ERROR;
+ }
+ case TV_CREATE_VIDEO_FRAME: {
+ CHECK_INTERFACE(ITv, data, reply);
+ sp<IMemory> buffer = interface_cast<IMemory>(data.readStrongBinder());
+ int srcMode = data.readInt32();
+ int capVideoLayerOnly = data.readInt32();
+ createVideoFrame(buffer, srcMode, capVideoLayerOnly);
+ //reply->write(tmp.data(), tmp.dataSize());
+ return NO_ERROR;
+ }
+ break;
+ default:
+ return BBinder::onTransact(code, data, reply, flags);
+ }
+}
+