diff options
31 files changed, 10 insertions, 7364 deletions
diff --git a/.gitignore b/.gitignore index 714470b25e..3390b4eb4c 100644 --- a/.gitignore +++ b/.gitignore @@ -593,7 +593,6 @@ lib/cpluff/stamp-h1 /xbmc/cores/dvdplayer/DVDCodecs/Audio/Makefile /xbmc/cores/dvdplayer/DVDCodecs/Makefile /xbmc/cores/dvdplayer/DVDCodecs/Overlay/Makefile -/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD/Makefile /xbmc/cores/dvdplayer/DVDCodecs/Video/Makefile /xbmc/cores/dvdplayer/DVDDemuxers/Makefile /xbmc/cores/dvdplayer/DVDSubtitles/Makefile diff --git a/XBMC.xcodeproj/project.pbxproj b/XBMC.xcodeproj/project.pbxproj index 84852532db..355816b1d6 100644 --- a/XBMC.xcodeproj/project.pbxproj +++ b/XBMC.xcodeproj/project.pbxproj @@ -1462,8 +1462,6 @@ DFF0F16117528350002DA3A4 /* DVDOverlayCodecSSA.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8883CE9E0DD817D1004E8B72 /* DVDOverlayCodecSSA.cpp */; }; DFF0F16217528350002DA3A4 /* DVDOverlayCodecText.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E38E152F0D25F9F900618676 /* DVDOverlayCodecText.cpp */; }; DFF0F16317528350002DA3A4 /* DVDOverlayCodecTX3G.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5CEE60713D3C89700225F72 /* DVDOverlayCodecTX3G.cpp */; }; - DFF0F16417528350002DA3A4 /* CrystalHD.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5F240EB110A4F76009126C6 /* CrystalHD.cpp */; }; - DFF0F16517528350002DA3A4 /* DVDVideoCodecCrystalHD.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F595994410E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp */; }; DFF0F16617528350002DA3A4 /* DVDVideoCodecFFmpeg.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E38E153D0D25F9F900618676 /* DVDVideoCodecFFmpeg.cpp */; }; DFF0F16717528350002DA3A4 /* DVDVideoCodecLibMpeg2.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E38E153F0D25F9F900618676 /* DVDVideoCodecLibMpeg2.cpp */; }; DFF0F16817528350002DA3A4 /* DVDVideoCodecVDA.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F52B06B81187CE18004B1D66 /* DVDVideoCodecVDA.cpp */; }; @@ -2727,8 +2725,6 @@ E49911C9174E5D2500741B6D /* DVDOverlayCodecSSA.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8883CE9E0DD817D1004E8B72 /* DVDOverlayCodecSSA.cpp */; }; E49911CA174E5D2500741B6D /* DVDOverlayCodecText.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E38E152F0D25F9F900618676 /* DVDOverlayCodecText.cpp */; }; E49911CB174E5D2500741B6D /* DVDOverlayCodecTX3G.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5CEE60713D3C89700225F72 /* DVDOverlayCodecTX3G.cpp */; }; - E49911CC174E5D2500741B6D /* CrystalHD.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5F240EB110A4F76009126C6 /* CrystalHD.cpp */; }; - E49911CD174E5D2500741B6D /* DVDVideoCodecCrystalHD.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F595994410E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp */; }; E49911CE174E5D2500741B6D /* DVDVideoCodecFFmpeg.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E38E153D0D25F9F900618676 /* DVDVideoCodecFFmpeg.cpp */; }; E49911CF174E5D2500741B6D /* DVDVideoCodecLibMpeg2.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E38E153F0D25F9F900618676 /* DVDVideoCodecLibMpeg2.cpp */; }; E49911D0174E5D2500741B6D /* DVDVideoCodecVDA.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F52B06B81187CE18004B1D66 /* DVDVideoCodecVDA.cpp */; }; @@ -3575,7 +3571,6 @@ F584E12E0F257C5100DB26A5 /* HTTPDirectory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F584E12D0F257C5100DB26A5 /* HTTPDirectory.cpp */; }; F58E293911FFC103006F4D46 /* DVDInputStreamBluray.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F58E293711FFC103006F4D46 /* DVDInputStreamBluray.cpp */; }; F592568810FBF2E100D2C91D /* ConvolutionKernels.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F592568710FBF2E100D2C91D /* ConvolutionKernels.cpp */; }; - F595994510E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F595994410E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp */; }; F597B05B18A804E0005AADAE /* DVDVideoCodec.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F597B05A18A804E0005AADAE /* DVDVideoCodec.cpp */; }; F597B05C18A804E0005AADAE /* DVDVideoCodec.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F597B05A18A804E0005AADAE /* DVDVideoCodec.cpp */; }; F597B05D18A804E0005AADAE /* DVDVideoCodec.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F597B05A18A804E0005AADAE /* DVDVideoCodec.cpp */; }; @@ -3682,7 +3677,6 @@ F5ED9A15155EBE0000842059 /* DiskArbitration.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 88ECB6580DE013C4003396A7 /* DiskArbitration.framework */; }; F5ED9BFB155EC77400842059 /* ApplicationServices.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = E38E25340D26365C00618676 /* ApplicationServices.framework */; }; F5EDC48C1651A6F900B852D8 /* GroupUtils.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5EDC48A1651A6F900B852D8 /* GroupUtils.cpp */; }; - F5F240EF110A4F76009126C6 /* CrystalHD.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5F240EB110A4F76009126C6 /* CrystalHD.cpp */; }; F5F244651110DC6B009126C6 /* FileOperationJob.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5F244641110DC6B009126C6 /* FileOperationJob.cpp */; }; F5F245EE1112C9AB009126C6 /* FileUtils.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5F245EC1112C9AB009126C6 /* FileUtils.cpp */; }; F5F2EF4B0E593E0D0092C37F /* DVDFileInfo.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F5F2EF4A0E593E0D0092C37F /* DVDFileInfo.cpp */; }; @@ -6098,8 +6092,6 @@ F58E293811FFC103006F4D46 /* DVDInputStreamBluray.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = DVDInputStreamBluray.h; sourceTree = "<group>"; }; F592568610FBF2E100D2C91D /* ConvolutionKernels.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ConvolutionKernels.h; sourceTree = "<group>"; }; F592568710FBF2E100D2C91D /* ConvolutionKernels.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ConvolutionKernels.cpp; sourceTree = "<group>"; }; - F595994310E9F322004B58B3 /* DVDVideoCodecCrystalHD.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = DVDVideoCodecCrystalHD.h; sourceTree = "<group>"; }; - F595994410E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = DVDVideoCodecCrystalHD.cpp; sourceTree = "<group>"; }; F597B05A18A804E0005AADAE /* DVDVideoCodec.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = DVDVideoCodec.cpp; sourceTree = "<group>"; }; F59876BE0FBA351D008EF4FB /* VideoReferenceClock.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoReferenceClock.h; sourceTree = "<group>"; }; F59876BF0FBA351D008EF4FB /* VideoReferenceClock.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoReferenceClock.cpp; sourceTree = "<group>"; }; @@ -6254,8 +6246,6 @@ F5ED908D15538E2300842059 /* POUtils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = POUtils.h; sourceTree = "<group>"; }; F5EDC48A1651A6F900B852D8 /* GroupUtils.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = GroupUtils.cpp; sourceTree = "<group>"; }; F5EDC48B1651A6F900B852D8 /* GroupUtils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = GroupUtils.h; sourceTree = "<group>"; }; - F5F240EB110A4F76009126C6 /* CrystalHD.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CrystalHD.cpp; sourceTree = "<group>"; }; - F5F240EC110A4F76009126C6 /* CrystalHD.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CrystalHD.h; sourceTree = "<group>"; }; F5F244631110DC6B009126C6 /* FileOperationJob.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = FileOperationJob.h; sourceTree = "<group>"; }; F5F244641110DC6B009126C6 /* FileOperationJob.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = FileOperationJob.cpp; sourceTree = "<group>"; }; F5F245EC1112C9AB009126C6 /* FileUtils.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = FileUtils.cpp; sourceTree = "<group>"; }; @@ -8850,13 +8840,9 @@ isa = PBXGroup; children = ( E38E15430D25F9F900618676 /* libmpeg2 */, - F5F240EB110A4F76009126C6 /* CrystalHD.cpp */, - F5F240EC110A4F76009126C6 /* CrystalHD.h */, E38E153B0D25F9F900618676 /* DllLibMpeg2.h */, F597B05A18A804E0005AADAE /* DVDVideoCodec.cpp */, E38E153C0D25F9F900618676 /* DVDVideoCodec.h */, - F595994410E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp */, - F595994310E9F322004B58B3 /* DVDVideoCodecCrystalHD.h */, E38E153D0D25F9F900618676 /* DVDVideoCodecFFmpeg.cpp */, E38E153E0D25F9F900618676 /* DVDVideoCodecFFmpeg.h */, E38E153F0D25F9F900618676 /* DVDVideoCodecLibMpeg2.cpp */, @@ -11067,12 +11053,10 @@ E4A249F71095C880003D74C6 /* AutorunMediaJob.cpp in Sources */, F5A9D3091097C9370050490F /* AliasShortcutUtils.cpp in Sources */, 431AE5DA109C1A63007428C3 /* OverlayRendererUtil.cpp in Sources */, - F595994510E9F322004B58B3 /* DVDVideoCodecCrystalHD.cpp in Sources */, 7C45DBE910F325C400D4BBF3 /* DAVDirectory.cpp in Sources */, F592568810FBF2E100D2C91D /* ConvolutionKernels.cpp in Sources */, F5DC87E2110A287400EE1B15 /* RingBuffer.cpp in Sources */, F5DC8801110A46C700EE1B15 /* ModplugCodec.cpp in Sources */, - F5F240EF110A4F76009126C6 /* CrystalHD.cpp in Sources */, F5F244651110DC6B009126C6 /* FileOperationJob.cpp in Sources */, F5F245EE1112C9AB009126C6 /* FileUtils.cpp in Sources */, F5A7A702112893E50059D6AA /* AnnouncementManager.cpp in Sources */, @@ -11928,8 +11912,6 @@ DFF0F16117528350002DA3A4 /* DVDOverlayCodecSSA.cpp in Sources */, DFF0F16217528350002DA3A4 /* DVDOverlayCodecText.cpp in Sources */, DFF0F16317528350002DA3A4 /* DVDOverlayCodecTX3G.cpp in Sources */, - DFF0F16417528350002DA3A4 /* CrystalHD.cpp in Sources */, - DFF0F16517528350002DA3A4 /* DVDVideoCodecCrystalHD.cpp in Sources */, DFF0F16617528350002DA3A4 /* DVDVideoCodecFFmpeg.cpp in Sources */, DFF0F16717528350002DA3A4 /* DVDVideoCodecLibMpeg2.cpp in Sources */, DFF0F16817528350002DA3A4 /* DVDVideoCodecVDA.cpp in Sources */, @@ -13125,8 +13107,6 @@ E49911C9174E5D2500741B6D /* DVDOverlayCodecSSA.cpp in Sources */, E49911CA174E5D2500741B6D /* DVDOverlayCodecText.cpp in Sources */, E49911CB174E5D2500741B6D /* DVDOverlayCodecTX3G.cpp in Sources */, - E49911CC174E5D2500741B6D /* CrystalHD.cpp in Sources */, - E49911CD174E5D2500741B6D /* DVDVideoCodecCrystalHD.cpp in Sources */, E49911CE174E5D2500741B6D /* DVDVideoCodecFFmpeg.cpp in Sources */, E49911CF174E5D2500741B6D /* DVDVideoCodecLibMpeg2.cpp in Sources */, E49911D0174E5D2500741B6D /* DVDVideoCodecVDA.cpp in Sources */, diff --git a/configure.in b/configure.in index fb02f14f3a..fb6ab20cb8 100644 --- a/configure.in +++ b/configure.in @@ -151,8 +151,6 @@ vdpau_not_found="== Could not find libvdpau. VDPAU support disabled. ==" vdpau_disabled="== VDPAU support manually disabled. ==" vaapi_not_found="== Could not find libva. VAAPI support disabled. ==" vaapi_disabled="== VAAPI support manually disabled. ==" -crystalhd_not_found="== Could not find libcrystalhd. CrystalHD support disabled. ==" -crystalhd_disabled="== CrystalHD support manually disabled. ==" vtbdecoder_enabled="== VTBDecoder support enabled. ==" vtbdecoder_disabled="== VTBDecoder support manually disabled. ==" openmax_disabled="== OpenMax support manually disabled. ==" @@ -248,12 +246,6 @@ AC_ARG_ENABLE([vaapi], [use_vaapi=$enableval], [use_vaapi=auto]) -AC_ARG_ENABLE([crystalhd], - [AS_HELP_STRING([--enable-crystalhd], - [enable CrystalHD decoding (default is auto)])], - [use_crystalhd=$enableval], - [use_crystalhd=auto]) - AC_ARG_ENABLE([vtbdecoder], [AS_HELP_STRING([--enable-vtbdecoder], [enable VTBDecoder decoding (default is auto)])], @@ -594,7 +586,6 @@ case $host in use_joystick=no use_neon=yes use_libcec=no - use_crystalhd=no use_vtbdecoder=yes use_optical_drive=no use_dvdcss=no @@ -620,7 +611,6 @@ case $host in powerpc-apple-darwin*) use_joystick=no use_vtbdecoder=no - use_crystalhd=no ARCH="powerpc-osx" use_arch="ppc" DEPENDS_ROOT_FOR_XCODE=$(echo ${prefix%/*}) @@ -1842,41 +1832,6 @@ else USE_VAAPI=0 fi -# CrystalHD -if test "x$use_crystalhd" != "xno"; then - SAVE_CFLAGS="$CFLAGS" - CFLAGS="-D__LINUX_USER__" - AC_CHECK_HEADER([libcrystalhd/libcrystalhd_if.h], [], - [ if test "x$use_crystalhd" = "xyes"; then - AC_MSG_ERROR($crystalhd_not_found) - else - use_crystalhd=no - AC_MSG_RESULT($crystalhd_not_found) - fi - USE_CRYSTALHD=0 - ]) - CFLAGS="$SAVE_CFLAGS" - if test "$host_vendor" != "apple"; then - XB_FIND_SONAME([CRYSTALHD], [crystalhd], [use_crystalhd]) - fi - if test "x$use_crystalhd" != "xno"; then - SAVE_CFLAGS="$CFLAGS" - CFLAGS="-D__LINUX_USER__ -lcrystalhd" - # check for new crystalhd lib - AC_COMPILE_IFELSE( - [AC_LANG_SOURCE([#include <libcrystalhd/bc_dts_types.h> - #include <libcrystalhd/bc_dts_defs.h> - PBC_INFO_CRYSTAL bCrystalInfo;])], - [ AC_DEFINE([HAVE_LIBCRYSTALHD], [2], [Define to 2 if you have the 'New Broadcom Crystal HD' library.]) ], - [ AC_DEFINE([HAVE_LIBCRYSTALHD], [1], [Define to 1 if you have the 'Old Broadcom Crystal HD' library.]) ]) - CFLAGS="$SAVE_CFLAGS" - USE_CRYSTALHD=1 - fi -else - AC_MSG_NOTICE($crystalhd_disabled) - USE_CRYSTALHD=0 -fi - # VTBDecoder if test "x$use_vtbdecoder" != "xno"; then if test "$host_vendor" = "apple" ; then @@ -2080,12 +2035,6 @@ else final_message="$final_message\n VAAPI:\tNo" fi -if test "x$use_crystalhd" != "xno"; then - final_message="$final_message\n CrystalHD:\tYes" -else - final_message="$final_message\n CrystalHD:\tNo" -fi - if test "x$use_vtbdecoder" != "xno"; then final_message="$final_message\n VTBDecoder:\tYes" else @@ -2573,7 +2522,6 @@ AC_SUBST(USE_OPENGL) AC_SUBST(USE_OPENGLES) AC_SUBST(USE_VDPAU) AC_SUBST(USE_VAAPI) -AC_SUBST(USE_CRYSTALHD) AC_SUBST(USE_LIBSMBCLIENT) AC_SUBST(USE_LIBNFS) AC_SUBST(USE_LIBAFPCLIENT) diff --git a/docs/README.linux b/docs/README.linux index 32f83307c9..60c76bb30a 100644 --- a/docs/README.linux +++ b/docs/README.linux @@ -46,13 +46,12 @@ Build-Depends: autoconf, automake, autopoint, autotools-dev, cmake, curl, libass-dev (>= 0.9.8), libavahi-client-dev, libavahi-common-dev, libavcodec-dev, libavfilter-dev, libavformat-dev, libavutil-dev, libbluetooth-dev, libbluray-dev, libboost-dev, libboost-thread-dev, libbz2-dev, libcap-dev, libcdio-dev, libcec-dev, - libcrystalhd-dev, libcurl4-gnutls-dev | libcurl4-openssl-dev | libcurl-dev, - libcwiid-dev, libdbus-1-dev, libenca-dev, libflac-dev, libfontconfig-dev, - libfreetype6-dev, libfribidi-dev, libgl1-mesa-dev | libgl-dev, libglew-dev, - libglu1-mesa-dev | libglu-dev, libhal-dev, libhal-storage-dev, libiso9660-dev, - libjasper-dev, libjpeg-dev, libltdl-dev, liblzo2-dev, libmad0-dev, libmicrohttpd-dev, - libmodplug-dev, libmpcdec-dev, libmpeg2-4-dev, libmysqlclient-dev, libnfs-dev, - libogg-dev, libpcre3-dev, libplist-dev, libpng12-dev | libpng-dev, libpostproc-dev, + libcurl4-gnutls-dev | libcurl4-openssl-dev | libcurl-dev, libcwiid-dev, libdbus-1-dev, + libenca-dev, libflac-dev, libfontconfig-dev, libfreetype6-dev, libfribidi-dev, + libgl1-mesa-dev | libgl-dev, libglew-dev, libglu1-mesa-dev | libglu-dev, libhal-dev, + libhal-storage-dev, libiso9660-dev, libjasper-dev, libjpeg-dev, libltdl-dev, liblzo2-dev, + libmad0-dev, libmicrohttpd-dev, libmodplug-dev, libmpcdec-dev, libmpeg2-4-dev, libmysqlclient-dev, + libnfs-dev, libogg-dev, libpcre3-dev, libplist-dev, libpng12-dev | libpng-dev, libpostproc-dev, libpulse-dev, librtmp-dev, libsdl-dev, libsdl-image1.2-dev, libsdl-mixer1.2-dev, libshairplay-dev, libsmbclient-dev, libsqlite3-dev, libssh-dev, libssl-dev, libswscale-dev, libtag1-dev (>= 1.8), libtiff-dev, libtinyxml-dev, libtool, @@ -60,7 +59,6 @@ Build-Depends: autoconf, automake, autopoint, autotools-dev, cmake, curl, libxml2-dev, libxmu-dev, libxrandr-dev, libxslt1-dev, libxt-dev, libyajl-dev, lsb-release, nasm [!amd64], python-dev, python-imaging, python-support, swig, unzip, yasm, zip, zlib1g-dev - Note: For developers and anyone else who compiles frequently it is recommended to use ccache. $ sudo apt-get install ccache diff --git a/language/English (US)/strings.po b/language/English (US)/strings.po index 8050abde86..203396fa64 100644 --- a/language/English (US)/strings.po +++ b/language/English (US)/strings.po @@ -4933,10 +4933,6 @@ msgctxt "#13427" msgid "Allow hardware acceleration (DXVA2)" msgstr "Allow hardware acceleration (DXVA2)" -msgctxt "#13428" -msgid "Allow hardware acceleration (CrystalHD)" -msgstr "Allow hardware acceleration (CrystalHD)" - msgctxt "#13429" msgid "Allow hardware acceleration (VDADecoder)" msgstr "Allow hardware acceleration (VDADecoder)" @@ -11341,10 +11337,6 @@ msgctxt "#36158" msgid "Enable DXVA2 hardware decoding of video files." msgstr "Enable DXVA2 hardware decoding of video files." -msgctxt "#36159" -msgid "Enable CrystalHD decoding of video files." -msgstr "Enable CrystalHD decoding of video files." - msgctxt "#36160" msgid "Enable VDA hardware decoding of video files." msgstr "Enable VDA hardware decoding of video files." diff --git a/lib/win32/libcrystalhd/bc_dts_defs.h b/lib/win32/libcrystalhd/bc_dts_defs.h deleted file mode 100644 index c2a7c2d769..0000000000 --- a/lib/win32/libcrystalhd/bc_dts_defs.h +++ /dev/null @@ -1,635 +0,0 @@ -/******************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: bc_dts_defs.h - * - * Description: Common definitions for all components. Only types - * is allowed to be included from this file. - * - * AU - * - * HISTORY: - * - ******************************************************************** - * This header is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this header. If not, see <http://www.gnu.org/licenses/>. - *******************************************************************/ - -#ifndef _BC_DTS_DEFS_H_ -#define _BC_DTS_DEFS_H_ - -#include "bc_dts_types.h" - -/* BIT Mask */ -#define BC_BIT(_x) (1 << (_x)) - -typedef enum _BC_STATUS { - BC_STS_SUCCESS = 0, - BC_STS_INV_ARG = 1, - BC_STS_BUSY = 2, - BC_STS_NOT_IMPL = 3, - BC_STS_PGM_QUIT = 4, - BC_STS_NO_ACCESS = 5, - BC_STS_INSUFF_RES = 6, - BC_STS_IO_ERROR = 7, - BC_STS_NO_DATA = 8, - BC_STS_VER_MISMATCH = 9, - BC_STS_TIMEOUT = 10, - BC_STS_FW_CMD_ERR = 11, - BC_STS_DEC_NOT_OPEN = 12, - BC_STS_ERR_USAGE = 13, - BC_STS_IO_USER_ABORT = 14, - BC_STS_IO_XFR_ERROR = 15, - BC_STS_DEC_NOT_STARTED = 16, - BC_STS_FWHEX_NOT_FOUND = 17, - BC_STS_FMT_CHANGE = 18, - BC_STS_HIF_ACCESS = 19, - BC_STS_CMD_CANCELLED = 20, - BC_STS_FW_AUTH_FAILED = 21, - BC_STS_BOOTLOADER_FAILED = 22, - BC_STS_CERT_VERIFY_ERROR = 23, - BC_STS_DEC_EXIST_OPEN = 24, - BC_STS_PENDING = 25, - BC_STS_CLK_NOCHG = 26, - - /* Must be the last one.*/ - BC_STS_ERROR = -1 -} BC_STATUS; - -/*------------------------------------------------------* - * Registry Key Definitions * - *------------------------------------------------------*/ -#define BC_REG_KEY_MAIN_PATH "Software\\Broadcom\\MediaPC\\CrystalHD" -#define BC_REG_KEY_FWPATH "FirmwareFilePath" -#define BC_REG_KEY_SEC_OPT "DbgOptions" - -/* - * Options: - * - * b[5] = Enable RSA KEY in EEPROM Support - * b[6] = Enable Old PIB scheme. (0 = Use PIB with video scheme) - * - * b[12] = Enable send message to NotifyIcon - * - */ - -typedef enum _BC_SW_OPTIONS { - BC_OPT_DOSER_OUT_ENCRYPT = BC_BIT(3), - BC_OPT_LINK_OUT_ENCRYPT = BC_BIT(29), -} BC_SW_OPTIONS; - -typedef struct _BC_REG_CONFIG{ - uint32_t DbgOptions; -} BC_REG_CONFIG; - -#if defined(__KERNEL__) || defined(__LINUX_USER__) -#else -/* Align data structures */ -#define ALIGN(x) __declspec(align(x)) -#endif - -/* mode - * b[0]..b[7] = _DtsDeviceOpenMode - * b[8] = Load new FW - * b[9] = Load file play back FW - * b[10] = Disk format (0 for HD DVD and 1 for BLU ray) - * b[11]-b[15] = default output resolution - * b[16] = Skip TX CPB Buffer Check - * b[17] = Adaptive Output Encrypt/Scramble Scheme - * b[18]-b[31] = reserved for future use - */ - -/* To allow multiple apps to open the device. */ -enum _DtsDeviceOpenMode { - DTS_PLAYBACK_MODE = 0, - DTS_DIAG_MODE, - DTS_MONITOR_MODE, - DTS_HWINIT_MODE -}; - -/* To enable the filter to selectively enable/disable fixes or erratas */ -enum _DtsDeviceFixMode { - DTS_LOAD_NEW_FW = BC_BIT(8), - DTS_LOAD_FILE_PLAY_FW = BC_BIT(9), - DTS_DISK_FMT_BD = BC_BIT(10), - /* b[11]-b[15] : Default output resolution */ - DTS_SKIP_TX_CHK_CPB = BC_BIT(16), - DTS_ADAPTIVE_OUTPUT_PER = BC_BIT(17), - DTS_INTELLIMAP = BC_BIT(18), - /* b[19]-b[21] : select clock frequency */ - DTS_PLAYBACK_DROP_RPT_MODE = BC_BIT(22), - DTS_DIAG_TEST_MODE = BC_BIT(23), - DTS_SINGLE_THREADED_MODE = BC_BIT(24), - DTS_FILTER_MODE = BC_BIT(25), - DTS_MFT_MODE = BC_BIT(26) -}; - -#define DTS_DFLT_RESOLUTION(x) (x<<11) - -#define DTS_DFLT_CLOCK(x) (x<<19) - -/* F/W File Version corresponding to S/W Releases */ -enum _FW_FILE_VER { - /* S/W release: 02.04.02 F/W release 2.12.2.0 */ - BC_FW_VER_020402 = ((12<<16) | (2<<8) | (0)) -}; - -/*------------------------------------------------------* - * Stream Types for DtsOpenDecoder() * - *------------------------------------------------------*/ -enum _DtsOpenDecStreamTypes { - BC_STREAM_TYPE_ES = 0, - BC_STREAM_TYPE_PES = 1, - BC_STREAM_TYPE_TS = 2, - BC_STREAM_TYPE_ES_TSTAMP = 6, -}; - -/*------------------------------------------------------* - * Video Algorithms for DtsSetVideoParams() * - *------------------------------------------------------*/ -enum _DtsSetVideoParamsAlgo { - BC_VID_ALGO_H264 = 0, - BC_VID_ALGO_MPEG2 = 1, - BC_VID_ALGO_VC1 = 4, - BC_VID_ALGO_DIVX = 6, - BC_VID_ALGO_VC1MP = 7, -}; - -/*------------------------------------------------------* - * MPEG Extension to the PPB * - *------------------------------------------------------*/ -#define BC_MPEG_VALID_PANSCAN (1) - -typedef struct _BC_PIB_EXT_MPEG { - uint32_t valid; - /* Always valid, defaults to picture size if no - * sequence display extension in the stream. */ - uint32_t display_horizontal_size; - uint32_t display_vertical_size; - - /* MPEG_VALID_PANSCAN - * Offsets are a copy values from the MPEG stream. */ - uint32_t offset_count; - int32_t horizontal_offset[3]; - int32_t vertical_offset[3]; - -} BC_PIB_EXT_MPEG; - -/*------------------------------------------------------* - * H.264 Extension to the PPB * - *------------------------------------------------------*/ -/* Bit definitions for 'other.h264.valid' field */ -#define H264_VALID_PANSCAN (1) -#define H264_VALID_SPS_CROP (2) -#define H264_VALID_VUI (4) - -typedef struct _BC_PIB_EXT_H264 { - /* 'valid' specifies which fields (or sets of - * fields) below are valid. If the corresponding - * bit in 'valid' is NOT set then that field(s) - * is (are) not initialized. */ - uint32_t valid; - - /* H264_VALID_PANSCAN */ - uint32_t pan_scan_count; - int32_t pan_scan_left[3]; - int32_t pan_scan_right[3]; - int32_t pan_scan_top[3]; - int32_t pan_scan_bottom[3]; - - /* H264_VALID_SPS_CROP */ - int32_t sps_crop_left; - int32_t sps_crop_right; - int32_t sps_crop_top; - int32_t sps_crop_bottom; - - /* H264_VALID_VUI */ - uint32_t chroma_top; - uint32_t chroma_bottom; - -} BC_PIB_EXT_H264; - -/*------------------------------------------------------* - * VC1 Extension to the PPB * - *------------------------------------------------------*/ -#define VC1_VALID_PANSCAN (1) - -typedef struct _BC_PIB_EXT_VC1 { - uint32_t valid; - - /* Always valid, defaults to picture size if no - * sequence display extension in the stream. */ - uint32_t display_horizontal_size; - uint32_t display_vertical_size; - - /* VC1 pan scan windows */ - uint32_t num_panscan_windows; - int32_t ps_horiz_offset[4]; - int32_t ps_vert_offset[4]; - int32_t ps_width[4]; - int32_t ps_height[4]; - -} BC_PIB_EXT_VC1; - - -/*------------------------------------------------------* - * Picture Information Block * - *------------------------------------------------------*/ -#if defined(__LINUX_USER__) || defined(_WIN32) -/* Values for 'pulldown' field. '0' means no pulldown information - * was present for this picture. */ -enum { - vdecNoPulldownInfo = 0, - vdecTop = 1, - vdecBottom = 2, - vdecTopBottom = 3, - vdecBottomTop = 4, - vdecTopBottomTop = 5, - vdecBottomTopBottom = 6, - vdecFrame_X2 = 7, - vdecFrame_X3 = 8, - vdecFrame_X1 = 9, - vdecFrame_X4 = 10, -}; - -/* Values for the 'frame_rate' field. */ -enum { - vdecFrameRateUnknown = 0, - vdecFrameRate23_97, - vdecFrameRate24, - vdecFrameRate25, - vdecFrameRate29_97, - vdecFrameRate30, - vdecFrameRate50, - vdecFrameRate59_94, - vdecFrameRate60, - vdecFrameRate14_985, - vdecFrameRate7_496, -}; - -/* Values for the 'aspect_ratio' field. */ -enum { - vdecAspectRatioUnknown = 0, - vdecAspectRatioSquare, - vdecAspectRatio12_11, - vdecAspectRatio10_11, - vdecAspectRatio16_11, - vdecAspectRatio40_33, - vdecAspectRatio24_11, - vdecAspectRatio20_11, - vdecAspectRatio32_11, - vdecAspectRatio80_33, - vdecAspectRatio18_11, - vdecAspectRatio15_11, - vdecAspectRatio64_33, - vdecAspectRatio160_99, - vdecAspectRatio4_3, - vdecAspectRatio16_9, - vdecAspectRatio221_1, - vdecAspectRatioOther = 255, -}; - -/* Values for the 'colour_primaries' field. */ -enum { - vdecColourPrimariesUnknown = 0, - vdecColourPrimariesBT709, - vdecColourPrimariesUnspecified, - vdecColourPrimariesReserved, - vdecColourPrimariesBT470_2M = 4, - vdecColourPrimariesBT470_2BG, - vdecColourPrimariesSMPTE170M, - vdecColourPrimariesSMPTE240M, - vdecColourPrimariesGenericFilm, -}; - -enum { - vdecRESOLUTION_CUSTOM = 0x00000000, /* custom */ - vdecRESOLUTION_480i = 0x00000001, /* 480i */ - vdecRESOLUTION_1080i = 0x00000002, /* 1080i (1920x1080, 60i) */ - vdecRESOLUTION_NTSC = 0x00000003, /* NTSC (720x483, 60i) */ - vdecRESOLUTION_480p = 0x00000004, /* 480p (720x480, 60p) */ - vdecRESOLUTION_720p = 0x00000005, /* 720p (1280x720, 60p) */ - vdecRESOLUTION_PAL1 = 0x00000006, /* PAL_1 (720x576, 50i) */ - vdecRESOLUTION_1080i25 = 0x00000007, /* 1080i25 (1920x1080, 50i) */ - vdecRESOLUTION_720p50 = 0x00000008, /* 720p50 (1280x720, 50p) */ - vdecRESOLUTION_576p = 0x00000009, /* 576p (720x576, 50p) */ - vdecRESOLUTION_1080i29_97 = 0x0000000A, /* 1080i (1920x1080, 59.94i) */ - vdecRESOLUTION_720p59_94 = 0x0000000B, /* 720p (1280x720, 59.94p) */ - vdecRESOLUTION_SD_DVD = 0x0000000C, /* SD DVD (720x483, 60i) */ - vdecRESOLUTION_480p656 = 0x0000000D, /* 480p (720x480, 60p), output bus width 8 bit, clock 74.25MHz */ - vdecRESOLUTION_1080p23_976 = 0x0000000E, /* 1080p23_976 (1920x1080, 23.976p) */ - vdecRESOLUTION_720p23_976 = 0x0000000F, /* 720p23_976 (1280x720p, 23.976p) */ - vdecRESOLUTION_240p29_97 = 0x00000010, /* 240p (1440x240, 29.97p ) */ - vdecRESOLUTION_240p30 = 0x00000011, /* 240p (1440x240, 30p) */ - vdecRESOLUTION_288p25 = 0x00000012, /* 288p (1440x288p, 25p) */ - vdecRESOLUTION_1080p29_97 = 0x00000013, /* 1080p29_97 (1920x1080, 29.97p) */ - vdecRESOLUTION_1080p30 = 0x00000014, /* 1080p30 (1920x1080, 30p) */ - vdecRESOLUTION_1080p24 = 0x00000015, /* 1080p24 (1920x1080, 24p) */ - vdecRESOLUTION_1080p25 = 0x00000016, /* 1080p25 (1920x1080, 25p) */ - vdecRESOLUTION_720p24 = 0x00000017, /* 720p24 (1280x720, 25p) */ - vdecRESOLUTION_720p29_97 = 0x00000018, /* 720p29.97 (1280x720, 29.97p) */ - vdecRESOLUTION_480p23_976 = 0x00000019, /* 480p23.976 (720*480, 23.976) */ - vdecRESOLUTION_480p29_97 = 0x0000001A, /* 480p29.976 (720*480, 29.97p) */ - vdecRESOLUTION_576p25 = 0x0000001B, /* 576p25 (720*576, 25p) */ - /* For Zero Frame Rate */ - vdecRESOLUTION_480p0 = 0x0000001C, /* 480p (720x480, 0p) */ - vdecRESOLUTION_480i0 = 0x0000001D, /* 480i (720x480, 0i) */ - vdecRESOLUTION_576p0 = 0x0000001E, /* 576p (720x576, 0p) */ - vdecRESOLUTION_720p0 = 0x0000001F, /* 720p (1280x720, 0p) */ - vdecRESOLUTION_1080p0 = 0x00000020, /* 1080p (1920x1080, 0p) */ - vdecRESOLUTION_1080i0 = 0x00000021, /* 1080i (1920x1080, 0i) */ -}; - -/* Bit definitions for 'flags' field */ -#define VDEC_FLAG_EOS (0x0004) - -#define VDEC_FLAG_FRAME (0x0000) -#define VDEC_FLAG_FIELDPAIR (0x0008) -#define VDEC_FLAG_TOPFIELD (0x0010) -#define VDEC_FLAG_BOTTOMFIELD (0x0018) - -#define VDEC_FLAG_PROGRESSIVE_SRC (0x0000) -#define VDEC_FLAG_INTERLACED_SRC (0x0020) -#define VDEC_FLAG_UNKNOWN_SRC (0x0040) - -#define VDEC_FLAG_BOTTOM_FIRST (0x0080) -#define VDEC_FLAG_LAST_PICTURE (0x0100) - -#define VDEC_FLAG_PICTURE_META_DATA_PRESENT (0x40000) - -#endif /* __LINUX_USER__ */ - -typedef struct _BC_PIC_INFO_BLOCK { - /* Common fields. */ - uint64_t timeStamp; /* Timestamp */ - uint32_t picture_number; /* Ordinal display number */ - uint32_t width; /* pixels */ - uint32_t height; /* pixels */ - uint32_t chroma_format; /* 0x420, 0x422 or 0x444 */ - uint32_t pulldown; - uint32_t flags; - uint32_t frame_rate; - uint32_t aspect_ratio; - uint32_t colour_primaries; - uint32_t picture_meta_payload; - uint32_t sess_num; - uint32_t ycom; - uint32_t custom_aspect_ratio_width_height; - uint32_t n_drop; /* number of non-reference frames remaining to be dropped */ - - /* Protocol-specific extensions. */ - union { - BC_PIB_EXT_H264 h264; - BC_PIB_EXT_MPEG mpeg; - BC_PIB_EXT_VC1 vc1; - } other; - -} BC_PIC_INFO_BLOCK, *PBC_PIC_INFO_BLOCK; - -/*------------------------------------------------------* - * ProcOut Info * - *------------------------------------------------------*/ -/* Optional flags for ProcOut Interface.*/ -enum _POUT_OPTIONAL_IN_FLAGS_{ - /* Flags from App to Device */ - BC_POUT_FLAGS_YV12 = 0x01, /* Copy Data in YV12 format */ - BC_POUT_FLAGS_STRIDE = 0x02, /* Stride size is valid. */ - BC_POUT_FLAGS_SIZE = 0x04, /* Take size information from Application */ - BC_POUT_FLAGS_INTERLACED = 0x08, /* copy only half the bytes */ - BC_POUT_FLAGS_INTERLEAVED = 0x10, /* interleaved frame */ - BC_POUT_FLAGS_STRIDE_UV = 0x20, /* Stride size is valid (for UV buffers). */ - BC_POUT_FLAGS_MODE = 0x40, /* Take output mode from Application, overrides YV12 flag if on */ - - /* Flags from Device to APP */ - BC_POUT_FLAGS_FMT_CHANGE = 0x10000, /* Data is not VALID when this flag is set */ - BC_POUT_FLAGS_PIB_VALID = 0x20000, /* PIB Information valid */ - BC_POUT_FLAGS_ENCRYPTED = 0x40000, /* Data is encrypted. */ - BC_POUT_FLAGS_FLD_BOT = 0x80000, /* Bottom Field data */ -}; - -//Decoder Capability -enum DECODER_CAP_FLAGS -{ - BC_DEC_FLAGS_H264 = 0x01, - BC_DEC_FLAGS_MPEG2 = 0x02, - BC_DEC_FLAGS_VC1 = 0x04, - BC_DEC_FLAGS_M4P2 = 0x08, //MPEG-4 Part 2: Divx, Xvid etc. -}; - -#if defined(__KERNEL__) || defined(__LINUX_USER__) -typedef BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, void *pOut); -#else -typedef BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, struct _BC_DTS_PROC_OUT *pOut); -#endif - -/* Line 21 Closed Caption */ -/* User Data */ -#define MAX_UD_SIZE 1792 /* 1920 - 128 */ - -typedef struct _BC_DTS_PROC_OUT { - uint8_t *Ybuff; /* Caller Supplied buffer for Y data */ - uint32_t YbuffSz; /* Caller Supplied Y buffer size */ - uint32_t YBuffDoneSz; /* Transferred Y datasize */ - - uint8_t *UVbuff; /* Caller Supplied buffer for UV data */ - uint32_t UVbuffSz; /* Caller Supplied UV buffer size */ - uint32_t UVBuffDoneSz; /* Transferred UV data size */ - - uint32_t StrideSz; /* Caller supplied Stride Size */ - uint32_t PoutFlags; /* Call IN Flags */ - - uint32_t discCnt; /* Picture discontinuity count */ - - BC_PIC_INFO_BLOCK PicInfo; /* Picture Information Block Data */ - - /* Line 21 Closed Caption */ - /* User Data */ - uint32_t UserDataSz; - uint8_t UserData[MAX_UD_SIZE]; - - void *hnd; - dts_pout_callback AppCallBack; - uint8_t DropFrames; - uint8_t b422Mode; /* Picture output Mode */ - uint8_t bPibEnc; /* PIB encrypted */ - uint8_t bRevertScramble; - uint32_t StrideSzUV; /* Caller supplied Stride Size */ - -} BC_DTS_PROC_OUT; - -typedef struct _BC_DTS_STATUS { - uint8_t ReadyListCount; /* Number of frames in ready list (reported by driver) */ - uint8_t FreeListCount; /* Number of frame buffers free. (reported by driver) */ - uint8_t PowerStateChange; /* Number of active state power transitions (reported by driver) */ - uint8_t reserved_[1]; - - uint32_t FramesDropped; /* Number of frames dropped. (reported by DIL) */ - uint32_t FramesCaptured; /* Number of frames captured. (reported by DIL) */ - uint32_t FramesRepeated; /* Number of frames repeated. (reported by DIL) */ - - uint32_t InputCount; /* Times compressed video has been sent to the HW. - * i.e. Successful DtsProcInput() calls (reported by DIL) */ - uint64_t InputTotalSize; /* Amount of compressed video that has been sent to the HW. - * (reported by DIL) */ - uint32_t InputBusyCount; /* Times compressed video has attempted to be sent to the HW - * but the input FIFO was full. (reported by DIL) */ - - uint32_t PIBMissCount; /* Amount of times a PIB is invalid. (reported by DIL) */ - - uint32_t cpbEmptySize; /* supported only for H.264, specifically changed for - * SingleThreadedAppMode. Report size of CPB buffer available. - * Reported by DIL */ - uint64_t NextTimeStamp; /* TimeStamp of the next picture that will be returned - * by a call to ProcOutput. Added for SingleThreadedAppMode. - * Reported back from the driver */ - uint8_t TxBufData; - - uint8_t reserved__[3]; - - uint32_t picNumFlags; /* Picture number and flags of the next picture to be delivered from the driver */ - - uint8_t reserved___[8]; - -} BC_DTS_STATUS; - -#define BC_SWAP32(_v) \ - ((((_v) & 0xFF000000)>>24)| \ - (((_v) & 0x00FF0000)>>8)| \ - (((_v) & 0x0000FF00)<<8)| \ - (((_v) & 0x000000FF)<<24)) - -#define WM_AGENT_TRAYICON_DECODER_OPEN 10001 -#define WM_AGENT_TRAYICON_DECODER_CLOSE 10002 -#define WM_AGENT_TRAYICON_DECODER_START 10003 -#define WM_AGENT_TRAYICON_DECODER_STOP 10004 -#define WM_AGENT_TRAYICON_DECODER_RUN 10005 -#define WM_AGENT_TRAYICON_DECODER_PAUSE 10006 - -#define MAX_COLOR_SPACES 3 - -typedef enum _BC_OUTPUT_FORMAT { - MODE420 = 0x0, - MODE422_YUY2 = 0x1, - MODE422_UYVY = 0x2, - OUTPUT_MODE420 = 0x0, - OUTPUT_MODE422_YUY2 = 0x1, - OUTPUT_MODE422_UYVY = 0x2, - OUTPUT_MODE420_NV12 = 0x0, - OUTPUT_MODE_INVALID = 0xFF, -} BC_OUTPUT_FORMAT; - -typedef struct _BC_COLOR_SPACES_ { - BC_OUTPUT_FORMAT OutFmt[MAX_COLOR_SPACES]; - uint16_t Count; -} BC_COLOR_SPACES; - - -typedef enum _BC_CAPS_FLAGS_ { - PES_CONV_SUPPORT = 1, /*Support PES Conversion*/ - MULTIPLE_DECODE_SUPPORT = 2 /*Support multiple stream decode*/ -} BC_CAPS_FLAGS; - -typedef struct _BC_HW_CAPABILITY_ { - BC_CAPS_FLAGS flags; - BC_COLOR_SPACES ColorCaps; - void* Reserved1; /* Expansion Of API */ - - //Decoder Capability - uint32_t DecCaps; //DECODER_CAP_FLAGS -} BC_HW_CAPS, *PBC_HW_CAPS; - -typedef struct _BC_SCALING_PARAMS_ { - uint32_t sWidth; - uint32_t sHeight; - uint32_t DNR; - uint32_t Reserved1; /*Expansion Of API*/ - uint8_t *Reserved2; /*Expansion OF API*/ - uint32_t Reserved3; /*Expansion Of API*/ - uint8_t *Reserved4; /*Expansion Of API*/ - -} BC_SCALING_PARAMS, *PBC_SCALING_PARAMS; - -typedef enum _BC_MEDIA_SUBTYPE_ { - BC_MSUBTYPE_INVALID = 0, - BC_MSUBTYPE_MPEG1VIDEO, - BC_MSUBTYPE_MPEG2VIDEO, - BC_MSUBTYPE_H264, - BC_MSUBTYPE_WVC1, - BC_MSUBTYPE_WMV3, - BC_MSUBTYPE_AVC1, - BC_MSUBTYPE_WMVA, - BC_MSUBTYPE_VC1, - BC_MSUBTYPE_DIVX, - BC_MSUBTYPE_DIVX311, - BC_MSUBTYPE_OTHERS /*Types to facilitate PES conversion*/ -} BC_MEDIA_SUBTYPE; - -typedef struct _BC_INPUT_FORMAT_ { - BOOL FGTEnable; /*Enable processing of FGT SEI*/ - BOOL MetaDataEnable; /*Enable retrieval of picture metadata to be sent to video pipeline.*/ - BOOL Progressive; /*Instruct decoder to always try to send back progressive - frames. If input content is 1080p, the decoder will - ignore pull-down flags and always give 1080p output. - If 1080i content is processed, the decoder will return - 1080i data. When this flag is not set, the decoder will - use pull-down information in the input stream to decide - the decoded data format.*/ - uint32_t OptFlags; /*In this field bits 0:3 are used pass default frame rate, bits 4:5 are for operation mode - (used to indicate Blu-ray mode to the decoder) and bit 6 is for the flag mpcOutPutMaxFRate - which when set tells the FW to output at the max rate for the resolution and ignore the - frame rate determined from the stream. Bit 7 is set to indicate that this is single threaded - mode and the driver will be peeked to get timestamps ahead of time*/ - BC_MEDIA_SUBTYPE mSubtype; /* Video Media Type*/ - uint32_t width; - uint32_t height; - uint32_t startCodeSz; /*Start code size for H264 clips*/ - uint8_t *pMetaData; /*Metadata buffer that is used to pass sequence header*/ - uint32_t metaDataSz; /*Metadata size*/ - uint8_t bEnableScaling; - BC_SCALING_PARAMS ScalingParams; -} BC_INPUT_FORMAT; - -typedef struct _BC_INFO_CRYSTAL_ { - uint8_t device; - union { - struct { - uint32_t dilRelease:8; - uint32_t dilMajor:8; - uint32_t dilMinor:16; - }; - uint32_t version; - } dilVersion; - - union { - struct { - uint32_t drvRelease:4; - uint32_t drvMajor:8; - uint32_t drvMinor:12; - uint32_t drvBuild:8; - }; - uint32_t version; - } drvVersion; - - union { - struct { - uint32_t fwRelease:4; - uint32_t fwMajor:8; - uint32_t fwMinor:12; - uint32_t fwBuild:8; - }; - uint32_t version; - } fwVersion; - - uint32_t Reserved1; // For future expansion - uint32_t Reserved2; // For future expansion -} BC_INFO_CRYSTAL, *PBC_INFO_CRYSTAL; - -#endif /* _BC_DTS_DEFS_H_ */ diff --git a/lib/win32/libcrystalhd/bc_dts_types.h b/lib/win32/libcrystalhd/bc_dts_types.h deleted file mode 100644 index a0b9ca52ad..0000000000 --- a/lib/win32/libcrystalhd/bc_dts_types.h +++ /dev/null @@ -1,68 +0,0 @@ -/******************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: bc_dts_types.h - * - * Description: Data types - * - * AU - * - * HISTORY: - * - ******************************************************************** - * This header is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this header. If not, see <http://www.gnu.org/licenses/>. - *******************************************************************/ - -#ifndef _BC_DTS_TYPES_H_ -#define _BC_DTS_TYPES_H_ - -#ifdef __LINUX_USER__ /* Don't include these for KERNEL.. */ -#include <stdint.h> -#endif - -#ifndef PVOID -typedef void *PVOID; -#endif - -#ifndef BOOL -typedef int BOOL; -#endif - -#ifdef __LINUX_USER__ /* Don't include these for KERNEL */ -typedef uint32_t ULONG; -typedef int32_t LONG; -typedef void *HANDLE; -#ifndef VOID -typedef void VOID; -#endif -typedef void *LPVOID; -typedef uint32_t DWORD; -typedef uint32_t UINT32; -typedef uint32_t *LPDWORD; -typedef unsigned char *PUCHAR; - -#ifndef TRUE - #define TRUE 1 -#endif - -#ifndef FALSE - #define FALSE 0 -#endif - -#else /* !__LINUX_USER__ */ - -/* For Kernel usage.. */ -typedef bool bc_bool_t; -#endif /* __LINUX_USER__ */ - -#endif - diff --git a/lib/win32/libcrystalhd/libcrystalhd_if.h b/lib/win32/libcrystalhd/libcrystalhd_if.h deleted file mode 100644 index 880784224e..0000000000 --- a/lib/win32/libcrystalhd/libcrystalhd_if.h +++ /dev/null @@ -1,1539 +0,0 @@ -/***************************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: libcrystalhd_if.h - * - * Description: Device Interface Library API. - * - * AU - * - * HISTORY: - * - ***************************************************************************** - * - * This file is part of libcrystalhd. - * - * This library is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this library. If not, see <http://www.gnu.org/licenses/>. - * - ****************************************************************************/ - -#ifndef _BCM_LDIL_IF_H_ -#define _BCM_LDIL_IF_H_ - -#include "bc_dts_defs.h" - -#define FLEA_MAX_TRICK_MODE_SPEED 6 - -#ifdef __cplusplus -extern "C" { -#endif - -/***************************************************************************** -****************************************************************************** - - Theory of operation - - - The Device Interface Library (DIL) allows application level code, such -as a DirectShow filter, to access the Broadcom CrystalHD decoder driver to -provide hardware decoding for MPEG-2, H.264 (AVC) and VC-1 streams. - - In the Microsoft DirectShow system, the overall system graph would look -like the following: - -+--------+ +---------------+ +---------------+ +--------------------+ -| Source |->| Demultiplexer |->| Audio decoder |->| DirectSound Device | -+--------+ +---------------+ +---------------+ +--------------------+ - | - | +-------------------------+ +----------------+ - +->| Broadcom decoder filter |->| Video Renderer | - +-------------------------+ +----------------+ - | | - +----------------+ - | Broadcom DIL | - +----------------+ - | | - +-----------------+ - | Broadcom Driver | - +-----------------+ - - From the view of the caller, the DIL will accept compressed video streams -and will output decoded video frames or fields to seperate Y and UV buffers. -The DIL is responsible solely for decoding video and has no responsibilities -for audio nor for rendering, as shown in the above diagram. Audio/video -sychronization is assisted by feeding the DIL with timestamps so that it -may pass those timestamps along with the decoded video. The timestamped -output video will then be presented at the appropriate time by the renderer. - -A minimal implementation would be: - - HANDLE hBRCMhandle; - uint8_t input_buffer[INPUT_SIZE]; - uint8_t y_output_buffer[WIDTH*HEIGHT]; - uint8_t uv_output_buffer[WIDTH*HEIGHT]; - BC_DTS_PROC_OUT sProcOutData = { fill in your values here }; - BC_PIC_INFO_BLOCK sPIB = { fill in your values here }; - - // Acquire handle for device. - DtsDeviceOpen(&hBRCMhandle, 0); - - // Elemental stream. - DtsOpenDecoder(hBRCMhandle, 0); - - // H.264, Enable FGT SEI, do not parse metadata, no forced progressive out - DtsSetVideoParams(hBRCMhandle,0,1,0,0,0); - - // Tell decoder to wait for input from host. (PC) - DtsStartDecoder(hBRCMhandle); - - // Input buffer address, input buffer size, no timestamp, Unencrypted - DtsProcInput(hBRCMhandle,input_buffer,sizeof(input_buffer),0,0); - - // Tell PC to wait for data from decoder. - DtsStartCapture(hBRCMhandle); - - // 16ms timeout, pass pointer to PIB then get the decoded picture. - DtsProcOutput(hBRCMhandle,16,&sPIB); - - // Stop the decoder. - DtsStopDecoder(hBRCMhandle); - - // Close the decoder - DtsCloseDecoder(hBRCMhandle); - - // Release handle for device. - DtsDeviceClose(hBRCMhandle); - -****************************************************************************** -*****************************************************************************/ - -#define DRVIFLIB_API - -/***************************************************************************** -Function name: - - DtsDeviceOpen - -Description: - - Opens a handle to the decoder device that will be used to address that - unique instance of the decoder for all subsequent operations. - - Must be called once when the application opens the decoder for use. - -Parameters: - - *hDevice Pointer to device handle that will be filled in after the - device is successfully opened. [OUTPUT] - - mode Controls the mode in which the device is opened. - Currently only mode 0 (normal playback) is supported. - All other values will return BC_STS_INV_ARG. - -Return: - - Returns BC_STS_SUCCESS or error codes as appropriate. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsDeviceOpen( - HANDLE *hDevice, - uint32_t mode - ); - -/***************************************************************************** - -Function name: - - DtsDeviceClose - -Description: - - Close the handle to the decoder device. - - Must be called once when the application closes the decoder after use. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - -Return: - - Returns BC_STS_SUCCESS or error codes as appropriate. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsDeviceClose( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsGetVersion - -Description: - - Get version information from the driver as well as API library. - Version numbers are maintained in <Major>.<Minor>.<Revision> format. - Example ?01.23.4567 - - The device must have been previously opened for this call to succeed. - The individual components of the revision number are available as follows: - - o Major (8 Bits) : Bit 31 ?24 - o Minor (8 Bits) : Bit 23 ?16 - o Revision (16 Bits) : Bits 15 ?Bit 0. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - DrVer Device driver version - DilVer Driver interface library version - -Return: - The revision numbers from the currently loaded driver as well as the - driver interface API library. - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetVersion( - HANDLE hDevice, - uint32_t *DrVer, - uint32_t *DilVer - ); - -/***************************************************************************** - -Function name: - - DtsGetFWVersionFromFile - -Description: - - Get version information from the Firmware Bin file when FW is not running - Version numbers in FW are maintained in <Major>.<Minor>.<Spl Revision> format. - the return value will be of the format: - (Major << 16) | (Minor<<8) | Spl_rev ?012345 - - The individual components of the revision number are available as follows: - - o Major (8 Bits) : Bit 24 ?16 - o Minor (8 Bits) : Bit 16 ?8 - o Revision (16 Bits) : Bits 8 ?0. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - StreamVer Stream FW version - DecVer VDEC FW version - Rsvd Reserved for future use - -Return: - The Stream FW Version umbers from the FW bin file in the install directory - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetFWVersionFromFile( - HANDLE hDevice, - uint32_t *StreamVer, - uint32_t *DecVer, - char *fname - ); - -/***************************************************************************** - -Function name: - - DtsGetFWVersion - -Description: - - Get version information from the Firmware. The version information is obtained - from Bin file when the flag is not set. When the flag is set, a FW command is - issued to get the version numbers. - Version numbers in FW are maintained in <Major>.<Minor>.<Spl Revision> format. - Version number will be returned in the following format - (Major << 16) | (Minor<<8) | Spl_rev ?012345 - - The individual components of the revision number are available as follows: - - o Major (8 Bits) : Bit 24 ?16 - o Minor (8 Bits) : Bit 16 ?8 - o Revision (16 Bits) : Bits 8 ?Bit 0. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - StreamVer Stream FW version - DecVer VDEC FW version - HwVer Hardware version - Rsvd Reserved for future use - flag Reseved for future use - -Return: - The Stream FW Version number, VDEC FW version and Hwrev - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetFWVersion( - HANDLE hDevice, - uint32_t *StreamVer, - uint32_t *DecVer, - uint32_t *HwVer, - char *fname, - uint32_t flag - ); - - -/***************************************************************************** - -Function name: - - DtsOpenDecoder - -Description: - - Open the decoder for playback operations and sets appropriate parameters - for decode of input video data. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - StreamType Currently supported streams are: - Elementary Streams with no timestamp management (0) - Transport Streams (2) - Elementary Streams with timestamp management (6) - All other values will return BC_STS_INV_ARG. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsOpenDecoder( - HANDLE hDevice, - uint32_t StreamType - ); - -/***************************************************************************** - -Function name: - - DtsCloseDecoder - -Description: - - Close the decoder. No further pictures will be produced and all input - will be ignored. - - The device must have been previously opened for this call to succeed. - This function closes the decoder and cleans up the state of the driver - and the library. All pending pictures will be dropped and all outstanding - transfers to and from the decoder will be aborted. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsCloseDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsStartDecoder - -Description: - - Start the actual processing of input data. Before this command the - decoder will ignore all of the presented input data. - - DtsOpenDecoder must always be followed by a DtsStartDecoder for the - decoder to start processing input data. The device must have been - previously opened for this call to succeed. In addition the video - parameters for codec must have been set via a call to DtsSetVideoParams. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStartDecoder( - HANDLE hDevice - ); - - -/***************************************************************************** - -Function name: - - DtsSetVideoParams - -Description: - - Sets various codec parameters that would be used by a subsequent call - to DtsStartDecoder. - - DtsSetVideoParams must always be called before DtsStartDecoder for the - decoder to start processing input data. The device must have been - previously opened for this call to succeed. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - videoAlg Video Codec to be enabled to decode stream. - H.264 (0), VC-1 (4) and MPEG-2 (1) currently supported. - All other values will return BC_STS_INV_ARG - FGTEnable Enable processing of FGT SEI. - MetaDataEnable Enable retrieval of picture metadata to be sent to video - pipeline. - Progressive Instruct decoder to always try to send back progressive - frames. If input content is 1080p, the decoder will - ignore pull-down flags and always give 1080p output. - If 1080i content is processed, the decoder will return - 1080i data. When this flag is not set, the decoder will - use pull-down information in the input stream to decide - the decoded data format. - OptFlags In this field bits 0:3 are used pass default frame rate, - bits 4:5 are for operation mode (used to indicate Blu-ray - mode to the decoder) and bit 6 is for the flag mpcOutPutMaxFRate - which when set tells the FW to output at the max rate for the - resolution and ignore the frame rate determined from the - stream. Bit 7 is set to indicate that this is single threaded mode - and the driver will be peeked to get timestamps ahead of time. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetVideoParams( - HANDLE hDevice, - uint32_t videoAlg, - BOOL FGTEnable, - BOOL MetaDataEnable, - BOOL Progressive, - uint32_t OptFlags - ); - -/***************************************************************************** - -Function name: - - DtsSetInputFormat - -Description: - - Sets input video's various parameters that would be used by a subsequent call - to DtsStartDecoder. - - DtsSetInputFormat must always be called before DtsOpenDecoder for the - decoder to start processing input data. The device must have been - previously opened for this call to succeed. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to DtsDeviceOpen. - pInputFormat Pointer to the BC_INPUT_FORMAT data. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetInputFormat( - HANDLE hDevice, - BC_INPUT_FORMAT *pInputFormat - ); - -/***************************************************************************** - -Function name: - - DtsGetVideoParams - -Description: - - Returns various codec parameters that would be used by a subsequent call - to DtsStartDecoder. These parameters are either default values or were - set via a prior call to DtsSetVideoParams - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - *videoAlg See DtsSetVideoParams. [OUTPUT] - *FGTEnable See DtsSetVideoParams. [OUTPUT] - *MetaDataEnable See DtsSetVideoParams. [OUTPUT] - *Progressive See DtsSetVideoParams. [OUTPUT] - Reserved This field is reserved for possible future expansion. - Set to 0. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetVideoParams( - HANDLE hDevice, - uint32_t *videoAlg, - BOOL *FGTEnable, - BOOL *MetaDataEnable, - BOOL *Progressive, - uint32_t Reserved - ); - -/***************************************************************************** - -Function name: - - DtsFormatChange - -Description: - - Changes codec type and parameters. - - The device must have been previously opened for this call to succeed. - This function should be used only for mid-stream format changes. - DtsStartDecoder must have been called before for this function to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - videoAlg Video Codec to be enabled to decode stream. - H.264 (0), VC-1 (4) and MPEG-2 (1) currently supported. All - other values will return BC_STS_INV_ARG - FGTEnable Enable processing of FGT SEI. - Progressive Instruct decoder to always try to send back progressive - frames. If input content is 1080p, the decoder will ignore - pull-down flags and always give 1080p output. If 1080i - content is processed, the decoder will return 1080i data. - When this flag is not set, the decoder will use pull-down - information in the input stream to decide the decoded data - format. - Reserved This field is reserved for possible future expansion. - Set to 0. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsFormatChange( - HANDLE hDevice, - uint32_t videoAlg, - BOOL FGTEnable, - BOOL MetaDataEnable, - BOOL Progressive, - uint32_t Reserved - ); - -/***************************************************************************** - -Function name: - - DtsStopDecoder - -Description: - - Stop the decoder. - - The device must have been previously opened for this call to succeed. - This function will clean up any pending operations and stop the decoder. - Internal state is still maintained and the decoder can be restarted. - Any pending pictures will be dropped. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStopDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsPauseDecoder - -Description: - - Pause the decoder. The paused picture will be repeated by decoder. - - The device must have been previously opened for this call to succeed. - In addition the decoder must have been started as well. If the decoder - is open but not started, this function will return BC_STS_DEC_NOT_STARTED. - If the decoder has not been opened this function will return - BC_STS_DEC_NOT_OPEN. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsPauseDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsResumeDecoder - -Description: - - Unpause the decoder from a previous paused condition. - - The device must have been previously opened for this call to succeed. - If the decoder was not paused previously, this function will return - without affecting the decoder with a BC_STS_SUCCESS status. If the - decoder is open but not started, this function will return - BC_STS_DEC_NOT_STARTED. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsResumeDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsSetVideoPID - -Description: - - Sets the video PID in the input Transport Stream that the decoder - needs to process. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - PID PID value that decoder needs to process. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetVideoPID( - HANDLE hDevice, - uint32_t pid - ); - - -/***************************************************************************** - -Function name: - - StartCaptureImmidiate - -Description: - - Instruct the driver to start capturing decoded frames for output. - - The device must have been previously opened for this call to succeed. - This function must be called before the first call to DtsProcInput. - This function instructs the receive path in the driver to start waiting - for valid data to be presented from the decoder. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStartCaptureImmidiate( - HANDLE hDevice, - uint32_t Reserved - ); - - -/***************************************************************************** - -Function name: - - StartCapture - -Description: - - Instruct the driver to start capturing decoded frames for output. - - The device must have been previously opened for this call to succeed. - This function must be called before the first call to DtsProcInput. - This function instructs the receive path in the driver to start waiting - for valid data to be presented from the decoder. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStartCapture( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - FlushRxCapture - -Description: - - ***This function is deprecated and is for temporary use only.*** - - Flush the driverÃs queue of pictures and stops the capture process. These - functions will be replaced with automatic Stop (End of Sequence) detection. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsFlushRxCapture( - HANDLE hDevice, - BOOL bDiscardOnly - ); - -/***************************************************************************** - -Function name: - - DtsProcOutput - -Description: - - Returns one decoded picture to the caller. - - The device must have been previously opened for this call to succeed. - - == NOTE ==== - For PIB AND 100% output encryption/scrambling on Bcm LINK hardware - use ProcOutputNoCopy() Interace. This interface will not support - PIB encryption. - - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - milliSecWait Timeout parameter. DtsProcOutput will fail is no picture - is received in this time. - *pOut This is a pointer to the BC_DTS_PROC_OUT structure that is - allocated by the caller. The decoded picture is returned - in this structure. This structure is described in the - data structures section. The actual data buffer to be - filled with the decoded data is allocated by the caller. - Data is copied from the decoder to the buffers before this - function returns. [INPUT/OUTPUT] - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsProcOutput( - HANDLE hDevice, - uint32_t milliSecWait, - BC_DTS_PROC_OUT *pOut - ); - -/***************************************************************************** - -Function name: - - DtsProcOutputNoCopy - -Description: - - Returns one decoded picture to the caller. Functionality of this API() - is very similar to ProcOutPut() API. This API will not copy the video data - to caller's buffers but provides the source buffer pointers in pOut structure. - - This is more secure and preferred method for BCM's Link hardware. The actual - format conversion/copy routines are provided as part of the Filter/Security - layer source code. Using this method, all the clear data handling will be - done by bcmDFilter or bcmSec layers which are expected to be in Player's - tamper resistant area. - - == NOTE ==== - 1) DtsReleaseOutputBuffs() interface must be called to release the buffers - back to DIL if return Status is BC_STS_SUCCESS. - - 2) Only this interface supports PIB and full 100% output encryption/Scrambling. - - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - milliSecWait Timeout parameter. DtsProcOoutput will fail is no picture - is received in this time. - *pOut This is a pointer to the BC_DTS_PROC_OUT structure that is - allocated by the caller. The decoded picture is returned - in this structure. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsProcOutputNoCopy( - HANDLE hDevice, - uint32_t milliSecWait, - BC_DTS_PROC_OUT *pOut - ); - -/***************************************************************************** - -Function name: - - DtsReleaseOutputBuffs - -Description: - - Release Buffers acquired during ProcOutputNoCopy() interface. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - Reserved Reserved. Set to NULL. - - fChange FALSE. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsReleaseOutputBuffs( - HANDLE hDevice, - PVOID Reserved, - BOOL fChange - ); - - -/***************************************************************************** - -Function name: - - DtsProcInput - -Description: - - Sends compressed (coded) data to the decoder for processing. - - The device must have been previously opened for this call to succeed. - In addition, suitable keys must have been exchanged for decryption and - decode to be successful. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - pUserData Pointer to data buffer that holds the data to be transferred. - [INPUT] - sizeInBytes Size in Bytes of data available to be sent to the decoder for - processing. - Timestamp Optional timestamp information attached to the media sample - that is available in the buffer. If timestamp is present - (i.e. non-zero), then this will be reflected in the output - sample (picture) produced from the contents of this buffer. - Timestamp should be in units of 100 ns. - Encrypted Flag to indicate that the data transfer is not in the clear - and that the decoder needs to decrypt before it can decode - the data. Note that due to complexity, it is preferred that - the application writer uses the higher level - dts_pre_proc_input() call if encypted content will be sent. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsProcInput( - HANDLE hDevice, - uint8_t *pUserData, - uint32_t ulSizeInBytes, - uint64_t timeStamp, - BOOL encrypted - ); - -/***************************************************************************** - -Function name: - - DtsGetColorPrimaries - -Description: - - Returns color primaries information from the stream being processed. - - The device must have been previously opened for this call to succeed. - In addition at least one picture must have been successfully decoded and - returned back from the decoder. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - colorPrimaries Pointer to U32 to receive the color primaries information. - The values returned are described in the previous section - regarding the picture metadata. [OUTPUT] - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetColorPrimaries( - HANDLE hDevice, - uint32_t *colorPrimaries - ); - -/***************************************************************************** - -Function name: - - DtsFlushInput - -Description: - - Flushes the current channel and causes the decoder to stop accessing input - data. Based on the flush mode parameter, the channel will be flushed from - the current point in the input data or from the current processing point. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - Mode 0 Flush at the current input point. use to drain the - input FIFO . All the data that has been received will - be decoded. - 1 Flush at the current processing point. All the decoded - frames will be presented but no more data from the - input will be decoded. - 2 Flushes all the decoder buffers, input, decoded and - to be decoded. - 3 Cancels the pending TX Request from the DIL/driver - 4 Flushes all the decoder buffers, input, decoded and - to be decoded data. Also flushes the drivers buffers - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsFlushInput( - HANDLE hDevice, - uint32_t Mode - ); - -/***************************************************************************** - -Function name: - - DtsSetRateChange - -Description: - - Sets the decoder playback speed and direction of playback. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - rate Inverse of speed x 10000. - Examples: - 1/2x playback speed = 20000 - 1x playback speed = 10000 - 2x playback speed = 5000 - - direction Playback direction. - 0 Forward direction. - 1 Reverse direction. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetRateChange( - HANDLE hDevice, - uint32_t rate, - uint8_t direction - ); - - -//Set FF Rate for Catching Up -/***************************************************************************** - -Function name: - - DtsSetFFRate - -Description: - - Sets the decoder playback FF speed - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - rate Inverse of speed x 10000. - Examples: - 1/2x playback speed = 20000 - 1x playback speed = 10000 - 2x playback speed = 5000 - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetFFRate( - HANDLE hDevice, - uint32_t rate - ); - -/***************************************************************************** - -Function name: - - DtsSetSkipPictureMode - -Description: - - This command sets the decoder to only decode selected picture types. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - SkipMode 0 IPB, All pictures are decoded. - - 1 IP decoding, This mode skips all non reference pictures. - - 2 I decoding, This mode skips all P/B pictures and only decodes - I pictures. -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetSkipPictureMode( - HANDLE hDevice, - uint32_t SkipMode - ); - -/***************************************************************************** - -Function name: - - DtsSetIFrameTrickMode - -Description: - - This command sets the decoder to decode only I Frames for FF and FR. - - Use this API for I Frame only trick mode play back in either direction. The - application/Up stream filter determines the speed of the playback by - means of Skip on the input compressed data. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetIFrameTrickMode( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsStepDecoder - -Description: - - This function forwards one frame. - - The device must have been opened must be in paused - state previously for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStepDecoder( - HANDLE hDevice - ); - - -/***************************************************************************** - -Function name: - - DtsIs422Supported - -Description: - - This function returns whether 422 YUV mode is supported or not. - - The device must have been opened previously for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - bSupported 1 - 422 is supported - 0 - 422 is not supported. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsIs422Supported( - HANDLE hDevice, - uint8_t *bSupported - ); - -/***************************************************************************** - -Function name: - - DtsSetColorSpace - -Description: - - This function sets the output sample's color space. - - The device must have been opened previously and must support 422 mode for - this call to succeed. - - Use "DtsIs422Supported" to find whether 422 mode is supported. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - 422Mode Mode is defined by BC_OUTPUT_FORMAT as follows - - OUTPUT_MODE420 = 0x0, - OUTPUT_MODE422_YUY2 = 0x1, - OUTPUT_MODE422_UYVY = 0x2, - OUTPUT_MODE_INVALID = 0xFF - Valid values for this API are OUTPUT_MODE422_YUY2 and OUTPUT_MODE422_UYVY - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetColorSpace( - HANDLE hDevice, - BC_OUTPUT_FORMAT Mode422 - ); - -/***************************************************************************** - -Function name: - - DtsSet422Mode - -Description: - - This function sets the 422 mode to either YUY2 or UYVY. - - The device must have been opened previously and must support 422 mode for - this call to succeed. - - Use "DtsIs422Supported" to find whether 422 mode is supported. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - 422Mode 0 - set the YUV mode to YUY2 - 1 - set the YUV mode to UYVY - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSet422Mode( - HANDLE hDevice, - uint8_t Mode422 - ); - -/***************************************************************************** - -Function name: - - DtsGetDILPath - -Description: - - This is a helper function to return DIL's Path. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - DilPath Buffer to hold DIL path info upto 256 bytes. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ - -DRVIFLIB_API BC_STATUS -DtsGetDILPath( - HANDLE hDevice, - char *DilPath, - uint32_t size - ); - -/***************************************************************************** - -Function name: - - DtsDropPictures - -Description: - - This command sets the decoder to skip one or more non-reference (B) pictures - in the input data stream. This is used for when the audio is ahead of - video and the application needs to cause video to move ahead to catch up. - Reference pictures are not skipped. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - Pictures The number of non-reference pictures to drop. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsDropPictures( - HANDLE hDevice, - uint32_t Pictures - ); - -/***************************************************************************** - -Function name: - - DtsGetDriverStatus - -Description: - - This command returns various statistics related to the driver and DIL. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - *pStatus Pointer to BC_DTS_STATUS to receive driver status. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetDriverStatus( - HANDLE hDevice, - BC_DTS_STATUS *pStatus - ); - -/***************************************************************************** - -Function name: - - DtsGetCapabilities - -Description: - - This command returns output format support and hardware capabilities. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - pCapsBuffer Pointer to BC_HW_CAPS to receive HW Output capabilities. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetCapabilities ( - HANDLE hDevice, - PBC_HW_CAPS pCapsBuffer - ); - -/***************************************************************************** - -Function name: - - DtsSetScaleParams - -Description: - - This command sets hardware scaling parameters. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - pScaleParams Pointer to BC_SCALING_PARAMS to set hardware scaling parameters. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetScaleParams ( - HANDLE hDevice, - PBC_SCALING_PARAMS pScaleParams - ); - -/***************************************************************************** - -Function name: - - DtsIsEndOfStream - -Description: - - This command returns whether the end of stream(EOS) is reaching. -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - bEOS Pointer to uint8_t to indicate if EOS of not - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsIsEndOfStream( - HANDLE hDevice, - uint8_t* bEOS -); - -/***************************************************************************** - -Function name: - - DtsCrystalHDVersion - -Description: - - This API returns hw and sw version information for Crystal HD solutions -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - bCrystalInfo Pointer to structure to fill in with information - - device = 0 for BCM70012, 1 for BCM70015 - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsCrystalHDVersion( - HANDLE hDevice, - PBC_INFO_CRYSTAL bCrystalInfo -); - -/***************************************************************************** - -Function name: - - DtsTxFreeSize - -Description: - - This API returns the amount of free space in the tx circular buffer -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - uint32_t value of number of free bytes in the tx circular buffer - -*****************************************************************************/ -DRVIFLIB_API uint32_t -DtsTxFreeSize( - HANDLE hDevice -); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/lib/win32/libcrystalhd/libcrystalhd_version.h b/lib/win32/libcrystalhd/libcrystalhd_version.h deleted file mode 100644 index 9ac76323fc..0000000000 --- a/lib/win32/libcrystalhd/libcrystalhd_version.h +++ /dev/null @@ -1,82 +0,0 @@ -/******************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: libcrystalhd_version.h - * - * Description: Version numbering for the driver use. - * - * AU - * - * HISTORY: - * - ******************************************************************** - * This header is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this header. If not, see <http://www.gnu.org/licenses/>. - *******************************************************************/ - -#ifndef _BC_DTS_VERSION_LNX_ -#define _BC_DTS_VERSION_LNX_ -// -// The version format that we are adopting is -// MajorVersion.MinorVersion.Revision -// This will be the same for all the components. -// -// -#define STRINGIFY_VERSION(MAJ,MIN,REV) STRINGIFIED_VERSION(MAJ,MIN,REV) -#define STRINGIFIED_VERSION(MAJ,MIN,REV) #MAJ "." #MIN "." #REV - -#define STRINGIFY_VERSION_W(MAJ,MIN,REV) STRINGIFIED_VERSION_W(MAJ,MIN,REV) -#define STRINGIFIED_VERSION_W(MAJ,MIN,REV) #MAJ "." #MIN "." #REV - -// -// Product Version number is: -// x.y.z.a -// -// x = Major release. 1 = Dozer, 2 = Dozer + Link -// y = Minor release. Should increase +1 per "real" release. -// z = Branch release. 0 for main branch. This is +1 per branch release. -// a = Build number +1 per candidate release. Reset to 0 every "real" release. -// -// -// Enabling Check-In rules enforcement 08092007 -// -#define INVALID_VERSION 0xFFFF - -/*========================== Common For All Components =================================*/ -#define BRCM_MAJOR_VERSION 3 - -// Note: the driver doesn't currently use these defines, it has its own -// version information (which should match) stored in bc_dts_glob_lnx.h -#define DRIVER_MAJOR_VERSION BRCM_MAJOR_VERSION -#define DRIVER_MINOR_VERSION 8 -#define DRIVER_REVISION 0 - -#define RC_FILE_VERSION STRINGIFY_VERSION(DRIVER_MAJOR_VERSION,DRIVER_MINOR_VERSION,DRIVER_REVISION) ".0" - -/*======================= Device Interface Library ========================*/ -#define DIL_MAJOR_VERSION BRCM_MAJOR_VERSION -#define DIL_MINOR_VERSION 20 -#define DIL_REVISION 0 - -#define DIL_RC_FILE_VERSION STRINGIFY_VERSION(DIL_MAJOR_VERSION,DIL_MINOR_VERSION,DIL_REVISION) - -/*========================== deconf utility ==============================*/ -#define DECONF_MAJOR_VERSION BRCM_MAJOR_VERSION -#define DECONF_MINOR_VERSION 9 -#define DECONF_REVISION 18 -#define DECONF_RC_FILE_VERSION STRINGIFY_VERSION(DIL_MAJOR_VERSION,DIL_MINOR_VERSION,DIL_REVISION) - -/*========================== Firmware ==============================*/ -#define FW_MAJOR_VERSION BRCM_MAJOR_VERSION -#define FW_MINOR_VERSION 60 -#define FW_REVISION 39 - -#endif diff --git a/project/VS2010Express/XBMC.vcxproj b/project/VS2010Express/XBMC.vcxproj index 624b1e7ba6..271ee3aa36 100644 --- a/project/VS2010Express/XBMC.vcxproj +++ b/project/VS2010Express/XBMC.vcxproj @@ -216,7 +216,6 @@ <ClCompile Include="..\..\xbmc\cores\AudioEngine\Utils\AEStreamInfo.cpp" /> <ClCompile Include="..\..\xbmc\cores\AudioEngine\Utils\AEUtil.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Audio\DVDAudioCodecPassthrough.cpp" /> - <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\CrystalHD.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodec.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDDemuxers\DVDDemuxBXA.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDDemuxers\DVDDemuxCDDA.cpp" /> @@ -1465,7 +1464,6 @@ <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\DVDCodecUtils.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\DVDFactoryCodec.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Audio\DVDAudioCodecFFmpeg.cpp" /> - <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecCrystalHD.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecFFmpeg.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecLibMpeg2.cpp" /> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoPPFFmpeg.cpp" /> @@ -1663,7 +1661,6 @@ <ClInclude Include="..\..\xbmc\Autorun.h" /> <ClInclude Include="..\..\xbmc\AutoSwitch.h" /> <ClInclude Include="..\..\xbmc\BackgroundInfoLoader.h" /> - <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\CrystalHD.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDDemuxers\DVDDemuxPVRClient.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDInputStreams\DVDInputStreamBluray.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDInputStreams\DVDInputStreamPVRManager.h" /> @@ -2160,7 +2157,6 @@ <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Audio\DVDAudioCodecFFmpeg.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DllLibMpeg2.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodec.h" /> - <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecCrystalHD.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecFFmpeg.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecLibMpeg2.h" /> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoPPFFmpeg.h" /> @@ -2540,4 +2536,4 @@ </VisualStudio> </ProjectExtensions> <Import Project="$(SolutionDir)\$(ProjectFileName).targets.user" Condition="Exists('$(SolutionDir)\$(ProjectFileName).targets.user')" /> -</Project>
\ No newline at end of file +</Project> diff --git a/project/VS2010Express/XBMC.vcxproj.filters b/project/VS2010Express/XBMC.vcxproj.filters index 91206a1d9c..342fb9a5f5 100644 --- a/project/VS2010Express/XBMC.vcxproj.filters +++ b/project/VS2010Express/XBMC.vcxproj.filters @@ -402,9 +402,6 @@ <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Audio\DVDAudioCodecFFmpeg.cpp"> <Filter>cores\dvdplayer\DVDCodecs\Audio</Filter> </ClCompile> - <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecCrystalHD.cpp"> - <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> - </ClCompile> <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecFFmpeg.cpp"> <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> </ClCompile> @@ -774,9 +771,6 @@ <ClCompile Include="..\..\xbmc\addons\PluginSource.cpp"> <Filter>addons</Filter> </ClCompile> - <ClCompile Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\CrystalHD.cpp"> - <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> - </ClCompile> <ClCompile Include="..\..\xbmc\cores\VideoRenderers\VideoShaders\WinVideoFilter.cpp"> <Filter>cores\VideoRenderers\Shaders</Filter> </ClCompile> @@ -3163,9 +3157,6 @@ <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodec.h"> <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> </ClInclude> - <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecCrystalHD.h"> - <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> - </ClInclude> <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\DVDVideoCodecFFmpeg.h"> <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> </ClInclude> @@ -3652,9 +3643,6 @@ <ClInclude Include="..\..\xbmc\addons\PluginSource.h"> <Filter>addons</Filter> </ClInclude> - <ClInclude Include="..\..\xbmc\cores\dvdplayer\DVDCodecs\Video\CrystalHD.h"> - <Filter>cores\dvdplayer\DVDCodecs\Video</Filter> - </ClInclude> <ClInclude Include="..\..\xbmc\cores\VideoRenderers\VideoShaders\WinVideoFilter.h"> <Filter>cores\VideoRenderers\Shaders</Filter> </ClInclude> @@ -6037,4 +6025,4 @@ <Filter>interfaces\swig</Filter> </None> </ItemGroup> -</Project>
\ No newline at end of file +</Project> diff --git a/system/settings/settings.xml b/system/settings/settings.xml index 32ff1d9213..7f33d83e69 100644 --- a/system/settings/settings.xml +++ b/system/settings/settings.xml @@ -724,15 +724,6 @@ <default>true</default> <control type="toggle" /> </setting> - <setting id="videoplayer.usechd" type="boolean" label="13428" help="36159"> - <requirement>HasCrystalHDDevice</requirement> - <dependencies> - <dependency type="enable" setting="videoplayer.decodingmethod" operator="is">1</dependency> - </dependencies> - <level>2</level> - <default>true</default> - <control type="toggle" /> - </setting> <setting id="videoplayer.useomx" type="boolean" label="13430" help="36161"> <requirement>HAVE_LIBOPENMAX</requirement> <dependencies> diff --git a/tools/depends/target/Makefile b/tools/depends/target/Makefile index fce60df608..f5374b2e54 100644 --- a/tools/depends/target/Makefile +++ b/tools/depends/target/Makefile @@ -26,11 +26,11 @@ endif ifeq ($(OS),ios) DEPENDS += Backrow - EXCLUDED_DEPENDS = libcec libcrystalhd libusb gmp nettle gnutls + EXCLUDED_DEPENDS = libcec libusb gmp nettle gnutls endif ifeq ($(OS),osx) - DEPENDS += libGLEW libsdl libcrystalhd + DEPENDS += libGLEW libsdl EXCLUDED_DEPENDS = libusb gmp nettle gnutls endif diff --git a/tools/depends/target/libcrystalhd/Makefile b/tools/depends/target/libcrystalhd/Makefile deleted file mode 100644 index fa3d44356b..0000000000 --- a/tools/depends/target/libcrystalhd/Makefile +++ /dev/null @@ -1,15 +0,0 @@ -include ../../Makefile.include -DEPS= ../../Makefile.include - -SOURCE=libcrystalhd - -all: .installed-$(PLATFORM) - -.installed-$(PLATFORM): $(SOURCE) - mkdir -p $(PREFIX)/include - cp -rf $(SOURCE) $(PREFIX)/include/ - touch $@ - -clean: -distclean:: - rm -f .installed-$(PLATFORM) diff --git a/tools/depends/target/libcrystalhd/libcrystalhd/bc_dts_defs.h b/tools/depends/target/libcrystalhd/libcrystalhd/bc_dts_defs.h deleted file mode 100644 index 2bffb80631..0000000000 --- a/tools/depends/target/libcrystalhd/libcrystalhd/bc_dts_defs.h +++ /dev/null @@ -1,635 +0,0 @@ -/******************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: bc_dts_defs.h - * - * Description: Common definitions for all components. Only types - * is allowed to be included from this file. - * - * AU - * - * HISTORY: - * - ******************************************************************** - * This header is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this header. If not, see <http://www.gnu.org/licenses/>. - *******************************************************************/ - -#ifndef _BC_DTS_DEFS_H_ -#define _BC_DTS_DEFS_H_ - -#include "bc_dts_types.h" - -/* BIT Mask */ -#define BC_BIT(_x) (1 << (_x)) - -typedef enum _BC_STATUS { - BC_STS_SUCCESS = 0, - BC_STS_INV_ARG = 1, - BC_STS_BUSY = 2, - BC_STS_NOT_IMPL = 3, - BC_STS_PGM_QUIT = 4, - BC_STS_NO_ACCESS = 5, - BC_STS_INSUFF_RES = 6, - BC_STS_IO_ERROR = 7, - BC_STS_NO_DATA = 8, - BC_STS_VER_MISMATCH = 9, - BC_STS_TIMEOUT = 10, - BC_STS_FW_CMD_ERR = 11, - BC_STS_DEC_NOT_OPEN = 12, - BC_STS_ERR_USAGE = 13, - BC_STS_IO_USER_ABORT = 14, - BC_STS_IO_XFR_ERROR = 15, - BC_STS_DEC_NOT_STARTED = 16, - BC_STS_FWHEX_NOT_FOUND = 17, - BC_STS_FMT_CHANGE = 18, - BC_STS_HIF_ACCESS = 19, - BC_STS_CMD_CANCELLED = 20, - BC_STS_FW_AUTH_FAILED = 21, - BC_STS_BOOTLOADER_FAILED = 22, - BC_STS_CERT_VERIFY_ERROR = 23, - BC_STS_DEC_EXIST_OPEN = 24, - BC_STS_PENDING = 25, - BC_STS_CLK_NOCHG = 26, - - /* Must be the last one.*/ - BC_STS_ERROR = -1 -} BC_STATUS; - -/*------------------------------------------------------* - * Registry Key Definitions * - *------------------------------------------------------*/ -#define BC_REG_KEY_MAIN_PATH "Software\\Broadcom\\MediaPC\\CrystalHD" -#define BC_REG_KEY_FWPATH "FirmwareFilePath" -#define BC_REG_KEY_SEC_OPT "DbgOptions" - -/* - * Options: - * - * b[5] = Enable RSA KEY in EEPROM Support - * b[6] = Enable Old PIB scheme. (0 = Use PIB with video scheme) - * - * b[12] = Enable send message to NotifyIcon - * - */ - -typedef enum _BC_SW_OPTIONS { - BC_OPT_DOSER_OUT_ENCRYPT = BC_BIT(3), - BC_OPT_LINK_OUT_ENCRYPT = BC_BIT(29), -} BC_SW_OPTIONS; - -typedef struct _BC_REG_CONFIG{ - uint32_t DbgOptions; -} BC_REG_CONFIG; - -#if defined(__KERNEL__) || defined(__LINUX_USER__) -#else -/* Align data structures */ -#define ALIGN(x) __declspec(align(x)) -#endif - -/* mode - * b[0]..b[7] = _DtsDeviceOpenMode - * b[8] = Load new FW - * b[9] = Load file play back FW - * b[10] = Disk format (0 for HD DVD and 1 for BLU ray) - * b[11]-b[15] = default output resolution - * b[16] = Skip TX CPB Buffer Check - * b[17] = Adaptive Output Encrypt/Scramble Scheme - * b[18]-b[31] = reserved for future use - */ - -/* To allow multiple apps to open the device. */ -enum _DtsDeviceOpenMode { - DTS_PLAYBACK_MODE = 0, - DTS_DIAG_MODE, - DTS_MONITOR_MODE, - DTS_HWINIT_MODE -}; - -/* To enable the filter to selectively enable/disable fixes or erratas */ -enum _DtsDeviceFixMode { - DTS_LOAD_NEW_FW = BC_BIT(8), - DTS_LOAD_FILE_PLAY_FW = BC_BIT(9), - DTS_DISK_FMT_BD = BC_BIT(10), - /* b[11]-b[15] : Default output resolution */ - DTS_SKIP_TX_CHK_CPB = BC_BIT(16), - DTS_ADAPTIVE_OUTPUT_PER = BC_BIT(17), - DTS_INTELLIMAP = BC_BIT(18), - /* b[19]-b[21] : select clock frequency */ - DTS_PLAYBACK_DROP_RPT_MODE = BC_BIT(22), - DTS_DIAG_TEST_MODE = BC_BIT(23), - DTS_SINGLE_THREADED_MODE = BC_BIT(24), - DTS_FILTER_MODE = BC_BIT(25), - DTS_MFT_MODE = BC_BIT(26) -}; - -#define DTS_DFLT_RESOLUTION(x) (x<<11) - -#define DTS_DFLT_CLOCK(x) (x<<19) - -/* F/W File Version corresponding to S/W Releases */ -enum _FW_FILE_VER { - /* S/W release: 02.04.02 F/W release 2.12.2.0 */ - BC_FW_VER_020402 = ((12<<16) | (2<<8) | (0)) -}; - -/*------------------------------------------------------* - * Stream Types for DtsOpenDecoder() * - *------------------------------------------------------*/ -enum _DtsOpenDecStreamTypes { - BC_STREAM_TYPE_ES = 0, - BC_STREAM_TYPE_PES = 1, - BC_STREAM_TYPE_TS = 2, - BC_STREAM_TYPE_ES_TSTAMP = 6, -}; - -/*------------------------------------------------------* - * Video Algorithms for DtsSetVideoParams() * - *------------------------------------------------------*/ -enum _DtsSetVideoParamsAlgo { - BC_VID_ALGO_H264 = 0, - BC_VID_ALGO_MPEG2 = 1, - BC_VID_ALGO_VC1 = 4, - BC_VID_ALGO_DIVX = 6, - BC_VID_ALGO_VC1MP = 7, -}; - -/*------------------------------------------------------* - * MPEG Extension to the PPB * - *------------------------------------------------------*/ -#define BC_MPEG_VALID_PANSCAN (1) - -typedef struct _BC_PIB_EXT_MPEG { - uint32_t valid; - /* Always valid, defaults to picture size if no - * sequence display extension in the stream. */ - uint32_t display_horizontal_size; - uint32_t display_vertical_size; - - /* MPEG_VALID_PANSCAN - * Offsets are a copy values from the MPEG stream. */ - uint32_t offset_count; - int32_t horizontal_offset[3]; - int32_t vertical_offset[3]; - -} BC_PIB_EXT_MPEG; - -/*------------------------------------------------------* - * H.264 Extension to the PPB * - *------------------------------------------------------*/ -/* Bit definitions for 'other.h264.valid' field */ -#define H264_VALID_PANSCAN (1) -#define H264_VALID_SPS_CROP (2) -#define H264_VALID_VUI (4) - -typedef struct _BC_PIB_EXT_H264 { - /* 'valid' specifies which fields (or sets of - * fields) below are valid. If the corresponding - * bit in 'valid' is NOT set then that field(s) - * is (are) not initialized. */ - uint32_t valid; - - /* H264_VALID_PANSCAN */ - uint32_t pan_scan_count; - int32_t pan_scan_left[3]; - int32_t pan_scan_right[3]; - int32_t pan_scan_top[3]; - int32_t pan_scan_bottom[3]; - - /* H264_VALID_SPS_CROP */ - int32_t sps_crop_left; - int32_t sps_crop_right; - int32_t sps_crop_top; - int32_t sps_crop_bottom; - - /* H264_VALID_VUI */ - uint32_t chroma_top; - uint32_t chroma_bottom; - -} BC_PIB_EXT_H264; - -/*------------------------------------------------------* - * VC1 Extension to the PPB * - *------------------------------------------------------*/ -#define VC1_VALID_PANSCAN (1) - -typedef struct _BC_PIB_EXT_VC1 { - uint32_t valid; - - /* Always valid, defaults to picture size if no - * sequence display extension in the stream. */ - uint32_t display_horizontal_size; - uint32_t display_vertical_size; - - /* VC1 pan scan windows */ - uint32_t num_panscan_windows; - int32_t ps_horiz_offset[4]; - int32_t ps_vert_offset[4]; - int32_t ps_width[4]; - int32_t ps_height[4]; - -} BC_PIB_EXT_VC1; - - -/*------------------------------------------------------* - * Picture Information Block * - *------------------------------------------------------*/ -#if defined(__LINUX_USER__) -/* Values for 'pulldown' field. '0' means no pulldown information - * was present for this picture. */ -enum { - vdecNoPulldownInfo = 0, - vdecTop = 1, - vdecBottom = 2, - vdecTopBottom = 3, - vdecBottomTop = 4, - vdecTopBottomTop = 5, - vdecBottomTopBottom = 6, - vdecFrame_X2 = 7, - vdecFrame_X3 = 8, - vdecFrame_X1 = 9, - vdecFrame_X4 = 10, -}; - -/* Values for the 'frame_rate' field. */ -enum { - vdecFrameRateUnknown = 0, - vdecFrameRate23_97, - vdecFrameRate24, - vdecFrameRate25, - vdecFrameRate29_97, - vdecFrameRate30, - vdecFrameRate50, - vdecFrameRate59_94, - vdecFrameRate60, - vdecFrameRate14_985, - vdecFrameRate7_496, -}; - -/* Values for the 'aspect_ratio' field. */ -enum { - vdecAspectRatioUnknown = 0, - vdecAspectRatioSquare, - vdecAspectRatio12_11, - vdecAspectRatio10_11, - vdecAspectRatio16_11, - vdecAspectRatio40_33, - vdecAspectRatio24_11, - vdecAspectRatio20_11, - vdecAspectRatio32_11, - vdecAspectRatio80_33, - vdecAspectRatio18_11, - vdecAspectRatio15_11, - vdecAspectRatio64_33, - vdecAspectRatio160_99, - vdecAspectRatio4_3, - vdecAspectRatio16_9, - vdecAspectRatio221_1, - vdecAspectRatioOther = 255, -}; - -/* Values for the 'colour_primaries' field. */ -enum { - vdecColourPrimariesUnknown = 0, - vdecColourPrimariesBT709, - vdecColourPrimariesUnspecified, - vdecColourPrimariesReserved, - vdecColourPrimariesBT470_2M = 4, - vdecColourPrimariesBT470_2BG, - vdecColourPrimariesSMPTE170M, - vdecColourPrimariesSMPTE240M, - vdecColourPrimariesGenericFilm, -}; - -enum { - vdecRESOLUTION_CUSTOM = 0x00000000, /* custom */ - vdecRESOLUTION_480i = 0x00000001, /* 480i */ - vdecRESOLUTION_1080i = 0x00000002, /* 1080i (1920x1080, 60i) */ - vdecRESOLUTION_NTSC = 0x00000003, /* NTSC (720x483, 60i) */ - vdecRESOLUTION_480p = 0x00000004, /* 480p (720x480, 60p) */ - vdecRESOLUTION_720p = 0x00000005, /* 720p (1280x720, 60p) */ - vdecRESOLUTION_PAL1 = 0x00000006, /* PAL_1 (720x576, 50i) */ - vdecRESOLUTION_1080i25 = 0x00000007, /* 1080i25 (1920x1080, 50i) */ - vdecRESOLUTION_720p50 = 0x00000008, /* 720p50 (1280x720, 50p) */ - vdecRESOLUTION_576p = 0x00000009, /* 576p (720x576, 50p) */ - vdecRESOLUTION_1080i29_97 = 0x0000000A, /* 1080i (1920x1080, 59.94i) */ - vdecRESOLUTION_720p59_94 = 0x0000000B, /* 720p (1280x720, 59.94p) */ - vdecRESOLUTION_SD_DVD = 0x0000000C, /* SD DVD (720x483, 60i) */ - vdecRESOLUTION_480p656 = 0x0000000D, /* 480p (720x480, 60p), output bus width 8 bit, clock 74.25MHz */ - vdecRESOLUTION_1080p23_976 = 0x0000000E, /* 1080p23_976 (1920x1080, 23.976p) */ - vdecRESOLUTION_720p23_976 = 0x0000000F, /* 720p23_976 (1280x720p, 23.976p) */ - vdecRESOLUTION_240p29_97 = 0x00000010, /* 240p (1440x240, 29.97p ) */ - vdecRESOLUTION_240p30 = 0x00000011, /* 240p (1440x240, 30p) */ - vdecRESOLUTION_288p25 = 0x00000012, /* 288p (1440x288p, 25p) */ - vdecRESOLUTION_1080p29_97 = 0x00000013, /* 1080p29_97 (1920x1080, 29.97p) */ - vdecRESOLUTION_1080p30 = 0x00000014, /* 1080p30 (1920x1080, 30p) */ - vdecRESOLUTION_1080p24 = 0x00000015, /* 1080p24 (1920x1080, 24p) */ - vdecRESOLUTION_1080p25 = 0x00000016, /* 1080p25 (1920x1080, 25p) */ - vdecRESOLUTION_720p24 = 0x00000017, /* 720p24 (1280x720, 25p) */ - vdecRESOLUTION_720p29_97 = 0x00000018, /* 720p29.97 (1280x720, 29.97p) */ - vdecRESOLUTION_480p23_976 = 0x00000019, /* 480p23.976 (720*480, 23.976) */ - vdecRESOLUTION_480p29_97 = 0x0000001A, /* 480p29.976 (720*480, 29.97p) */ - vdecRESOLUTION_576p25 = 0x0000001B, /* 576p25 (720*576, 25p) */ - /* For Zero Frame Rate */ - vdecRESOLUTION_480p0 = 0x0000001C, /* 480p (720x480, 0p) */ - vdecRESOLUTION_480i0 = 0x0000001D, /* 480i (720x480, 0i) */ - vdecRESOLUTION_576p0 = 0x0000001E, /* 576p (720x576, 0p) */ - vdecRESOLUTION_720p0 = 0x0000001F, /* 720p (1280x720, 0p) */ - vdecRESOLUTION_1080p0 = 0x00000020, /* 1080p (1920x1080, 0p) */ - vdecRESOLUTION_1080i0 = 0x00000021, /* 1080i (1920x1080, 0i) */ -}; - -/* Bit definitions for 'flags' field */ -#define VDEC_FLAG_EOS (0x0004) - -#define VDEC_FLAG_FRAME (0x0000) -#define VDEC_FLAG_FIELDPAIR (0x0008) -#define VDEC_FLAG_TOPFIELD (0x0010) -#define VDEC_FLAG_BOTTOMFIELD (0x0018) - -#define VDEC_FLAG_PROGRESSIVE_SRC (0x0000) -#define VDEC_FLAG_INTERLACED_SRC (0x0020) -#define VDEC_FLAG_UNKNOWN_SRC (0x0040) - -#define VDEC_FLAG_BOTTOM_FIRST (0x0080) -#define VDEC_FLAG_LAST_PICTURE (0x0100) - -#define VDEC_FLAG_PICTURE_META_DATA_PRESENT (0x40000) - -#endif /* __LINUX_USER__ */ - -typedef struct _BC_PIC_INFO_BLOCK { - /* Common fields. */ - uint64_t timeStamp; /* Timestamp */ - uint32_t picture_number; /* Ordinal display number */ - uint32_t width; /* pixels */ - uint32_t height; /* pixels */ - uint32_t chroma_format; /* 0x420, 0x422 or 0x444 */ - uint32_t pulldown; - uint32_t flags; - uint32_t frame_rate; - uint32_t aspect_ratio; - uint32_t colour_primaries; - uint32_t picture_meta_payload; - uint32_t sess_num; - uint32_t ycom; - uint32_t custom_aspect_ratio_width_height; - uint32_t n_drop; /* number of non-reference frames remaining to be dropped */ - - /* Protocol-specific extensions. */ - union { - BC_PIB_EXT_H264 h264; - BC_PIB_EXT_MPEG mpeg; - BC_PIB_EXT_VC1 vc1; - } other; - -} BC_PIC_INFO_BLOCK, *PBC_PIC_INFO_BLOCK; - -/*------------------------------------------------------* - * ProcOut Info * - *------------------------------------------------------*/ -/* Optional flags for ProcOut Interface.*/ -enum _POUT_OPTIONAL_IN_FLAGS_{ - /* Flags from App to Device */ - BC_POUT_FLAGS_YV12 = 0x01, /* Copy Data in YV12 format */ - BC_POUT_FLAGS_STRIDE = 0x02, /* Stride size is valid. */ - BC_POUT_FLAGS_SIZE = 0x04, /* Take size information from Application */ - BC_POUT_FLAGS_INTERLACED = 0x08, /* copy only half the bytes */ - BC_POUT_FLAGS_INTERLEAVED = 0x10, /* interleaved frame */ - BC_POUT_FLAGS_STRIDE_UV = 0x20, /* Stride size is valid (for UV buffers). */ - BC_POUT_FLAGS_MODE = 0x40, /* Take output mode from Application, overrides YV12 flag if on */ - - /* Flags from Device to APP */ - BC_POUT_FLAGS_FMT_CHANGE = 0x10000, /* Data is not VALID when this flag is set */ - BC_POUT_FLAGS_PIB_VALID = 0x20000, /* PIB Information valid */ - BC_POUT_FLAGS_ENCRYPTED = 0x40000, /* Data is encrypted. */ - BC_POUT_FLAGS_FLD_BOT = 0x80000, /* Bottom Field data */ -}; - -//Decoder Capability -enum DECODER_CAP_FLAGS -{ - BC_DEC_FLAGS_H264 = 0x01, - BC_DEC_FLAGS_MPEG2 = 0x02, - BC_DEC_FLAGS_VC1 = 0x04, - BC_DEC_FLAGS_M4P2 = 0x08, //MPEG-4 Part 2: Divx, Xvid etc. -}; - -#if defined(__KERNEL__) || defined(__LINUX_USER__) -typedef BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, void *pOut); -#else -typedef BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, struct _BC_DTS_PROC_OUT *pOut); -#endif - -/* Line 21 Closed Caption */ -/* User Data */ -#define MAX_UD_SIZE 1792 /* 1920 - 128 */ - -typedef struct _BC_DTS_PROC_OUT { - uint8_t *Ybuff; /* Caller Supplied buffer for Y data */ - uint32_t YbuffSz; /* Caller Supplied Y buffer size */ - uint32_t YBuffDoneSz; /* Transferred Y datasize */ - - uint8_t *UVbuff; /* Caller Supplied buffer for UV data */ - uint32_t UVbuffSz; /* Caller Supplied UV buffer size */ - uint32_t UVBuffDoneSz; /* Transferred UV data size */ - - uint32_t StrideSz; /* Caller supplied Stride Size */ - uint32_t PoutFlags; /* Call IN Flags */ - - uint32_t discCnt; /* Picture discontinuity count */ - - BC_PIC_INFO_BLOCK PicInfo; /* Picture Information Block Data */ - - /* Line 21 Closed Caption */ - /* User Data */ - uint32_t UserDataSz; - uint8_t UserData[MAX_UD_SIZE]; - - void *hnd; - dts_pout_callback AppCallBack; - uint8_t DropFrames; - uint8_t b422Mode; /* Picture output Mode */ - uint8_t bPibEnc; /* PIB encrypted */ - uint8_t bRevertScramble; - uint32_t StrideSzUV; /* Caller supplied Stride Size */ - -} BC_DTS_PROC_OUT; - -typedef struct _BC_DTS_STATUS { - uint8_t ReadyListCount; /* Number of frames in ready list (reported by driver) */ - uint8_t FreeListCount; /* Number of frame buffers free. (reported by driver) */ - uint8_t PowerStateChange; /* Number of active state power transitions (reported by driver) */ - uint8_t reserved_[1]; - - uint32_t FramesDropped; /* Number of frames dropped. (reported by DIL) */ - uint32_t FramesCaptured; /* Number of frames captured. (reported by DIL) */ - uint32_t FramesRepeated; /* Number of frames repeated. (reported by DIL) */ - - uint32_t InputCount; /* Times compressed video has been sent to the HW. - * i.e. Successful DtsProcInput() calls (reported by DIL) */ - uint64_t InputTotalSize; /* Amount of compressed video that has been sent to the HW. - * (reported by DIL) */ - uint32_t InputBusyCount; /* Times compressed video has attempted to be sent to the HW - * but the input FIFO was full. (reported by DIL) */ - - uint32_t PIBMissCount; /* Amount of times a PIB is invalid. (reported by DIL) */ - - uint32_t cpbEmptySize; /* supported only for H.264, specifically changed for - * SingleThreadedAppMode. Report size of CPB buffer available. - * Reported by DIL */ - uint64_t NextTimeStamp; /* TimeStamp of the next picture that will be returned - * by a call to ProcOutput. Added for SingleThreadedAppMode. - * Reported back from the driver */ - uint8_t TxBufData; - - uint8_t reserved__[3]; - - uint32_t picNumFlags; /* Picture number and flags of the next picture to be delivered from the driver */ - - uint8_t reserved___[8]; - -} BC_DTS_STATUS; - -#define BC_SWAP32(_v) \ - ((((_v) & 0xFF000000)>>24)| \ - (((_v) & 0x00FF0000)>>8)| \ - (((_v) & 0x0000FF00)<<8)| \ - (((_v) & 0x000000FF)<<24)) - -#define WM_AGENT_TRAYICON_DECODER_OPEN 10001 -#define WM_AGENT_TRAYICON_DECODER_CLOSE 10002 -#define WM_AGENT_TRAYICON_DECODER_START 10003 -#define WM_AGENT_TRAYICON_DECODER_STOP 10004 -#define WM_AGENT_TRAYICON_DECODER_RUN 10005 -#define WM_AGENT_TRAYICON_DECODER_PAUSE 10006 - -#define MAX_COLOR_SPACES 3 - -typedef enum _BC_OUTPUT_FORMAT { - MODE420 = 0x0, - MODE422_YUY2 = 0x1, - MODE422_UYVY = 0x2, - OUTPUT_MODE420 = 0x0, - OUTPUT_MODE422_YUY2 = 0x1, - OUTPUT_MODE422_UYVY = 0x2, - OUTPUT_MODE420_NV12 = 0x0, - OUTPUT_MODE_INVALID = 0xFF, -} BC_OUTPUT_FORMAT; - -typedef struct _BC_COLOR_SPACES_ { - BC_OUTPUT_FORMAT OutFmt[MAX_COLOR_SPACES]; - uint16_t Count; -} BC_COLOR_SPACES; - - -typedef enum _BC_CAPS_FLAGS_ { - PES_CONV_SUPPORT = 1, /*Support PES Conversion*/ - MULTIPLE_DECODE_SUPPORT = 2 /*Support multiple stream decode*/ -} BC_CAPS_FLAGS; - -typedef struct _BC_HW_CAPABILITY_ { - BC_CAPS_FLAGS flags; - BC_COLOR_SPACES ColorCaps; - void* Reserved1; /* Expansion Of API */ - - //Decoder Capability - uint32_t DecCaps; //DECODER_CAP_FLAGS -} BC_HW_CAPS, *PBC_HW_CAPS; - -typedef struct _BC_SCALING_PARAMS_ { - uint32_t sWidth; - uint32_t sHeight; - uint32_t DNR; - uint32_t Reserved1; /*Expansion Of API*/ - uint8_t *Reserved2; /*Expansion OF API*/ - uint32_t Reserved3; /*Expansion Of API*/ - uint8_t *Reserved4; /*Expansion Of API*/ - -} BC_SCALING_PARAMS, *PBC_SCALING_PARAMS; - -typedef enum _BC_MEDIA_SUBTYPE_ { - BC_MSUBTYPE_INVALID = 0, - BC_MSUBTYPE_MPEG1VIDEO, - BC_MSUBTYPE_MPEG2VIDEO, - BC_MSUBTYPE_H264, - BC_MSUBTYPE_WVC1, - BC_MSUBTYPE_WMV3, - BC_MSUBTYPE_AVC1, - BC_MSUBTYPE_WMVA, - BC_MSUBTYPE_VC1, - BC_MSUBTYPE_DIVX, - BC_MSUBTYPE_DIVX311, - BC_MSUBTYPE_OTHERS /*Types to facilitate PES conversion*/ -} BC_MEDIA_SUBTYPE; - -typedef struct _BC_INPUT_FORMAT_ { - BOOL FGTEnable; /*Enable processing of FGT SEI*/ - BOOL MetaDataEnable; /*Enable retrieval of picture metadata to be sent to video pipeline.*/ - BOOL Progressive; /*Instruct decoder to always try to send back progressive - frames. If input content is 1080p, the decoder will - ignore pull-down flags and always give 1080p output. - If 1080i content is processed, the decoder will return - 1080i data. When this flag is not set, the decoder will - use pull-down information in the input stream to decide - the decoded data format.*/ - uint32_t OptFlags; /*In this field bits 0:3 are used pass default frame rate, bits 4:5 are for operation mode - (used to indicate Blu-ray mode to the decoder) and bit 6 is for the flag mpcOutPutMaxFRate - which when set tells the FW to output at the max rate for the resolution and ignore the - frame rate determined from the stream. Bit 7 is set to indicate that this is single threaded - mode and the driver will be peeked to get timestamps ahead of time*/ - BC_MEDIA_SUBTYPE mSubtype; /* Video Media Type*/ - uint32_t width; - uint32_t height; - uint32_t startCodeSz; /*Start code size for H264 clips*/ - uint8_t *pMetaData; /*Metadata buffer that is used to pass sequence header*/ - uint32_t metaDataSz; /*Metadata size*/ - uint8_t bEnableScaling; - BC_SCALING_PARAMS ScalingParams; -} BC_INPUT_FORMAT; - -typedef struct _BC_INFO_CRYSTAL_ { - uint8_t device; - union { - struct { - uint32_t dilRelease:8; - uint32_t dilMajor:8; - uint32_t dilMinor:16; - }; - uint32_t version; - } dilVersion; - - union { - struct { - uint32_t drvRelease:4; - uint32_t drvMajor:8; - uint32_t drvMinor:12; - uint32_t drvBuild:8; - }; - uint32_t version; - } drvVersion; - - union { - struct { - uint32_t fwRelease:4; - uint32_t fwMajor:8; - uint32_t fwMinor:12; - uint32_t fwBuild:8; - }; - uint32_t version; - } fwVersion; - - uint32_t Reserved1; // For future expansion - uint32_t Reserved2; // For future expansion -} BC_INFO_CRYSTAL, *PBC_INFO_CRYSTAL; - -#endif /* _BC_DTS_DEFS_H_ */ diff --git a/tools/depends/target/libcrystalhd/libcrystalhd/bc_dts_types.h b/tools/depends/target/libcrystalhd/libcrystalhd/bc_dts_types.h deleted file mode 100644 index a0b9ca52ad..0000000000 --- a/tools/depends/target/libcrystalhd/libcrystalhd/bc_dts_types.h +++ /dev/null @@ -1,68 +0,0 @@ -/******************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: bc_dts_types.h - * - * Description: Data types - * - * AU - * - * HISTORY: - * - ******************************************************************** - * This header is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this header. If not, see <http://www.gnu.org/licenses/>. - *******************************************************************/ - -#ifndef _BC_DTS_TYPES_H_ -#define _BC_DTS_TYPES_H_ - -#ifdef __LINUX_USER__ /* Don't include these for KERNEL.. */ -#include <stdint.h> -#endif - -#ifndef PVOID -typedef void *PVOID; -#endif - -#ifndef BOOL -typedef int BOOL; -#endif - -#ifdef __LINUX_USER__ /* Don't include these for KERNEL */ -typedef uint32_t ULONG; -typedef int32_t LONG; -typedef void *HANDLE; -#ifndef VOID -typedef void VOID; -#endif -typedef void *LPVOID; -typedef uint32_t DWORD; -typedef uint32_t UINT32; -typedef uint32_t *LPDWORD; -typedef unsigned char *PUCHAR; - -#ifndef TRUE - #define TRUE 1 -#endif - -#ifndef FALSE - #define FALSE 0 -#endif - -#else /* !__LINUX_USER__ */ - -/* For Kernel usage.. */ -typedef bool bc_bool_t; -#endif /* __LINUX_USER__ */ - -#endif - diff --git a/tools/depends/target/libcrystalhd/libcrystalhd/libcrystalhd_if.h b/tools/depends/target/libcrystalhd/libcrystalhd/libcrystalhd_if.h deleted file mode 100644 index 45fa7a63f8..0000000000 --- a/tools/depends/target/libcrystalhd/libcrystalhd/libcrystalhd_if.h +++ /dev/null @@ -1,1515 +0,0 @@ -/***************************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: libcrystalhd_if.h - * - * Description: Device Interface Library API. - * - * AU - * - * HISTORY: - * - ***************************************************************************** - * - * This file is part of libcrystalhd. - * - * This library is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this library. If not, see <http://www.gnu.org/licenses/>. - * - ****************************************************************************/ - -#ifndef _BCM_LDIL_IF_H_ -#define _BCM_LDIL_IF_H_ - -#include "bc_dts_defs.h" - -#define FLEA_MAX_TRICK_MODE_SPEED 6 - -#ifdef __cplusplus -extern "C" { -#endif - -/***************************************************************************** -****************************************************************************** - - Theory of operation - - - The Device Interface Library (DIL) allows application level code, such -as a DirectShow filter, to access the Broadcom CrystalHD decoder driver to -provide hardware decoding for MPEG-2, H.264 (AVC) and VC-1 streams. - - In the Microsoft DirectShow system, the overall system graph would look -like the following: - -+--------+ +---------------+ +---------------+ +--------------------+ -| Source |->| Demultiplexer |->| Audio decoder |->| DirectSound Device | -+--------+ +---------------+ +---------------+ +--------------------+ - | - | +-------------------------+ +----------------+ - +->| Broadcom decoder filter |->| Video Renderer | - +-------------------------+ +----------------+ - | | - +----------------+ - | Broadcom DIL | - +----------------+ - | | - +-----------------+ - | Broadcom Driver | - +-----------------+ - - From the view of the caller, the DIL will accept compressed video streams -and will output decoded video frames or fields to seperate Y and UV buffers. -The DIL is responsible solely for decoding video and has no responsibilities -for audio nor for rendering, as shown in the above diagram. Audio/video -sychronization is assisted by feeding the DIL with timestamps so that it -may pass those timestamps along with the decoded video. The timestamped -output video will then be presented at the appropriate time by the renderer. - -A minimal implementation would be: - - HANDLE hBRCMhandle; - uint8_t input_buffer[INPUT_SIZE]; - uint8_t y_output_buffer[WIDTH*HEIGHT]; - uint8_t uv_output_buffer[WIDTH*HEIGHT]; - BC_DTS_PROC_OUT sProcOutData = { fill in your values here }; - BC_PIC_INFO_BLOCK sPIB = { fill in your values here }; - - // Acquire handle for device. - DtsDeviceOpen(&hBRCMhandle, 0); - - // Elemental stream. - DtsOpenDecoder(hBRCMhandle, 0); - - // H.264, Enable FGT SEI, do not parse metadata, no forced progressive out - DtsSetVideoParams(hBRCMhandle,0,1,0,0,0); - - // Tell decoder to wait for input from host. (PC) - DtsStartDecoder(hBRCMhandle); - - // Input buffer address, input buffer size, no timestamp, Unencrypted - DtsProcInput(hBRCMhandle,input_buffer,sizeof(input_buffer),0,0); - - // Tell PC to wait for data from decoder. - DtsStartCapture(hBRCMhandle); - - // 16ms timeout, pass pointer to PIB then get the decoded picture. - DtsProcOutput(hBRCMhandle,16,&sPIB); - - // Stop the decoder. - DtsStopDecoder(hBRCMhandle); - - // Close the decoder - DtsCloseDecoder(hBRCMhandle); - - // Release handle for device. - DtsDeviceClose(hBRCMhandle); - -****************************************************************************** -*****************************************************************************/ - -#define DRVIFLIB_API - -/***************************************************************************** -Function name: - - DtsDeviceOpen - -Description: - - Opens a handle to the decoder device that will be used to address that - unique instance of the decoder for all subsequent operations. - - Must be called once when the application opens the decoder for use. - -Parameters: - - *hDevice Pointer to device handle that will be filled in after the - device is successfully opened. [OUTPUT] - - mode Controls the mode in which the device is opened. - Currently only mode 0 (normal playback) is supported. - All other values will return BC_STS_INV_ARG. - -Return: - - Returns BC_STS_SUCCESS or error codes as appropriate. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsDeviceOpen( - HANDLE *hDevice, - uint32_t mode - ); - -/***************************************************************************** - -Function name: - - DtsDeviceClose - -Description: - - Close the handle to the decoder device. - - Must be called once when the application closes the decoder after use. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - -Return: - - Returns BC_STS_SUCCESS or error codes as appropriate. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsDeviceClose( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsGetVersion - -Description: - - Get version information from the driver as well as API library. - Version numbers are maintained in <Major>.<Minor>.<Revision> format. - Example ?01.23.4567 - - The device must have been previously opened for this call to succeed. - The individual components of the revision number are available as follows: - - o Major (8 Bits) : Bit 31 ?24 - o Minor (8 Bits) : Bit 23 ?16 - o Revision (16 Bits) : Bits 15 ?Bit 0. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - DrVer Device driver version - DilVer Driver interface library version - -Return: - The revision numbers from the currently loaded driver as well as the - driver interface API library. - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetVersion( - HANDLE hDevice, - uint32_t *DrVer, - uint32_t *DilVer - ); - -/***************************************************************************** - -Function name: - - DtsGetFWVersionFromFile - -Description: - - Get version information from the Firmware Bin file when FW is not running - Version numbers in FW are maintained in <Major>.<Minor>.<Spl Revision> format. - the return value will be of the format: - (Major << 16) | (Minor<<8) | Spl_rev ?012345 - - The individual components of the revision number are available as follows: - - o Major (8 Bits) : Bit 24 ?16 - o Minor (8 Bits) : Bit 16 ?8 - o Revision (16 Bits) : Bits 8 ?0. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - StreamVer Stream FW version - DecVer VDEC FW version - Rsvd Reserved for future use - -Return: - The Stream FW Version umbers from the FW bin file in the install directory - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetFWVersionFromFile( - HANDLE hDevice, - uint32_t *StreamVer, - uint32_t *DecVer, - char *fname - ); - -/***************************************************************************** - -Function name: - - DtsGetFWVersion - -Description: - - Get version information from the Firmware. The version information is obtained - from Bin file when the flag is not set. When the flag is set, a FW command is - issued to get the version numbers. - Version numbers in FW are maintained in <Major>.<Minor>.<Spl Revision> format. - Version number will be returned in the following format - (Major << 16) | (Minor<<8) | Spl_rev ?012345 - - The individual components of the revision number are available as follows: - - o Major (8 Bits) : Bit 24 ?16 - o Minor (8 Bits) : Bit 16 ?8 - o Revision (16 Bits) : Bits 8 ?Bit 0. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen - StreamVer Stream FW version - DecVer VDEC FW version - HwVer Hardware version - Rsvd Reserved for future use - flag Reseved for future use - -Return: - The Stream FW Version number, VDEC FW version and Hwrev - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetFWVersion( - HANDLE hDevice, - uint32_t *StreamVer, - uint32_t *DecVer, - uint32_t *HwVer, - char *fname, - uint32_t flag - ); - - -/***************************************************************************** - -Function name: - - DtsOpenDecoder - -Description: - - Open the decoder for playback operations and sets appropriate parameters - for decode of input video data. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - StreamType Currently supported streams are: - Elementary Streams with no timestamp management (0) - Transport Streams (2) - Elementary Streams with timestamp management (6) - All other values will return BC_STS_INV_ARG. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsOpenDecoder( - HANDLE hDevice, - uint32_t StreamType - ); - -/***************************************************************************** - -Function name: - - DtsCloseDecoder - -Description: - - Close the decoder. No further pictures will be produced and all input - will be ignored. - - The device must have been previously opened for this call to succeed. - This function closes the decoder and cleans up the state of the driver - and the library. All pending pictures will be dropped and all outstanding - transfers to and from the decoder will be aborted. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsCloseDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsStartDecoder - -Description: - - Start the actual processing of input data. Before this command the - decoder will ignore all of the presented input data. - - DtsOpenDecoder must always be followed by a DtsStartDecoder for the - decoder to start processing input data. The device must have been - previously opened for this call to succeed. In addition the video - parameters for codec must have been set via a call to DtsSetVideoParams. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStartDecoder( - HANDLE hDevice - ); - - -/***************************************************************************** - -Function name: - - DtsSetVideoParams - -Description: - - Sets various codec parameters that would be used by a subsequent call - to DtsStartDecoder. - - DtsSetVideoParams must always be called before DtsStartDecoder for the - decoder to start processing input data. The device must have been - previously opened for this call to succeed. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - videoAlg Video Codec to be enabled to decode stream. - H.264 (0), VC-1 (4) and MPEG-2 (1) currently supported. - All other values will return BC_STS_INV_ARG - FGTEnable Enable processing of FGT SEI. - MetaDataEnable Enable retrieval of picture metadata to be sent to video - pipeline. - Progressive Instruct decoder to always try to send back progressive - frames. If input content is 1080p, the decoder will - ignore pull-down flags and always give 1080p output. - If 1080i content is processed, the decoder will return - 1080i data. When this flag is not set, the decoder will - use pull-down information in the input stream to decide - the decoded data format. - OptFlags In this field bits 0:3 are used pass default frame rate, - bits 4:5 are for operation mode (used to indicate Blu-ray - mode to the decoder) and bit 6 is for the flag mpcOutPutMaxFRate - which when set tells the FW to output at the max rate for the - resolution and ignore the frame rate determined from the - stream. Bit 7 is set to indicate that this is single threaded mode - and the driver will be peeked to get timestamps ahead of time. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetVideoParams( - HANDLE hDevice, - uint32_t videoAlg, - BOOL FGTEnable, - BOOL MetaDataEnable, - BOOL Progressive, - uint32_t OptFlags - ); - -/***************************************************************************** - -Function name: - - DtsSetInputFormat - -Description: - - Sets input video's various parameters that would be used by a subsequent call - to DtsStartDecoder. - - DtsSetInputFormat must always be called before DtsStartDecoder for the - decoder to start processing input data. The device must have been - previously opened for this call to succeed. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to DtsDeviceOpen. - pInputFormat Pointer to the BC_INPUT_FORMAT data. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetInputFormat( - HANDLE hDevice, - BC_INPUT_FORMAT *pInputFormat - ); - -/***************************************************************************** - -Function name: - - DtsGetVideoParams - -Description: - - Returns various codec parameters that would be used by a subsequent call - to DtsStartDecoder. These parameters are either default values or were - set via a prior call to DtsSetVideoParams - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - *videoAlg See DtsSetVideoParams. [OUTPUT] - *FGTEnable See DtsSetVideoParams. [OUTPUT] - *MetaDataEnable See DtsSetVideoParams. [OUTPUT] - *Progressive See DtsSetVideoParams. [OUTPUT] - Reserved This field is reserved for possible future expansion. - Set to 0. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetVideoParams( - HANDLE hDevice, - uint32_t *videoAlg, - BOOL *FGTEnable, - BOOL *MetaDataEnable, - BOOL *Progressive, - uint32_t Reserved - ); - -/***************************************************************************** - -Function name: - - DtsFormatChange - -Description: - - Changes codec type and parameters. - - The device must have been previously opened for this call to succeed. - This function should be used only for mid-stream format changes. - DtsStartDecoder must have been called before for this function to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - videoAlg Video Codec to be enabled to decode stream. - H.264 (0), VC-1 (4) and MPEG-2 (1) currently supported. All - other values will return BC_STS_INV_ARG - FGTEnable Enable processing of FGT SEI. - Progressive Instruct decoder to always try to send back progressive - frames. If input content is 1080p, the decoder will ignore - pull-down flags and always give 1080p output. If 1080i - content is processed, the decoder will return 1080i data. - When this flag is not set, the decoder will use pull-down - information in the input stream to decide the decoded data - format. - Reserved This field is reserved for possible future expansion. - Set to 0. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsFormatChange( - HANDLE hDevice, - uint32_t videoAlg, - BOOL FGTEnable, - BOOL MetaDataEnable, - BOOL Progressive, - uint32_t Reserved - ); - -/***************************************************************************** - -Function name: - - DtsStopDecoder - -Description: - - Stop the decoder. - - The device must have been previously opened for this call to succeed. - This function will clean up any pending operations and stop the decoder. - Internal state is still maintained and the decoder can be restarted. - Any pending pictures will be dropped. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStopDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsPauseDecoder - -Description: - - Pause the decoder. The paused picture will be repeated by decoder. - - The device must have been previously opened for this call to succeed. - In addition the decoder must have been started as well. If the decoder - is open but not started, this function will return BC_STS_DEC_NOT_STARTED. - If the decoder has not been opened this function will return - BC_STS_DEC_NOT_OPEN. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsPauseDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsResumeDecoder - -Description: - - Unpause the decoder from a previous paused condition. - - The device must have been previously opened for this call to succeed. - If the decoder was not paused previously, this function will return - without affecting the decoder with a BC_STS_SUCCESS status. If the - decoder is open but not started, this function will return - BC_STS_DEC_NOT_STARTED. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsResumeDecoder( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsSetVideoPID - -Description: - - Sets the video PID in the input Transport Stream that the decoder - needs to process. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - PID PID value that decoder needs to process. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetVideoPID( - HANDLE hDevice, - uint32_t pid - ); - - -/***************************************************************************** - -Function name: - - StartCaptureImmidiate - -Description: - - Instruct the driver to start capturing decoded frames for output. - - The device must have been previously opened for this call to succeed. - This function must be called before the first call to DtsProcInput. - This function instructs the receive path in the driver to start waiting - for valid data to be presented from the decoder. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStartCaptureImmidiate( - HANDLE hDevice, - uint32_t Reserved - ); - - -/***************************************************************************** - -Function name: - - StartCapture - -Description: - - Instruct the driver to start capturing decoded frames for output. - - The device must have been previously opened for this call to succeed. - This function must be called before the first call to DtsProcInput. - This function instructs the receive path in the driver to start waiting - for valid data to be presented from the decoder. - -Parameters: - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStartCapture( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - FlushRxCapture - -Description: - - ***This function is deprecated and is for temporary use only.*** - - Flush the driverÃs queue of pictures and stops the capture process. These - functions will be replaced with automatic Stop (End of Sequence) detection. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsFlushRxCapture( - HANDLE hDevice, - BOOL bDiscardOnly - ); - -/***************************************************************************** - -Function name: - - DtsProcOutput - -Description: - - Returns one decoded picture to the caller. - - The device must have been previously opened for this call to succeed. - - == NOTE ==== - For PIB AND 100% output encryption/scrambling on Bcm LINK hardware - use ProcOutputNoCopy() Interace. This interface will not support - PIB encryption. - - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - milliSecWait Timeout parameter. DtsProcOutput will fail is no picture - is received in this time. - *pOut This is a pointer to the BC_DTS_PROC_OUT structure that is - allocated by the caller. The decoded picture is returned - in this structure. This structure is described in the - data structures section. The actual data buffer to be - filled with the decoded data is allocated by the caller. - Data is copied from the decoder to the buffers before this - function returns. [INPUT/OUTPUT] - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsProcOutput( - HANDLE hDevice, - uint32_t milliSecWait, - BC_DTS_PROC_OUT *pOut - ); - -/***************************************************************************** - -Function name: - - DtsProcOutputNoCopy - -Description: - - Returns one decoded picture to the caller. Functionality of this API() - is very similar to ProcOutPut() API. This API will not copy the video data - to caller's buffers but provides the source buffer pointers in pOut structure. - - This is more secure and preferred method for BCM's Link hardware. The actual - format conversion/copy routines are provided as part of the Filter/Security - layer source code. Using this method, all the clear data handling will be - done by bcmDFilter or bcmSec layers which are expected to be in Player's - tamper resistant area. - - == NOTE ==== - 1) DtsReleaseOutputBuffs() interface must be called to release the buffers - back to DIL if return Status is BC_STS_SUCCESS. - - 2) Only this interface supports PIB and full 100% output encryption/Scrambling. - - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - milliSecWait Timeout parameter. DtsProcOoutput will fail is no picture - is received in this time. - *pOut This is a pointer to the BC_DTS_PROC_OUT structure that is - allocated by the caller. The decoded picture is returned - in this structure. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsProcOutputNoCopy( - HANDLE hDevice, - uint32_t milliSecWait, - BC_DTS_PROC_OUT *pOut - ); - -/***************************************************************************** - -Function name: - - DtsReleaseOutputBuffs - -Description: - - Release Buffers acquired during ProcOutputNoCopy() interface. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - Reserved Reserved. Set to NULL. - - fChange FALSE. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsReleaseOutputBuffs( - HANDLE hDevice, - PVOID Reserved, - BOOL fChange - ); - - -/***************************************************************************** - -Function name: - - DtsProcInput - -Description: - - Sends compressed (coded) data to the decoder for processing. - - The device must have been previously opened for this call to succeed. - In addition, suitable keys must have been exchanged for decryption and - decode to be successful. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - pUserData Pointer to data buffer that holds the data to be transferred. - [INPUT] - sizeInBytes Size in Bytes of data available to be sent to the decoder for - processing. - Timestamp Optional timestamp information attached to the media sample - that is available in the buffer. If timestamp is present - (i.e. non-zero), then this will be reflected in the output - sample (picture) produced from the contents of this buffer. - Timestamp should be in units of 100 ns. - Encrypted Flag to indicate that the data transfer is not in the clear - and that the decoder needs to decrypt before it can decode - the data. Note that due to complexity, it is preferred that - the application writer uses the higher level - dts_pre_proc_input() call if encypted content will be sent. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsProcInput( - HANDLE hDevice, - uint8_t *pUserData, - uint32_t ulSizeInBytes, - uint64_t timeStamp, - BOOL encrypted - ); - -/***************************************************************************** - -Function name: - - DtsGetColorPrimaries - -Description: - - Returns color primaries information from the stream being processed. - - The device must have been previously opened for this call to succeed. - In addition at least one picture must have been successfully decoded and - returned back from the decoder. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - colorPrimaries Pointer to U32 to receive the color primaries information. - The values returned are described in the previous section - regarding the picture metadata. [OUTPUT] - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetColorPrimaries( - HANDLE hDevice, - uint32_t *colorPrimaries - ); - -/***************************************************************************** - -Function name: - - DtsFlushInput - -Description: - - Flushes the current channel and causes the decoder to stop accessing input - data. Based on the flush mode parameter, the channel will be flushed from - the current point in the input data or from the current processing point. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - Mode 0 Flush at the current input point. use to drain the - input FIFO . All the data that has been received will - be decoded. - 1 Flush at the current processing point. All the decoded - frames will be presented but no more data from the - input will be decoded. - 2 Flushes all the decoder buffers, input, decoded and - to be decoded. - 3 Cancels the pending TX Request from the DIL/driver - 4 Flushes all the decoder buffers, input, decoded and - to be decoded data. Also flushes the drivers buffers - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsFlushInput( - HANDLE hDevice, - uint32_t Mode - ); - -/***************************************************************************** - -Function name: - - DtsSetRateChange - -Description: - - Sets the decoder playback speed and direction of playback. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - rate Inverse of speed x 10000. - Examples: - 1/2x playback speed = 20000 - 1x playback speed = 10000 - 2x playback speed = 5000 - - direction Playback direction. - 0 Forward direction. - 1 Reverse direction. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetRateChange( - HANDLE hDevice, - uint32_t rate, - uint8_t direction - ); - - -//Set FF Rate for Catching Up -/***************************************************************************** - -Function name: - - DtsSetFFRate - -Description: - - Sets the decoder playback FF speed - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - rate Inverse of speed x 10000. - Examples: - 1/2x playback speed = 20000 - 1x playback speed = 10000 - 2x playback speed = 5000 - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetFFRate( - HANDLE hDevice, - uint32_t rate - ); - -/***************************************************************************** - -Function name: - - DtsSetSkipPictureMode - -Description: - - This command sets the decoder to only decode selected picture types. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - SkipMode 0 IPB, All pictures are decoded. - - 1 IP decoding, This mode skips all non reference pictures. - - 2 I decoding, This mode skips all P/B pictures and only decodes - I pictures. -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetSkipPictureMode( - HANDLE hDevice, - uint32_t SkipMode - ); - -/***************************************************************************** - -Function name: - - DtsSetIFrameTrickMode - -Description: - - This command sets the decoder to decode only I Frames for FF and FR. - - Use this API for I Frame only trick mode play back in either direction. The - application/Up stream filter determines the speed of the playback by - means of Skip on the input compressed data. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetIFrameTrickMode( - HANDLE hDevice - ); - -/***************************************************************************** - -Function name: - - DtsStepDecoder - -Description: - - This function forwards one frame. - - The device must have been opened must be in paused - state previously for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsStepDecoder( - HANDLE hDevice - ); - - -/***************************************************************************** - -Function name: - - DtsIs422Supported - -Description: - - This function returns whether 422 YUV mode is supported or not. - - The device must have been opened previously for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - bSupported 1 - 422 is supported - 0 - 422 is not supported. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsIs422Supported( - HANDLE hDevice, - uint8_t *bSupported - ); - -/***************************************************************************** - -Function name: - - DtsSetColorSpace - -Description: - - This function sets the output sample's color space. - - The device must have been opened previously and must support 422 mode for - this call to succeed. - - Use "DtsIs422Supported" to find whether 422 mode is supported. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - 422Mode Mode is defined by BC_OUTPUT_FORMAT as follows - - OUTPUT_MODE420 = 0x0, - OUTPUT_MODE422_YUY2 = 0x1, - OUTPUT_MODE422_UYVY = 0x2, - OUTPUT_MODE_INVALID = 0xFF - Valid values for this API are OUTPUT_MODE422_YUY2 and OUTPUT_MODE422_UYVY - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetColorSpace( - HANDLE hDevice, - BC_OUTPUT_FORMAT Mode422 - ); - -/***************************************************************************** - -Function name: - - DtsSet422Mode - -Description: - - This function sets the 422 mode to either YUY2 or UYVY. - - The device must have been opened previously and must support 422 mode for - this call to succeed. - - Use "DtsIs422Supported" to find whether 422 mode is supported. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - 422Mode 0 - set the YUV mode to YUY2 - 1 - set the YUV mode to UYVY - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSet422Mode( - HANDLE hDevice, - uint8_t Mode422 - ); - -/***************************************************************************** - -Function name: - - DtsGetDILPath - -Description: - - This is a helper function to return DIL's Path. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - DilPath Buffer to hold DIL path info upto 256 bytes. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ - -DRVIFLIB_API BC_STATUS -DtsGetDILPath( - HANDLE hDevice, - char *DilPath, - uint32_t size - ); - -/***************************************************************************** - -Function name: - - DtsDropPictures - -Description: - - This command sets the decoder to skip one or more non-reference (B) pictures - in the input data stream. This is used for when the audio is ahead of - video and the application needs to cause video to move ahead to catch up. - Reference pictures are not skipped. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - Pictures The number of non-reference pictures to drop. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsDropPictures( - HANDLE hDevice, - uint32_t Pictures - ); - -/***************************************************************************** - -Function name: - - DtsGetDriverStatus - -Description: - - This command returns various statistics related to the driver and DIL. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - *pStatus Pointer to BC_DTS_STATUS to receive driver status. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetDriverStatus( - HANDLE hDevice, - BC_DTS_STATUS *pStatus - ); - -/***************************************************************************** - -Function name: - - DtsGetCapabilities - -Description: - - This command returns output format support and hardware capabilities. - - The device must have been previously opened for this call to succeed. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - pCapsBuffer Pointer to BC_HW_CAPS to receive HW Output capabilities. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsGetCapabilities ( - HANDLE hDevice, - PBC_HW_CAPS pCapsBuffer - ); - -/***************************************************************************** - -Function name: - - DtsSetScaleParams - -Description: - - This command sets hardware scaling parameters. - -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - pScaleParams Pointer to BC_SCALING_PARAMS to set hardware scaling parameters. - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsSetScaleParams ( - HANDLE hDevice, - PBC_SCALING_PARAMS pScaleParams - ); - -/***************************************************************************** - -Function name: - - DtsIsEndOfStream - -Description: - - This command returns whether the end of stream(EOS) is reaching. -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - bEOS Pointer to uint8_t to indicate if EOS of not - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsIsEndOfStream( - HANDLE hDevice, - uint8_t* bEOS -); - -/***************************************************************************** - -Function name: - - DtsCrystalHDVersion - -Description: - - This API returns hw and sw version information for Crystal HD solutions -Parameters: - - hDevice Handle to device. This is obtained via a prior call to - DtsDeviceOpen. - - bCrystalInfo Pointer to structure to fill in with information - - device = 0 for BCM70012, 1 for BCM70015 - -Return: - - BC_STS_SUCCESS will be returned on successful completion. - -*****************************************************************************/ -DRVIFLIB_API BC_STATUS -DtsCrystalHDVersion( - HANDLE hDevice, - PBC_INFO_CRYSTAL bCrystalInfo -); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/tools/depends/target/libcrystalhd/libcrystalhd/libcrystalhd_version.h b/tools/depends/target/libcrystalhd/libcrystalhd/libcrystalhd_version.h deleted file mode 100644 index b640dac41a..0000000000 --- a/tools/depends/target/libcrystalhd/libcrystalhd/libcrystalhd_version.h +++ /dev/null @@ -1,80 +0,0 @@ -/******************************************************************** - * Copyright(c) 2006-2009 Broadcom Corporation. - * - * Name: libcrystalhd_version.h - * - * Description: Version numbering for the driver use. - * - * AU - * - * HISTORY: - * - ******************************************************************** - * This header is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation, either version 2.1 of the License. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * You should have received a copy of the GNU Lesser General Public License - * along with this header. If not, see <http://www.gnu.org/licenses/>. - *******************************************************************/ - -#ifndef _BC_DTS_VERSION_LNX_ -#define _BC_DTS_VERSION_LNX_ -// -// The version format that we are adopting is -// MajorVersion.MinorVersion.Revision -// This will be the same for all the components. -// -// -#define STRINGIFY_VERSION(MAJ,MIN,REV) STRINGIFIED_VERSION(MAJ,MIN,REV) -#define STRINGIFIED_VERSION(MAJ,MIN,REV) #MAJ "." #MIN "." #REV - -#define STRINGIFY_VERSION_W(MAJ,MIN,REV) STRINGIFIED_VERSION_W(MAJ,MIN,REV) -#define STRINGIFIED_VERSION_W(MAJ,MIN,REV) #MAJ "." #MIN "." #REV - -// -// Product Version number is: -// x.y.z.a -// -// x = Major release. 1 = Dozer, 2 = Dozer + Link -// y = Minor release. Should increase +1 per "real" release. -// z = Branch release. 0 for main branch. This is +1 per branch release. -// a = Build number +1 per candidate release. Reset to 0 every "real" release. -// -// -// Enabling Check-In rules enforcement 08092007 -// -#define INVALID_VERSION 0xFFFF - -/*========================== Common For All Components =================================*/ -#define BRCM_MAJOR_VERSION 3 - -#define DRIVER_MAJOR_VERSION BRCM_MAJOR_VERSION -#define DRIVER_MINOR_VERSION 6 -#define DRIVER_REVISION 0 - -#define RC_FILE_VERSION STRINGIFY_VERSION(DRIVER_MAJOR_VERSION,DRIVER_MINOR_VERSION,DRIVER_REVISION) ".0" - -/*======================= Device Interface Library ========================*/ -#define DIL_MAJOR_VERSION BRCM_MAJOR_VERSION -#define DIL_MINOR_VERSION 6 -#define DIL_REVISION 0 - -#define DIL_RC_FILE_VERSION STRINGIFY_VERSION(DIL_MAJOR_VERSION,DIL_MINOR_VERSION,DIL_REVISION) - -/*========================== deconf utility ==============================*/ -#define DECONF_MAJOR_VERSION BRCM_MAJOR_VERSION -#define DECONF_MINOR_VERSION 9 -#define DECONF_REVISION 18 -#define DECONF_RC_FILE_VERSION STRINGIFY_VERSION(DIL_MAJOR_VERSION,DIL_MINOR_VERSION,DIL_REVISION) - -/*========================== Firmware ==============================*/ -#define FW_MAJOR_VERSION BRCM_MAJOR_VERSION -#define FW_MINOR_VERSION 60 -#define FW_REVISION 39 - -#endif diff --git a/xbmc/Application.cpp b/xbmc/Application.cpp index 2093886a4a..57ea71b720 100644 --- a/xbmc/Application.cpp +++ b/xbmc/Application.cpp @@ -156,9 +156,6 @@ #ifdef HAS_AIRTUNES #include "network/AirTunesServer.h" #endif -#if defined(HAVE_LIBCRYSTALHD) -#include "cores/dvdplayer/DVDCodecs/Video/CrystalHD.h" -#endif #include "interfaces/AnnouncementManager.h" #include "peripherals/Peripherals.h" #include "peripherals/dialogs/GUIDialogPeripheralManager.h" @@ -1523,10 +1520,6 @@ bool CApplication::Initialize() m_slowTimer.StartZero(); -#if defined(HAVE_LIBCRYSTALHD) - CCrystalHD::GetInstance(); -#endif - CAddonMgr::Get().StartServices(true); CLog::Log(LOGNOTICE, "initialize done"); @@ -3616,10 +3609,6 @@ void CApplication::Stop(int exitCode) XBMCHelper::GetInstance().Stop(); #endif -#if defined(HAVE_LIBCRYSTALHD) - CCrystalHD::RemoveInstance(); -#endif - g_mediaManager.Stop(); // Stop services before unloading Python diff --git a/xbmc/DllPaths_generated.h.in b/xbmc/DllPaths_generated.h.in index 74bd5d1820..37a179bfab 100644 --- a/xbmc/DllPaths_generated.h.in +++ b/xbmc/DllPaths_generated.h.in @@ -73,13 +73,6 @@ #define DLL_PATH_OGG "@OGG_SONAME@" #define DLL_PATH_VORBIS "@VORBIS_SONAME@" -/* broadcom crystalhd */ -#if defined(TARGET_DARWIN) -#define DLL_PATH_LIBCRYSTALHD "libcrystalhd.dylib" -#else -#define DLL_PATH_LIBCRYSTALHD "@CRYSTALHD_SONAME@" -#endif - /* libbluray */ #define DLL_PATH_LIBBLURAY "@BLURAY_SONAME@" diff --git a/xbmc/DllPaths_win32.h b/xbmc/DllPaths_win32.h index 4cf3cd1122..fcc1148f6c 100644 --- a/xbmc/DllPaths_win32.h +++ b/xbmc/DllPaths_win32.h @@ -51,7 +51,6 @@ #define DLL_PATH_LIBASS "special://xbmcbin/system/players/dvdplayer/libass.dll" #define DLL_PATH_LIBMPEG2 "special://xbmcbin/system/players/dvdplayer/libmpeg2-0.dll" #define DLL_PATH_LIBDVDNAV "special://xbmcbin/system/players/dvdplayer/libdvdnav.dll" -#define DLL_PATH_LIBCRYSTALHD "special://xbmcbin/system/players/dvdplayer/bcmDIL.dll" #define DLL_PATH_LIBRTMP "special://xbmcbin/system/players/dvdplayer/librtmp.dll" /* ffmpeg */ diff --git a/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp b/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp index 32d58d4060..181d755ad8 100644 --- a/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp +++ b/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp @@ -37,9 +37,6 @@ #include "Video/DVDVideoCodecOpenMax.h" #include "Video/DVDVideoCodecLibMpeg2.h" #include "Video/DVDVideoCodecStageFright.h" -#if defined(HAVE_LIBCRYSTALHD) -#include "Video/DVDVideoCodecCrystalHD.h" -#endif #if defined(HAS_LIBAMCODEC) #include "utils/AMLUtils.h" #include "Video/DVDVideoCodecAmlogic.h" @@ -149,11 +146,6 @@ CDVDVideoCodec* CDVDFactoryCodec::CreateVideoCodec(CDVDStreamInfo &hint, unsigne #elif defined(TARGET_DARWIN) hwSupport += "VideoToolBoxDecoder:no "; #endif -#ifdef HAVE_LIBCRYSTALHD - hwSupport += "CrystalHD:yes "; -#else - hwSupport += "CrystalHD:no "; -#endif #if defined(HAS_LIBAMCODEC) hwSupport += "AMCodec:yes "; #else @@ -235,30 +227,6 @@ CDVDVideoCodec* CDVDFactoryCodec::CreateVideoCodec(CDVDStreamInfo &hint, unsigne } #endif -#if defined(HAVE_LIBCRYSTALHD) - if (!hint.software && CSettings::Get().GetBool("videoplayer.usechd")) - { - if (CCrystalHD::GetInstance()->DevicePresent()) - { - switch(hint.codec) - { - case AV_CODEC_ID_VC1: - case AV_CODEC_ID_WMV3: - case AV_CODEC_ID_H264: - case AV_CODEC_ID_MPEG2VIDEO: - if (hint.codec == AV_CODEC_ID_H264 && hint.ptsinvalid) - break; - if (hint.codec == AV_CODEC_ID_MPEG2VIDEO && hint.width <= 720) - break; - if ( (pCodec = OpenCodec(new CDVDVideoCodecCrystalHD(), hint, options)) ) return pCodec; - break; - default: - break; - } - } - } -#endif - #if defined(TARGET_ANDROID) if (!hint.software && CSettings::Get().GetBool("videoplayer.usemediacodec")) { diff --git a/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD.cpp b/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD.cpp deleted file mode 100644 index 2dcc2442a4..0000000000 --- a/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD.cpp +++ /dev/null @@ -1,2011 +0,0 @@ -/* - * Copyright (C) 2005-2013 Team XBMC - * http://xbmc.org - * - * This Program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This Program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with XBMC; see the file COPYING. If not, see - * <http://www.gnu.org/licenses/>. - * - */ - -#include "system.h" -#if defined(TARGET_WINDOWS) -#include "WIN32Util.h" -#include "util.h" -#include "dialogs/GUIDialogKaiToast.h" -#include "guilib/LocalizeStrings.h" -#endif - -#if defined(HAVE_LIBCRYSTALHD) -#include "CrystalHD.h" - -#include "DVDClock.h" -#include "DynamicDll.h" -#include "utils/SystemInfo.h" -#include "threads/Atomics.h" -#include "threads/Thread.h" -#include "utils/log.h" -#include "utils/fastmemcpy.h" -extern "C" { -#include "libswscale/swscale.h" -} -#include "utils/TimeUtils.h" -#include "windowing/WindowingFactory.h" -#include "cores/FFmpeg.h" - -namespace BCM -{ - #if defined(TARGET_WINDOWS) - typedef void *HANDLE; - #else - #ifndef __LINUX_USER__ - #define __LINUX_USER__ - #endif - #endif - - #include <libcrystalhd/bc_dts_types.h> - #include <libcrystalhd/bc_dts_defs.h> - #include <libcrystalhd/libcrystalhd_if.h> -}; - -#define __MODULE_NAME__ "CrystalHD" -//#define USE_CHD_SINGLE_THREADED_API -class DllLibCrystalHDInterface -{ -public: - virtual ~DllLibCrystalHDInterface() {} - virtual BCM::BC_STATUS DtsDeviceOpen(void *hDevice, uint32_t mode)=0; - virtual BCM::BC_STATUS DtsDeviceClose(void *hDevice)=0; - virtual BCM::BC_STATUS DtsOpenDecoder(void *hDevice, uint32_t StreamType)=0; - virtual BCM::BC_STATUS DtsCloseDecoder(void *hDevice)=0; - virtual BCM::BC_STATUS DtsStartDecoder(void *hDevice)=0; - virtual BCM::BC_STATUS DtsSetVideoParams(void *hDevice, uint32_t videoAlg, int FGTEnable, int MetaDataEnable, int Progressive, uint32_t OptFlags)=0; - virtual BCM::BC_STATUS DtsStartCapture(void *hDevice)=0; - virtual BCM::BC_STATUS DtsFlushRxCapture(void *hDevice, int bDiscardOnly)=0; - virtual BCM::BC_STATUS DtsSetFFRate(void *hDevice, uint32_t rate)=0; - virtual BCM::BC_STATUS DtsGetDriverStatus(void *hDevice, BCM::BC_DTS_STATUS *pStatus)=0; - virtual BCM::BC_STATUS DtsProcInput(void *hDevice, uint8_t *pUserData, uint32_t ulSizeInBytes, uint64_t timeStamp, int encrypted)=0; - virtual BCM::BC_STATUS DtsProcOutput(void *hDevice, uint32_t milliSecWait, BCM::BC_DTS_PROC_OUT *pOut)=0; - virtual BCM::BC_STATUS DtsProcOutputNoCopy(void *hDevice, uint32_t milliSecWait, BCM::BC_DTS_PROC_OUT *pOut)=0; - virtual BCM::BC_STATUS DtsReleaseOutputBuffs(void *hDevice, void *Reserved, int fChange)=0; - virtual BCM::BC_STATUS DtsSetSkipPictureMode(void *hDevice, uint32_t Mode)=0; - virtual BCM::BC_STATUS DtsFlushInput(void *hDevice, uint32_t SkipMode)=0; - -#if (HAVE_LIBCRYSTALHD == 2) - // new function calls, only present in new driver/library so manually load them - virtual BCM::BC_STATUS DtsGetVersion(void *hDevice, uint32_t *DrVer, uint32_t *DilVer)=0; - virtual BCM::BC_STATUS DtsSetInputFormat(void *hDevice, BCM::BC_INPUT_FORMAT *pInputFormat)=0; - virtual BCM::BC_STATUS DtsGetColorPrimaries(void *hDevice, uint32_t *colorPrimaries)=0; - virtual BCM::BC_STATUS DtsSetColorSpace(void *hDevice, BCM::BC_OUTPUT_FORMAT Mode422)=0; - virtual BCM::BC_STATUS DtsGetCapabilities(void *hDevice, BCM::BC_HW_CAPS *CapsBuffer)=0; - virtual BCM::BC_STATUS DtsSetScaleParams(void *hDevice, BCM::BC_SCALING_PARAMS *ScaleParams)=0; - virtual BCM::BC_STATUS DtsIsEndOfStream(void *hDevice, uint8_t* bEOS)=0; - virtual BCM::BC_STATUS DtsCrystalHDVersion(void *hDevice, BCM::BC_INFO_CRYSTAL *CrystalInfo)=0; -#endif -}; - -class DllLibCrystalHD : public DllDynamic, DllLibCrystalHDInterface -{ - DECLARE_DLL_WRAPPER(DllLibCrystalHD, DLL_PATH_LIBCRYSTALHD) - - DEFINE_METHOD2(BCM::BC_STATUS, DtsDeviceOpen, (void *p1, uint32_t p2)) - DEFINE_METHOD1(BCM::BC_STATUS, DtsDeviceClose, (void *p1)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsOpenDecoder, (void *p1, uint32_t p2)) - DEFINE_METHOD1(BCM::BC_STATUS, DtsCloseDecoder, (void *p1)) - DEFINE_METHOD1(BCM::BC_STATUS, DtsStartDecoder, (void *p1)) - DEFINE_METHOD1(BCM::BC_STATUS, DtsStopDecoder, (void *p1)) - DEFINE_METHOD6(BCM::BC_STATUS, DtsSetVideoParams, (void *p1, uint32_t p2, int p3, int p4, int p5, uint32_t p6)) - DEFINE_METHOD1(BCM::BC_STATUS, DtsStartCapture, (void *p1)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsFlushRxCapture, (void *p1, int p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsSetFFRate, (void *p1, uint32_t p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsGetDriverStatus, (void *p1, BCM::BC_DTS_STATUS *p2)) - DEFINE_METHOD5(BCM::BC_STATUS, DtsProcInput, (void *p1, uint8_t *p2, uint32_t p3, uint64_t p4, int p5)) - DEFINE_METHOD3(BCM::BC_STATUS, DtsProcOutput, (void *p1, uint32_t p2, BCM::BC_DTS_PROC_OUT *p3)) - DEFINE_METHOD3(BCM::BC_STATUS, DtsProcOutputNoCopy,(void *p1, uint32_t p2, BCM::BC_DTS_PROC_OUT *p3)) - DEFINE_METHOD3(BCM::BC_STATUS, DtsReleaseOutputBuffs,(void *p1, void *p2, int p3)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsSetSkipPictureMode,(void *p1, uint32_t p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsFlushInput, (void *p1, uint32_t p2)) - -#if (HAVE_LIBCRYSTALHD == 2) - DEFINE_METHOD3(BCM::BC_STATUS, DtsGetVersion, (void *p1, uint32_t *p2, uint32_t *p3)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsSetInputFormat, (void *p1, BCM::BC_INPUT_FORMAT *p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsGetColorPrimaries,(void *p1, uint32_t *p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsSetColorSpace, (void *p1, BCM::BC_OUTPUT_FORMAT p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsGetCapabilities, (void *p1, BCM::BC_HW_CAPS *p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsSetScaleParams, (void *p1, BCM::BC_SCALING_PARAMS *p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsIsEndOfStream, (void *p1, uint8_t *p2)) - DEFINE_METHOD2(BCM::BC_STATUS, DtsCrystalHDVersion,(void *p1, BCM::BC_INFO_CRYSTAL *p2)) -#endif - - BEGIN_METHOD_RESOLVE() - RESOLVE_METHOD_RENAME(DtsDeviceOpen, DtsDeviceOpen) - RESOLVE_METHOD_RENAME(DtsDeviceClose, DtsDeviceClose) - RESOLVE_METHOD_RENAME(DtsOpenDecoder, DtsOpenDecoder) - RESOLVE_METHOD_RENAME(DtsCloseDecoder, DtsCloseDecoder) - RESOLVE_METHOD_RENAME(DtsStartDecoder, DtsStartDecoder) - RESOLVE_METHOD_RENAME(DtsStopDecoder, DtsStopDecoder) - RESOLVE_METHOD_RENAME(DtsSetVideoParams, DtsSetVideoParams) - RESOLVE_METHOD_RENAME(DtsStartCapture, DtsStartCapture) - RESOLVE_METHOD_RENAME(DtsFlushRxCapture, DtsFlushRxCapture) - RESOLVE_METHOD_RENAME(DtsSetFFRate, DtsSetFFRate) - RESOLVE_METHOD_RENAME(DtsGetDriverStatus, DtsGetDriverStatus) - RESOLVE_METHOD_RENAME(DtsProcInput, DtsProcInput) - RESOLVE_METHOD_RENAME(DtsProcOutput, DtsProcOutput) - RESOLVE_METHOD_RENAME(DtsProcOutputNoCopy,DtsProcOutputNoCopy) - RESOLVE_METHOD_RENAME(DtsReleaseOutputBuffs,DtsReleaseOutputBuffs) - RESOLVE_METHOD_RENAME(DtsSetSkipPictureMode,DtsSetSkipPictureMode) - RESOLVE_METHOD_RENAME(DtsFlushInput, DtsFlushInput) - END_METHOD_RESOLVE() - -public: - bool LoadNewLibFunctions(void) - { -#if (HAVE_LIBCRYSTALHD == 2) - int rtn; - rtn = m_dll->ResolveExport("DtsGetVersion", (void**)&m_DtsGetVersion_ptr, false); - rtn &= m_dll->ResolveExport("DtsSetInputFormat", (void**)&m_DtsSetInputFormat_ptr, false); - rtn &= m_dll->ResolveExport("DtsGetColorPrimaries",(void**)&m_DtsGetColorPrimaries_ptr, false); - rtn &= m_dll->ResolveExport("DtsSetColorSpace", (void**)&m_DtsSetColorSpace_ptr, false); - rtn &= m_dll->ResolveExport("DtsGetCapabilities", (void**)&m_DtsGetCapabilities_ptr, false); - rtn &= m_dll->ResolveExport("DtsSetScaleParams", (void**)&m_DtsSetScaleParams_ptr, false); - rtn &= m_dll->ResolveExport("DtsIsEndOfStream", (void**)&m_DtsIsEndOfStream_ptr, false); - rtn &= m_dll->ResolveExport("DtsCrystalHDVersion", (void**)&m_DtsCrystalHDVersion_ptr, false); - rtn &= m_dll->ResolveExport("DtsSetInputFormat", (void**)&m_DtsSetInputFormat_ptr, false); - return(rtn == 1); -#else - return false; -#endif - }; -}; - -void PrintFormat(BCM::BC_PIC_INFO_BLOCK &pib); -void BcmDebugLog( BCM::BC_STATUS lResult, std::string strFuncName=""); - -const char* g_DtsStatusText[] = { - "BC_STS_SUCCESS", - "BC_STS_INV_ARG", - "BC_STS_BUSY", - "BC_STS_NOT_IMPL", - "BC_STS_PGM_QUIT", - "BC_STS_NO_ACCESS", - "BC_STS_INSUFF_RES", - "BC_STS_IO_ERROR", - "BC_STS_NO_DATA", - "BC_STS_VER_MISMATCH", - "BC_STS_TIMEOUT", - "BC_STS_FW_CMD_ERR", - "BC_STS_DEC_NOT_OPEN", - "BC_STS_ERR_USAGE", - "BC_STS_IO_USER_ABORT", - "BC_STS_IO_XFR_ERROR", - "BC_STS_DEC_NOT_STARTED", - "BC_STS_FWHEX_NOT_FOUND", - "BC_STS_FMT_CHANGE", - "BC_STS_HIF_ACCESS", - "BC_STS_CMD_CANCELLED", - "BC_STS_FW_AUTH_FAILED", - "BC_STS_BOOTLOADER_FAILED", - "BC_STS_CERT_VERIFY_ERROR", - "BC_STS_DEC_EXIST_OPEN", - "BC_STS_PENDING", - "BC_STS_CLK_NOCHG" -}; - -//////////////////////////////////////////////////////////////////////////////////////////// -class CMPCOutputThread : public CThread -{ -public: - CMPCOutputThread(void *device, DllLibCrystalHD *dll, bool has_bcm70015); - virtual ~CMPCOutputThread(); - - unsigned int GetReadyCount(void); - unsigned int GetFreeCount(void); - CPictureBuffer* ReadyListPop(void); - void FreeListPush(CPictureBuffer* pBuffer); - bool WaitOutput(unsigned int msec); - -protected: - void DoFrameRateTracking(double timestamp); - void SetFrameRate(uint32_t resolution); - void SetAspectRatio(BCM::BC_PIC_INFO_BLOCK *pic_info); - void CopyOutAsNV12(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride); - void CopyOutAsNV12DeInterlace(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride); - void CopyOutAsYV12(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride); - void CopyOutAsYV12DeInterlace(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride); - void CheckUpperLeftGreenPixelHack(CPictureBuffer *pBuffer); - bool GetDecoderOutput(void); - virtual void Process(void); - - CSyncPtrQueue<CPictureBuffer> m_FreeList; - CSyncPtrQueue<CPictureBuffer> m_ReadyList; - - DllLibCrystalHD *m_dll; - void *m_device; - bool m_has_bcm70015; - unsigned int m_timeout; - bool m_format_valid; - bool m_is_live_stream; - int m_width; - int m_height; - uint64_t m_timestamp; - bool m_output_YV12; - uint64_t m_PictureNumber; - uint8_t m_color_space; - unsigned int m_color_range; - unsigned int m_color_matrix; - int m_interlace; - bool m_framerate_tracking; - uint64_t m_framerate_cnt; - double m_framerate_timestamp; - double m_framerate; - int m_aspectratio_x; - int m_aspectratio_y; - CEvent m_ready_event; - struct SwsContext *m_sw_scale_ctx; -}; - -//////////////////////////////////////////////////////////////////////////////////////////// -#if defined(TARGET_DARWIN) -#pragma mark - -#endif -CPictureBuffer::CPictureBuffer(ERenderFormat format, int width, int height) -{ - m_width = width; - m_height = height; - m_field = CRYSTALHD_FIELD_FULL; - m_interlace = false; - m_timestamp = DVD_NOPTS_VALUE; - m_PictureNumber = 0; - m_color_space = BCM::MODE420; - m_color_range = 0; - m_color_matrix = 4; - m_format = format; - m_framerate = 0; - - switch(m_format) - { - default: - case RENDER_FMT_NV12: - // setup y plane - m_y_buffer_size = m_width * m_height; - m_y_buffer_ptr = (unsigned char*)_aligned_malloc(m_y_buffer_size, 16); - - m_u_buffer_size = 0; - m_v_buffer_size = 0; - m_u_buffer_ptr = NULL; - m_v_buffer_ptr = NULL; - m_uv_buffer_size = m_y_buffer_size / 2; - m_uv_buffer_ptr = (unsigned char*)_aligned_malloc(m_uv_buffer_size, 16); - break; - case RENDER_FMT_YUYV422: - // setup y plane - m_y_buffer_size = (2 * m_width) * m_height; - m_y_buffer_ptr = (unsigned char*)_aligned_malloc(m_y_buffer_size, 16); - - m_uv_buffer_size = 0; - m_uv_buffer_ptr = NULL; - m_u_buffer_size = 0; - m_v_buffer_size = 0; - m_u_buffer_ptr = NULL; - m_v_buffer_ptr = NULL; - break; - case RENDER_FMT_YUV420P: - // setup y plane - m_y_buffer_size = m_width * m_height; - m_y_buffer_ptr = (unsigned char*)_aligned_malloc(m_y_buffer_size, 16); - - m_uv_buffer_size = 0; - m_uv_buffer_ptr = NULL; - m_u_buffer_size = m_y_buffer_size / 4; - m_v_buffer_size = m_y_buffer_size / 4; - m_u_buffer_ptr = (unsigned char*)_aligned_malloc(m_u_buffer_size, 16); - m_v_buffer_ptr = (unsigned char*)_aligned_malloc(m_v_buffer_size, 16); - break; - } -} - -CPictureBuffer::~CPictureBuffer() -{ - if (m_y_buffer_ptr) _aligned_free(m_y_buffer_ptr); - if (m_u_buffer_ptr) _aligned_free(m_u_buffer_ptr); - if (m_v_buffer_ptr) _aligned_free(m_v_buffer_ptr); - if (m_uv_buffer_ptr) _aligned_free(m_uv_buffer_ptr); -} - -///////////////////////////////////////////////////////////////////////////////////////////// -#if defined(TARGET_DARWIN) -#pragma mark - -#endif -CMPCOutputThread::CMPCOutputThread(void *device, DllLibCrystalHD *dll, bool has_bcm70015) : - CThread("MPCOutput"), - m_dll(dll), - m_device(device), - m_has_bcm70015(has_bcm70015), - m_timeout(20), - m_format_valid(false), - m_is_live_stream(false), - m_width(0), - m_height(0), - m_timestamp(0), - m_PictureNumber(0), - m_color_space(0), - m_color_range(0), - m_color_matrix(0), - m_interlace(0), - m_framerate_tracking(false), - m_framerate_cnt(0), - m_framerate_timestamp(0.0), - m_framerate(0.0), - m_aspectratio_x(1), - m_aspectratio_y(1) -{ - m_sw_scale_ctx = NULL; - - if (g_Windowing.GetRenderQuirks() & RENDER_QUIRKS_YV12_PREFERED) - m_output_YV12 = true; - else - m_output_YV12 = false; -} - -CMPCOutputThread::~CMPCOutputThread() -{ - while(m_ReadyList.Count()) - delete m_ReadyList.Pop(); - while(m_FreeList.Count()) - delete m_FreeList.Pop(); - - if (m_sw_scale_ctx) - sws_freeContext(m_sw_scale_ctx); -} - -unsigned int CMPCOutputThread::GetReadyCount(void) -{ - return m_ReadyList.Count(); -} - -unsigned int CMPCOutputThread::GetFreeCount(void) -{ - return m_FreeList.Count(); -} - -CPictureBuffer* CMPCOutputThread::ReadyListPop(void) -{ - CPictureBuffer *pBuffer = m_ReadyList.Pop(); - return pBuffer; -} - -void CMPCOutputThread::FreeListPush(CPictureBuffer* pBuffer) -{ - m_FreeList.Push(pBuffer); -} - -bool CMPCOutputThread::WaitOutput(unsigned int msec) -{ - return m_ready_event.WaitMSec(msec); -} - -void CMPCOutputThread::DoFrameRateTracking(double timestamp) -{ - if (timestamp != DVD_NOPTS_VALUE) - { - double duration; - // if timestamp does not start at a low value we - // came in the middle of an online live stream - // 250 ms is a fourth of a 25fps source - // if timestamp is larger than that at the beginning - // we are much more out of sync than with the rough - // calculation. To cover these 250 ms we need - // roughly 5 seconds of video stream to get back - // in sync - if (m_framerate_cnt == 0 && timestamp > 250000.0) - m_is_live_stream = true; - - duration = timestamp - m_framerate_timestamp; - if (duration > 0.0) - { - double framerate; - // cnt count has to be done here, cause we miss frames - // if framerate will not calculated correctly and - // duration has to be > 0.0 so we do not calc images twice - m_framerate_cnt++; - - m_framerate_timestamp += duration; - framerate = DVD_TIME_BASE / duration; - // qualify framerate, we don't care about absolute value, just - // want to to verify range. Timestamp could be borked so ignore - // anything that does not verify. - // 60, 59.94 -> 60 - // 50, 49.95 -> 50 - // 30, 29.97 -> 30 - // 25, 24.975 -> 25 - // 24, 23.976 -> 24 - switch ((int)(0.5 + framerate)) - { - case 60: - case 50: - case 30: - case 25: - case 24: - // if we have such a live stream framerate is more exact than calculating - // cause of m_framerate_cnt and timestamp do not match in any way - m_framerate = m_is_live_stream ? framerate : DVD_TIME_BASE / (m_framerate_timestamp/m_framerate_cnt); - break; - } - } - } -} - -void CMPCOutputThread::SetFrameRate(uint32_t resolution) -{ - m_interlace = FALSE; - - switch (resolution) - { - case BCM::vdecRESOLUTION_1080p30: - m_framerate = 30.0; - break; - case BCM::vdecRESOLUTION_1080p29_97: - m_framerate = 30.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_1080p25 : - m_framerate = 25.0; - break; - case BCM::vdecRESOLUTION_1080p24: - m_framerate = 24.0; - break; - case BCM::vdecRESOLUTION_1080p23_976: - m_framerate = 24.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_1080p0: - // 1080p0 is ambiguious, could be 23.976 or 29.97 fps, decoder - // just does not know. 1080p@23_976 is more common but this - // will mess up 1080p@29_97 playback. We really need to verify - // which framerate with duration tracking. - m_framerate_tracking = true; - m_framerate = 24.0 * 1000.0 / 1001.0; - break; - - case BCM::vdecRESOLUTION_1080i29_97: - m_framerate = 30.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - case BCM::vdecRESOLUTION_1080i0: - m_framerate = 30.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - case BCM::vdecRESOLUTION_1080i: - m_framerate = 30.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - case BCM::vdecRESOLUTION_1080i25: - m_framerate = 25.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - - case BCM::vdecRESOLUTION_720p59_94: - m_framerate = 60.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_720p: - m_framerate = 60.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_720p50: - m_framerate = 50.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_720p29_97: - m_framerate = 30.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_720p24: - m_framerate = 24.0; - break; - case BCM::vdecRESOLUTION_720p23_976: - // some 720p/25 will be identifed as this, enable tracking. - m_framerate_tracking = true; - m_framerate = 24.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_720p0: - // 720p0 is ambiguious, could be 23.976, 29.97 or 59.97 fps, decoder - // just does not know. 720p@23_976 is more common but this - // will mess up other playback. We really need to verify - // which framerate with duration tracking. - m_framerate_tracking = true; - m_framerate = 24.0 * 1000.0 / 1001.0; - break; - - case BCM::vdecRESOLUTION_576p25: - m_framerate = 25.0; - break; - case BCM::vdecRESOLUTION_576p0: - m_framerate = 25.0; - break; - case BCM::vdecRESOLUTION_PAL1: - m_framerate = 25.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - - case BCM::vdecRESOLUTION_480p0: - m_framerate = 60.0; - break; - case BCM::vdecRESOLUTION_480p: - m_framerate = 60.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_480p29_97: - m_framerate = 30.0 * 1000.0 / 1001.0; - break; - case BCM::vdecRESOLUTION_480p23_976: - m_framerate = 24.0 * 1000.0 / 1001.0; - break; - - case BCM::vdecRESOLUTION_480i0: - m_framerate = 30.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - case BCM::vdecRESOLUTION_480i: - m_framerate = 30.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - case BCM::vdecRESOLUTION_NTSC: - m_framerate = 30.0 * 1000.0 / 1001.0; - m_interlace = TRUE; - break; - - default: - m_framerate_tracking = true; - m_framerate = 24.0 * 1000.0 / 1001.0; - break; - } - - CLog::Log(LOGDEBUG, "%s: resolution = %x interlace = %d", __MODULE_NAME__, resolution, m_interlace); -} - -void CMPCOutputThread::SetAspectRatio(BCM::BC_PIC_INFO_BLOCK *pic_info) -{ - switch(pic_info->aspect_ratio) - { - case BCM::vdecAspectRatioSquare: - m_aspectratio_x = 1; - m_aspectratio_y = 1; - break; - case BCM::vdecAspectRatio12_11: - m_aspectratio_x = 12; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio10_11: - m_aspectratio_x = 10; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio16_11: - m_aspectratio_x = 16; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio40_33: - m_aspectratio_x = 40; - m_aspectratio_y = 33; - break; - case BCM::vdecAspectRatio24_11: - m_aspectratio_x = 24; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio20_11: - m_aspectratio_x = 20; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio32_11: - m_aspectratio_x = 32; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio80_33: - m_aspectratio_x = 80; - m_aspectratio_y = 33; - break; - case BCM::vdecAspectRatio18_11: - m_aspectratio_x = 18; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio15_11: - m_aspectratio_x = 15; - m_aspectratio_y = 11; - break; - case BCM::vdecAspectRatio64_33: - m_aspectratio_x = 64; - m_aspectratio_y = 33; - break; - case BCM::vdecAspectRatio160_99: - m_aspectratio_x = 160; - m_aspectratio_y = 99; - break; - case BCM::vdecAspectRatio4_3: - m_aspectratio_x = 4; - m_aspectratio_y = 3; - break; - case BCM::vdecAspectRatio16_9: - m_aspectratio_x = 16; - m_aspectratio_y = 9; - break; - case BCM::vdecAspectRatio221_1: - m_aspectratio_x = 221; - m_aspectratio_y = 1; - break; - case BCM::vdecAspectRatioUnknown: - m_aspectratio_x = 0; - m_aspectratio_y = 0; - break; - - case BCM::vdecAspectRatioOther: - m_aspectratio_x = pic_info->custom_aspect_ratio_width_height & 0x0000ffff; - m_aspectratio_y = pic_info->custom_aspect_ratio_width_height >> 16; - break; - } - if(m_aspectratio_x == 0) - { - m_aspectratio_x = 1; - m_aspectratio_y = 1; - } - - CLog::Log(LOGDEBUG, "%s: dec_par x = %d, dec_par y = %d", __MODULE_NAME__, m_aspectratio_x, m_aspectratio_y); -} - -void CMPCOutputThread::CopyOutAsYV12(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride) -{ - // copy y - if (w == stride) - { - fast_memcpy(pBuffer->m_y_buffer_ptr, procOut->Ybuff, w * h); - } - else - { - uint8_t *s_y = procOut->Ybuff; - uint8_t *d_y = pBuffer->m_y_buffer_ptr; - for (int y = 0; y < h; y++, s_y += stride, d_y += w) - fast_memcpy(d_y, s_y, w); - } - //copy chroma - //copy uv packed to u,v planes (1/2 the width and 1/2 the height of y) - uint8_t *d_u = pBuffer->m_u_buffer_ptr; - uint8_t *d_v = pBuffer->m_v_buffer_ptr; - for (int y = 0; y < h/2; y++) - { - uint8_t *s_uv = procOut->UVbuff + (y * stride); - for (int x = 0; x < w/2; x++) - { - *d_u++ = *s_uv++; - *d_v++ = *s_uv++; - } - } -} - -void CMPCOutputThread::CopyOutAsYV12DeInterlace(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride) -{ - // copy luma - uint8_t *s_y = procOut->Ybuff; - uint8_t *d_y = pBuffer->m_y_buffer_ptr; - for (int y = 0; y < h/2; y++, s_y += stride) - { - fast_memcpy(d_y, s_y, w); - d_y += w; - fast_memcpy(d_y, s_y, w); - d_y += w; - } - //copy chroma - //copy uv packed to u,v planes (1/2 the width and 1/2 the height of y) - uint8_t *d_u = pBuffer->m_u_buffer_ptr; - uint8_t *d_v = pBuffer->m_v_buffer_ptr; - for (int y = 0; y < h/4; y++) - { - uint8_t *s_uv = procOut->UVbuff + (y * stride); - for (int x = 0; x < w/2; x++) - { - *d_u++ = *s_uv++; - *d_v++ = *s_uv++; - } - s_uv = procOut->UVbuff + (y * stride); - for (int x = 0; x < w/2; x++) - { - *d_u++ = *s_uv++; - *d_v++ = *s_uv++; - } - } - - pBuffer->m_interlace = false; -} - -void CMPCOutputThread::CopyOutAsNV12(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride) -{ - if (w == stride) - { - int bytes = w * h; - // copy y - fast_memcpy(pBuffer->m_y_buffer_ptr, procOut->Ybuff, bytes); - // copy uv - fast_memcpy(pBuffer->m_uv_buffer_ptr, procOut->UVbuff, bytes/2 ); - } - else - { - // copy y - uint8_t *s = procOut->Ybuff; - uint8_t *d = pBuffer->m_y_buffer_ptr; - for (int y = 0; y < h; y++, s += stride, d += w) - fast_memcpy(d, s, w); - // copy uv - s = procOut->UVbuff; - d = pBuffer->m_uv_buffer_ptr; - for (int y = 0; y < h/2; y++, s += stride, d += w) - fast_memcpy(d, s, w); - } -} - -void CMPCOutputThread::CopyOutAsNV12DeInterlace(CPictureBuffer *pBuffer, BCM::BC_DTS_PROC_OUT *procOut, int w, int h, int stride) -{ - // do simple line doubling de-interlacing. - // copy luma - uint8_t *s_y = procOut->Ybuff; - uint8_t *d_y = pBuffer->m_y_buffer_ptr; - for (int y = 0; y < h/2; y++, s_y += stride) - { - fast_memcpy(d_y, s_y, w); - d_y += w; - fast_memcpy(d_y, s_y, w); - d_y += w; - } - //copy chroma - uint8_t *s_uv = procOut->UVbuff; - uint8_t *d_uv = pBuffer->m_uv_buffer_ptr; - for (int y = 0; y < h/4; y++, s_uv += stride) { - fast_memcpy(d_uv, s_uv, w); - d_uv += w; - fast_memcpy(d_uv, s_uv, w); - d_uv += w; - } - pBuffer->m_interlace = false; -} - -void CMPCOutputThread::CheckUpperLeftGreenPixelHack(CPictureBuffer *pBuffer) -{ - // crystalhd driver sends internal info in 1st pixel location, then restores - // original pixel value but sometimes, the info is broked and the - // driver cannot do the restore and zeros the pixel. This is wrong for - // yuv color space, uv values should be set to 128 otherwise we get a - // bright green pixel in upper left. - // We fix this by replicating the 2nd pixel to the 1st. - switch(pBuffer->m_format) - { - default: - case RENDER_FMT_YUV420P: - { - uint8_t *d_y = pBuffer->m_y_buffer_ptr; - uint8_t *d_u = pBuffer->m_u_buffer_ptr; - uint8_t *d_v = pBuffer->m_v_buffer_ptr; - d_y[0] = d_y[1]; - d_u[0] = d_u[1]; - d_v[0] = d_v[1]; - } - break; - - case RENDER_FMT_NV12: - { - uint8_t *d_y = pBuffer->m_y_buffer_ptr; - uint16_t *d_uv = (uint16_t*)pBuffer->m_uv_buffer_ptr; - d_y[0] = d_y[1]; - d_uv[0] = d_uv[1]; - } - break; - - case RENDER_FMT_YUYV422: - { - uint32_t *d_yuyv = (uint32_t*)pBuffer->m_y_buffer_ptr; - d_yuyv[0] = d_yuyv[1]; - } - break; - } -} - -bool CMPCOutputThread::GetDecoderOutput(void) -{ - BCM::BC_STATUS ret; - BCM::BC_DTS_PROC_OUT procOut; - CPictureBuffer *pBuffer = NULL; - bool got_picture = false; - - // Setup output struct - memset(&procOut, 0, sizeof(BCM::BC_DTS_PROC_OUT)); - - // Fetch data from the decoder - ret = m_dll->DtsProcOutputNoCopy(m_device, m_timeout, &procOut); - - switch (ret) - { - case BCM::BC_STS_SUCCESS: - if (m_format_valid && (procOut.PoutFlags & BCM::BC_POUT_FLAGS_PIB_VALID)) - { - if (procOut.PicInfo.timeStamp && - m_timestamp != procOut.PicInfo.timeStamp && - m_width == (int)procOut.PicInfo.width && - m_height == (int)procOut.PicInfo.height) - { - m_timestamp = procOut.PicInfo.timeStamp; - m_PictureNumber = procOut.PicInfo.picture_number; - - if (m_framerate_tracking) - DoFrameRateTracking((double)m_timestamp / 1000.0); - - // do not let FreeList to get greater than 10 - if (m_FreeList.Count() > 10) - delete m_FreeList.Pop(); - - // Get next output buffer from the free list - pBuffer = m_FreeList.Pop(); - if (!pBuffer) - { - // No free pre-allocated buffers so make one - if (m_output_YV12) - { - // output YV12, nouveau driver has slow NV12, YUY2 capability. - pBuffer = new CPictureBuffer(RENDER_FMT_YUV420P, m_width, m_height); - } - else - { - if (m_color_space == BCM::MODE422_YUY2) - pBuffer = new CPictureBuffer(RENDER_FMT_YUYV422, m_width, m_height); - else - pBuffer = new CPictureBuffer(RENDER_FMT_NV12, m_width, m_height); - } - - CLog::Log(LOGDEBUG, "%s: Added a new Buffer, ReadyListCount: %d", __MODULE_NAME__, m_ReadyList.Count()); - while (!m_bStop && m_ReadyList.Count() > 10) - Sleep(1); - } - - pBuffer->m_width = m_width; - pBuffer->m_height = m_height; - pBuffer->m_field = CRYSTALHD_FIELD_FULL; - pBuffer->m_interlace = m_interlace > 0 ? true : false; - pBuffer->m_framerate = m_framerate; - pBuffer->m_timestamp = m_timestamp; - pBuffer->m_color_space = m_color_space; - pBuffer->m_color_range = m_color_range; - pBuffer->m_color_matrix = m_color_matrix; - pBuffer->m_PictureNumber = m_PictureNumber; - - int w = m_width; - int h = m_height; - // frame that are not equal in width to 720, 1280 or 1920 - // need to be copied by a quantized stride (possible lib/driver bug) so force it. - int stride = m_width; - if (!m_has_bcm70015) - { - // bcm70012 uses quantized strides - if (w <= 720) - stride = 720; - else if (w <= 1280) - stride = 1280; - else - stride = 1920; - } - - if (pBuffer->m_color_space == BCM::MODE420) - { - switch(pBuffer->m_format) - { - case RENDER_FMT_NV12: - if (pBuffer->m_interlace) - CopyOutAsNV12DeInterlace(pBuffer, &procOut, w, h, stride); - else - CopyOutAsNV12(pBuffer, &procOut, w, h, stride); - break; - case RENDER_FMT_YUV420P: - if (pBuffer->m_interlace) - CopyOutAsYV12DeInterlace(pBuffer, &procOut, w, h, stride); - else - CopyOutAsYV12(pBuffer, &procOut, w, h, stride); - break; - default: - break; - } - } - else - { - switch(pBuffer->m_format) - { - case RENDER_FMT_YUYV422: - if (pBuffer->m_interlace) - { - // do simple line doubling de-interlacing. - // copy luma - int yuy2_w = w * 2; - int yuy2_stride = stride*2; - uint8_t *s_y = procOut.Ybuff; - uint8_t *d_y = pBuffer->m_y_buffer_ptr; - for (int y = 0; y < h/2; y++, s_y += yuy2_stride) - { - fast_memcpy(d_y, s_y, yuy2_w); - d_y += yuy2_w; - fast_memcpy(d_y, s_y, yuy2_w); - d_y += yuy2_w; - } - pBuffer->m_interlace = false; - } - else - { - fast_memcpy(pBuffer->m_y_buffer_ptr, procOut.Ybuff, pBuffer->m_y_buffer_size); - } - break; - case RENDER_FMT_YUV420P: - // TODO: deinterlace for yuy2 -> yv12, icky - { - // Perform the color space conversion. - uint8_t* src[] = { procOut.Ybuff, NULL, NULL, NULL }; - int srcStride[] = { stride*2, 0, 0, 0 }; - uint8_t* dst[] = { pBuffer->m_y_buffer_ptr, pBuffer->m_u_buffer_ptr, pBuffer->m_v_buffer_ptr, NULL }; - int dstStride[] = { pBuffer->m_width, pBuffer->m_width/2, pBuffer->m_width/2, 0 }; - - m_sw_scale_ctx = sws_getCachedContext(m_sw_scale_ctx, - pBuffer->m_width, pBuffer->m_height, PIX_FMT_YUYV422, - pBuffer->m_width, pBuffer->m_height, PIX_FMT_YUV420P, - SWS_FAST_BILINEAR | SwScaleCPUFlags(), NULL, NULL, NULL); - sws_scale(m_sw_scale_ctx, src, srcStride, 0, pBuffer->m_height, dst, dstStride); - } - break; - default: - break; - } - } - - CheckUpperLeftGreenPixelHack(pBuffer); - m_ReadyList.Push(pBuffer); - m_ready_event.Set(); - got_picture = true; - } - else - { - if (m_PictureNumber != procOut.PicInfo.picture_number) - CLog::Log(LOGDEBUG, "%s: No timestamp detected: %" PRIu64, __MODULE_NAME__, procOut.PicInfo.timeStamp); - m_PictureNumber = procOut.PicInfo.picture_number; - } - } - - m_dll->DtsReleaseOutputBuffs(m_device, NULL, FALSE); - break; - - case BCM::BC_STS_FMT_CHANGE: - CLog::Log(LOGDEBUG, "%s: Format Change Detected. Flags: 0x%08x", __MODULE_NAME__, procOut.PoutFlags); - if ((procOut.PoutFlags & BCM::BC_POUT_FLAGS_PIB_VALID) && (procOut.PoutFlags & BCM::BC_POUT_FLAGS_FMT_CHANGE)) - { - PrintFormat(procOut.PicInfo); - - if (procOut.PicInfo.height == 1088) { - procOut.PicInfo.height = 1080; - } - m_width = procOut.PicInfo.width; - m_height = procOut.PicInfo.height; - m_timestamp = DVD_NOPTS_VALUE; - m_color_space = procOut.b422Mode; - m_color_range = 0; - m_color_matrix = procOut.PicInfo.colour_primaries; - SetAspectRatio(&procOut.PicInfo); - SetFrameRate(procOut.PicInfo.frame_rate); - if (procOut.PicInfo.flags & VDEC_FLAG_INTERLACED_SRC) - { - m_interlace = true; - } - m_timeout = 2000; - m_format_valid = true; - m_ready_event.Set(); - } - break; - - case BCM::BC_STS_DEC_NOT_OPEN: - break; - - case BCM::BC_STS_DEC_NOT_STARTED: - break; - - case BCM::BC_STS_IO_USER_ABORT: - break; - - case BCM::BC_STS_NO_DATA: - break; - - case BCM::BC_STS_TIMEOUT: - break; - - default: - if (ret > 26) - CLog::Log(LOGDEBUG, "%s: DtsProcOutput returned %d.", __MODULE_NAME__, ret); - else - CLog::Log(LOGDEBUG, "%s: DtsProcOutput returned %s.", __MODULE_NAME__, g_DtsStatusText[ret]); - break; - } - - return got_picture; -} - -void CMPCOutputThread::Process(void) -{ - BCM::BC_STATUS ret; - BCM::BC_DTS_STATUS decoder_status; - - m_PictureNumber = 0; - - CLog::Log(LOGDEBUG, "%s: Output Thread Started...", __MODULE_NAME__); - - // wait for decoder startup, calls into DtsProcOutputXXCopy will - // return immediately until decoder starts getting input packets. - while (!m_bStop) - { - memset(&decoder_status, 0, sizeof(decoder_status)); - ret = m_dll->DtsGetDriverStatus(m_device, &decoder_status); - if (ret == BCM::BC_STS_SUCCESS && decoder_status.ReadyListCount) - { - GetDecoderOutput(); - break; - } - Sleep(10); - } - - // decoder is primed so now calls in DtsProcOutputXXCopy will block - while (!m_bStop) - { - memset(&decoder_status, 0, sizeof(decoder_status)); - ret = m_dll->DtsGetDriverStatus(m_device, &decoder_status); - if (ret == BCM::BC_STS_SUCCESS && decoder_status.ReadyListCount != 0) - GetDecoderOutput(); - else - Sleep(1); - -#ifdef USE_CHD_SINGLE_THREADED_API - while (!m_bStop) - { - ret = m_dll->DtsGetDriverStatus(m_device, &decoder_status); - if (ret == BCM::BC_STS_SUCCESS && decoder_status.ReadyListCount != 0) - { - double pts = (double)decoder_status.NextTimeStamp / 1000.0; - fprintf(stdout, "cpbEmptySize(%d), NextTimeStamp(%f)\n", decoder_status.cpbEmptySize, pts); - break; - } - Sleep(10); - } -#endif - } - CLog::Log(LOGDEBUG, "%s: Output Thread Stopped...", __MODULE_NAME__); -} - -//////////////////////////////////////////////////////////////////////////////////////////// -#if defined(TARGET_DARWIN) -#pragma mark - -#endif -CCrystalHD* CCrystalHD::m_pInstance = NULL; - -CCrystalHD::CCrystalHD() : - m_device(NULL), - m_device_preset(false), - m_new_lib(false), - m_decoder_open(false), - m_has_bcm70015(false), - m_color_space(BCM::MODE420), - m_drop_state(false), - m_skip_state(false), - m_timeout(0), - m_wait_timeout(0), - m_field(0), - m_width(0), - m_height(0), - m_reset(0), - m_last_pict_num(0), - m_last_demuxer_pts(0.0), - m_last_decoder_pts(0.0), - m_pOutputThread(NULL), - m_sps_pps_size(0), - m_convert_bitstream(false) -{ -#if (HAVE_LIBCRYSTALHD == 2) - memset(&m_bc_info_crystal, 0, sizeof(m_bc_info_crystal)); -#endif - - memset(&m_chd_params, 0, sizeof(m_chd_params)); - memset(&m_sps_pps_context, 0, sizeof(m_sps_pps_context)); - - m_dll = new DllLibCrystalHD; -#ifdef TARGET_WINDOWS - std::string strDll; - if(CWIN32Util::GetCrystalHDLibraryPath(strDll) && m_dll->SetFile(strDll) && m_dll->Load() && m_dll->IsLoaded() ) -#else - if (m_dll->Load() && m_dll->IsLoaded() ) -#endif - { -#if (HAVE_LIBCRYSTALHD == 2) - m_new_lib = m_dll->LoadNewLibFunctions(); -#endif - - OpenDevice(); - -#if (HAVE_LIBCRYSTALHD == 2) - if (m_device && m_new_lib) - { - m_dll->DtsCrystalHDVersion(m_device, (BCM::PBC_INFO_CRYSTAL)&m_bc_info_crystal); - m_has_bcm70015 = (m_bc_info_crystal.device == 1); - // bcm70012 can do nv12 (420), yuy2 (422) and uyvy (422) - // bcm70015 can do only yuy2 (422) - if (m_has_bcm70015) - m_color_space = BCM::OUTPUT_MODE422_YUY2; - } -#endif - } - - // delete dll if device open fails, minimizes ram footprint - if (!m_device) - { - delete m_dll; - m_dll = NULL; - CLog::Log(LOGDEBUG, "%s: broadcom crystal hd not found", __MODULE_NAME__); - } - else - { - // we know there's a device present now, close the device until doing playback - CloseDevice(); - } -} - - -CCrystalHD::~CCrystalHD() -{ - if (m_decoder_open) - CloseDecoder(); - - if (m_device) - CloseDevice(); - - if (m_dll) - delete m_dll; -} - - -bool CCrystalHD::DevicePresent(void) -{ - return m_device_preset; -} - -void CCrystalHD::RemoveInstance(void) -{ - if (m_pInstance) - { - delete m_pInstance; - m_pInstance = NULL; - } -} - -CCrystalHD* CCrystalHD::GetInstance(void) -{ - if (!m_pInstance) - { - m_pInstance = new CCrystalHD(); - } - return m_pInstance; -} - -void CCrystalHD::OpenDevice() -{ - uint32_t mode = BCM::DTS_PLAYBACK_MODE | - BCM::DTS_LOAD_FILE_PLAY_FW | -#ifdef USE_CHD_SINGLE_THREADED_API - BCM::DTS_SINGLE_THREADED_MODE | -#endif - BCM::DTS_SKIP_TX_CHK_CPB | - BCM::DTS_PLAYBACK_DROP_RPT_MODE | - DTS_DFLT_RESOLUTION(BCM::vdecRESOLUTION_720p23_976); - - BCM::BC_STATUS res= m_dll->DtsDeviceOpen(&m_device, mode); - if (res != BCM::BC_STS_SUCCESS) - { - m_device = NULL; - if( res == BCM::BC_STS_DEC_EXIST_OPEN ) - CLog::Log(LOGDEBUG, "%s: device owned by another application", __MODULE_NAME__); - else - CLog::Log(LOGDEBUG, "%s: device open failed , returning(0x%x)", __MODULE_NAME__, res); - m_device_preset = false; - } - else - { - #if (HAVE_LIBCRYSTALHD == 2) - if (m_new_lib) - CLog::Log(LOGDEBUG, "%s(new API): device opened", __MODULE_NAME__); - else - CLog::Log(LOGDEBUG, "%s(old API): device opened", __MODULE_NAME__); - #else - CLog::Log(LOGDEBUG, "%s: device opened", __MODULE_NAME__); - #endif - m_device_preset = true; - } -} - -void CCrystalHD::CloseDevice() -{ - if (m_device) - { - m_dll->DtsDeviceClose(m_device); - m_device = NULL; - CLog::Log(LOGDEBUG, "%s: device closed", __MODULE_NAME__); - } -} - -bool CCrystalHD::OpenDecoder(CRYSTALHD_CODEC_TYPE codec_type, CDVDStreamInfo &hints) -{ - BCM::BC_STATUS res; - uint32_t StreamType; -#if (HAVE_LIBCRYSTALHD == 2) - BCM::BC_MEDIA_SUBTYPE Subtype; -#endif - - if (!m_device_preset) - return false; - - if (m_decoder_open) - CloseDecoder(); - - OpenDevice(); - if (!m_device) - return false; - -#if (HAVE_LIBCRYSTALHD == 2) && defined(TARGET_WINDOWS) - // Drivers prior to 3.6.9.32 don't have proper support for CRYSTALHD_CODEC_ID_AVC1 - // The internal version numbers are different for some reason... - if ( (m_bc_info_crystal.dilVersion.dilRelease < 3) - || (m_bc_info_crystal.dilVersion.dilRelease == 3 && m_bc_info_crystal.dilVersion.dilMajor < 22) - || (m_bc_info_crystal.drvVersion.drvRelease < 3) - || (m_bc_info_crystal.drvVersion.drvRelease == 3 && m_bc_info_crystal.drvVersion.drvMajor < 7) ) - { - CGUIDialogKaiToast::QueueNotification(CGUIDialogKaiToast::Warning, "CrystalHD", g_localizeStrings.Get(2101)); - CLog::Log(LOGWARNING, "CrystalHD drivers too old, please upgrade to 3.6.9 or later. Make sure to uninstall the old version first or the upgrade won't work."); - - if (codec_type == CRYSTALHD_CODEC_ID_AVC1) - return false; - } -#endif - - uint32_t videoAlg = 0; - switch (codec_type) - { - case CRYSTALHD_CODEC_ID_VC1: - videoAlg = BCM::BC_VID_ALGO_VC1; - StreamType = BCM::BC_STREAM_TYPE_ES; - m_convert_bitstream = false; - break; - case CRYSTALHD_CODEC_ID_WVC1: - videoAlg = BCM::BC_VID_ALGO_VC1MP; - StreamType = BCM::BC_STREAM_TYPE_ES; - m_convert_bitstream = false; - break; - case CRYSTALHD_CODEC_ID_WMV3: - if (!m_has_bcm70015) - return false; - videoAlg = BCM::BC_VID_ALGO_VC1MP; - StreamType = BCM::BC_STREAM_TYPE_ES; - m_convert_bitstream = false; - break; - case CRYSTALHD_CODEC_ID_H264: - videoAlg = BCM::BC_VID_ALGO_H264; - StreamType = BCM::BC_STREAM_TYPE_ES; - m_convert_bitstream = false; - break; - case CRYSTALHD_CODEC_ID_AVC1: - videoAlg = BCM::BC_VID_ALGO_H264; - StreamType = BCM::BC_STREAM_TYPE_ES; - if (!m_new_lib) - m_convert_bitstream = bitstream_convert_init((uint8_t*)hints.extradata, hints.extrasize); - else - m_convert_bitstream = false; - break; - case CRYSTALHD_CODEC_ID_MPEG2: - videoAlg = BCM::BC_VID_ALGO_MPEG2; - StreamType = BCM::BC_STREAM_TYPE_ES; - m_convert_bitstream = false; - break; - //BC_VID_ALGO_DIVX: - //BC_VID_ALGO_VC1MP: - default: - return false; - break; - } - -#if (HAVE_LIBCRYSTALHD == 2) - uint8_t *pMetaData = NULL; - uint32_t metaDataSz = 0; - uint32_t startCodeSz = 4; - m_chd_params.sps_pps_buf = NULL; - switch (codec_type) - { - case CRYSTALHD_CODEC_ID_VC1: - Subtype = BCM::BC_MSUBTYPE_VC1; - pMetaData = (uint8_t*)hints.extradata; - metaDataSz = hints.extrasize; - break; - case CRYSTALHD_CODEC_ID_WVC1: - Subtype = BCM::BC_MSUBTYPE_WVC1; - break; - case CRYSTALHD_CODEC_ID_WMV3: - Subtype = BCM::BC_MSUBTYPE_WMV3; - pMetaData = (uint8_t*)hints.extradata; - metaDataSz = hints.extrasize; - break; - case CRYSTALHD_CODEC_ID_H264: - Subtype = BCM::BC_MSUBTYPE_H264; - pMetaData = (uint8_t*)hints.extradata; - metaDataSz = hints.extrasize; - break; - case CRYSTALHD_CODEC_ID_AVC1: - Subtype = BCM::BC_MSUBTYPE_AVC1; - m_chd_params.sps_pps_buf = (uint8_t*)malloc(1000); - if (!extract_sps_pps_from_avcc(hints.extrasize, hints.extradata)) - { - free(m_chd_params.sps_pps_buf); - m_chd_params.sps_pps_buf = NULL; - } - else - { - pMetaData = m_chd_params.sps_pps_buf; - metaDataSz = m_chd_params.sps_pps_size; - startCodeSz = m_chd_params.nal_size_bytes; - } - break; - case CRYSTALHD_CODEC_ID_MPEG2: - Subtype = BCM::BC_MSUBTYPE_MPEG2VIDEO; - pMetaData = (uint8_t*)hints.extradata; - metaDataSz = hints.extrasize; - break; - //BC_VID_ALGO_DIVX: - //BC_VID_ALGO_VC1MP: - } -#endif - - do - { -#if (HAVE_LIBCRYSTALHD == 2) - if (m_new_lib) - { - BCM::BC_INPUT_FORMAT bcm_input_format; - memset(&bcm_input_format, 0, sizeof(BCM::BC_INPUT_FORMAT)); - - bcm_input_format.FGTEnable = FALSE; - bcm_input_format.Progressive = TRUE; - bcm_input_format.OptFlags = 0x80000000 | BCM::vdecFrameRate23_97; - #ifdef USE_CHD_SINGLE_THREADED_API - bcm_input_format.OptFlags |= 0x80; - #endif - - bcm_input_format.width = hints.width; - bcm_input_format.height = hints.height; - bcm_input_format.mSubtype = Subtype; - bcm_input_format.pMetaData = pMetaData; - bcm_input_format.metaDataSz = metaDataSz; - bcm_input_format.startCodeSz = startCodeSz; - - res = m_dll->DtsSetInputFormat(m_device, &bcm_input_format); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: set input format failed", __MODULE_NAME__); - break; - } - - res = m_dll->DtsOpenDecoder(m_device, StreamType); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: open decoder failed", __MODULE_NAME__); - break; - } - - if (m_has_bcm70015) - res = m_dll->DtsSetColorSpace(m_device, BCM::OUTPUT_MODE422_YUY2); - else - res = m_dll->DtsSetColorSpace(m_device, BCM::OUTPUT_MODE420); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: set color space failed", __MODULE_NAME__); - break; - } - } - else -#endif - { - res = m_dll->DtsOpenDecoder(m_device, StreamType); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: open decoder failed", __MODULE_NAME__); - break; - } - - uint32_t OptFlags = 0x80000000 | BCM::vdecFrameRate23_97; - res = m_dll->DtsSetVideoParams(m_device, videoAlg, FALSE, FALSE, TRUE, OptFlags); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: set video params failed", __MODULE_NAME__); - break; - } - } - - res = m_dll->DtsStartDecoder(m_device); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: start decoder failed", __MODULE_NAME__); - break; - } - - res = m_dll->DtsStartCapture(m_device); - if (res != BCM::BC_STS_SUCCESS) - { - CLog::Log(LOGERROR, "%s: start capture failed", __MODULE_NAME__); - break; - } - - m_pOutputThread = new CMPCOutputThread(m_device, m_dll, m_has_bcm70015); - m_pOutputThread->Create(); - - m_drop_state = false; - m_skip_state = false; - m_decoder_open = true; - // set output timeout to 1ms during startup, - // this will get reset once we get a picture back. - // the effect is to speed feeding demux packets during startup. - m_wait_timeout = 1; - m_reset = 0; - m_last_pict_num = 0; - m_last_demuxer_pts = DVD_NOPTS_VALUE; - m_last_decoder_pts = DVD_NOPTS_VALUE; - } while(false); - - return m_decoder_open; -} - -void CCrystalHD::CloseDecoder(void) -{ - if (m_pOutputThread) - { - while(m_BusyList.Count()) - m_pOutputThread->FreeListPush( m_BusyList.Pop() ); - - m_pOutputThread->StopThread(); - delete m_pOutputThread; - m_pOutputThread = NULL; - } - - if (m_convert_bitstream) - { - if (m_sps_pps_context.sps_pps_data) - { - free(m_sps_pps_context.sps_pps_data); - m_sps_pps_context.sps_pps_data = NULL; - } - } -#if (HAVE_LIBCRYSTALHD == 2) - if (m_chd_params.sps_pps_buf) - { - free(m_chd_params.sps_pps_buf); - m_chd_params.sps_pps_buf = NULL; - } -#endif - - if (m_decoder_open) - { - // DtsFlushRxCapture must release internal queues when - // calling DtsStopDecoder/DtsCloseDecoder or the next - // DtsStartCapture will fail. This is a driver/lib bug - // with new chd driver. The existing driver ignores the - // bDiscardOnly arg. - if (!m_has_bcm70015) - m_dll->DtsFlushRxCapture(m_device, false); - m_dll->DtsStopDecoder(m_device); - m_dll->DtsCloseDecoder(m_device); - m_decoder_open = false; - } - - CloseDevice(); -} - -void CCrystalHD::Reset(void) -{ - if (!m_has_bcm70015) - { - // Calling for non-error flush, Flushes all the decoder - // buffers, input, decoded and to be decoded. - m_reset = 10; - m_wait_timeout = 1; - m_dll->DtsFlushInput(m_device, 2); - } - - while (m_BusyList.Count()) - m_pOutputThread->FreeListPush( m_BusyList.Pop() ); - - while (m_pOutputThread->GetReadyCount()) - { - ::Sleep(1); - m_pOutputThread->FreeListPush( m_pOutputThread->ReadyListPop() ); - } -} - -bool CCrystalHD::AddInput(unsigned char *pData, size_t size, double dts, double pts) -{ - if (pData) - { - BCM::BC_STATUS ret; - uint64_t int_pts = pts * 1000; - int demuxer_bytes = size; - uint8_t *demuxer_content = pData; - bool free_demuxer_content = false; - - if (m_convert_bitstream) - { - // convert demuxer packet from bitstream (AVC1) to bytestream (AnnexB) - int bytestream_size = 0; - uint8_t *bytestream_buff = NULL; - - bitstream_convert(demuxer_content, demuxer_bytes, &bytestream_buff, &bytestream_size); - if (bytestream_buff && (bytestream_size > 0)) - { - if (bytestream_buff != demuxer_content) - free_demuxer_content = true; - demuxer_bytes = bytestream_size; - demuxer_content = bytestream_buff; - } - } - - do - { - ret = m_dll->DtsProcInput(m_device, demuxer_content, demuxer_bytes, int_pts, 0); - if (ret == BCM::BC_STS_SUCCESS) - { - m_last_demuxer_pts = pts; - } - else if (ret == BCM::BC_STS_BUSY) - { - CLog::Log(LOGDEBUG, "%s: DtsProcInput returned BC_STS_BUSY", __MODULE_NAME__); - ::Sleep(1); // Buffer is full, sleep it empty - } - } while (ret != BCM::BC_STS_SUCCESS); - - if (free_demuxer_content) - free(demuxer_content); - - if (!m_has_bcm70015) - { - if (m_reset) - { - m_reset--; - if (!m_skip_state) - { - m_skip_state = true; - m_dll->DtsSetSkipPictureMode(m_device, 1); - } - } - else - { - if (m_skip_state) - { - m_skip_state = false; - m_dll->DtsSetSkipPictureMode(m_device, 0); - } - } - } - - if (m_pOutputThread->GetReadyCount() < 1) - m_pOutputThread->WaitOutput(m_wait_timeout); - } - - return true; -} - -int CCrystalHD::GetReadyCount(void) -{ - if (m_pOutputThread) - return m_pOutputThread->GetReadyCount(); - else - return 0; -} - -void CCrystalHD::BusyListFlush(void) -{ - if (m_pOutputThread) - { - while ( m_BusyList.Count()) - m_pOutputThread->FreeListPush( m_BusyList.Pop() ); - } -} - -bool CCrystalHD::GetPicture(DVDVideoPicture *pDvdVideoPicture) -{ - CPictureBuffer* pBuffer = m_pOutputThread->ReadyListPop(); - - if (!pBuffer) - return false; - - // default both dts/pts to DVD_NOPTS_VALUE, if crystalhd drops a frame, - // we can't tell so we can not track dts through the decoder or with - // and external queue. pts will get set from m_timestamp. - pDvdVideoPicture->dts = DVD_NOPTS_VALUE; - pDvdVideoPicture->pts = DVD_NOPTS_VALUE; - - if (pBuffer->m_timestamp != 0) - pDvdVideoPicture->pts = (double)pBuffer->m_timestamp / 1000.0; - - pDvdVideoPicture->iWidth = pBuffer->m_width; - pDvdVideoPicture->iHeight = pBuffer->m_height; - pDvdVideoPicture->iDisplayWidth = pBuffer->m_width; - pDvdVideoPicture->iDisplayHeight = pBuffer->m_height; - - switch(pBuffer->m_format) - { - default: - case RENDER_FMT_NV12: - // Y plane - pDvdVideoPicture->data[0] = (uint8_t*)pBuffer->m_y_buffer_ptr; - pDvdVideoPicture->iLineSize[0] = pBuffer->m_width; - // UV packed plane - pDvdVideoPicture->data[1] = (uint8_t*)pBuffer->m_uv_buffer_ptr; - pDvdVideoPicture->iLineSize[1] = pBuffer->m_width; - // unused - pDvdVideoPicture->data[2] = NULL; - pDvdVideoPicture->iLineSize[2] = 0; - break; - case RENDER_FMT_YUYV422: - // YUV packed plane - pDvdVideoPicture->data[0] = (uint8_t*)pBuffer->m_y_buffer_ptr; - pDvdVideoPicture->iLineSize[0] = pBuffer->m_width * 2; - // unused - pDvdVideoPicture->data[1] = NULL; - pDvdVideoPicture->iLineSize[1] = 0; - // unused - pDvdVideoPicture->data[2] = NULL; - pDvdVideoPicture->iLineSize[2] = 0; - break; - case RENDER_FMT_YUV420P: - // Y plane - pDvdVideoPicture->data[0] = (uint8_t*)pBuffer->m_y_buffer_ptr; - pDvdVideoPicture->iLineSize[0] = pBuffer->m_width; - // U plane - pDvdVideoPicture->data[1] = (uint8_t*)pBuffer->m_u_buffer_ptr; - pDvdVideoPicture->iLineSize[1] = pBuffer->m_width / 2; - // V plane - pDvdVideoPicture->data[2] = (uint8_t*)pBuffer->m_v_buffer_ptr; - pDvdVideoPicture->iLineSize[2] = pBuffer->m_width / 2; - break; - } - - pDvdVideoPicture->iRepeatPicture = 0; - pDvdVideoPicture->iDuration = DVD_TIME_BASE / pBuffer->m_framerate; - m_wait_timeout = pDvdVideoPicture->iDuration/2000; - pDvdVideoPicture->color_range = pBuffer->m_color_range; - pDvdVideoPicture->color_matrix = pBuffer->m_color_matrix; - pDvdVideoPicture->iFlags = DVP_FLAG_ALLOCATED; - pDvdVideoPicture->iFlags |= m_drop_state ? DVP_FLAG_DROPPED : 0; - pDvdVideoPicture->format = pBuffer->m_format; - - m_last_pict_num = pBuffer->m_PictureNumber; - m_last_decoder_pts = pDvdVideoPicture->pts; - - while( m_BusyList.Count()) - m_pOutputThread->FreeListPush( m_BusyList.Pop() ); - - m_BusyList.Push(pBuffer); - return true; -} - -void CCrystalHD::SetDropState(bool bDrop) -{ - if (m_drop_state != bDrop) - { - m_drop_state = bDrop; - - if (!m_has_bcm70015) - { - if (!m_reset) - { - if (m_drop_state) - { - if (!m_skip_state) - { - m_skip_state = true; - m_dll->DtsSetSkipPictureMode(m_device, 1); - Sleep(1); - } - } - else - { - if (m_skip_state) - { - m_skip_state = false; - m_dll->DtsSetSkipPictureMode(m_device, 0); - Sleep(1); - } - } - } - } - } - /* - CLog::Log(LOGDEBUG, "%s: m_drop_state(%d), GetFreeCount(%d), GetReadyCount(%d)", __MODULE_NAME__, - m_drop_state, m_pOutputThread->GetFreeCount(), m_pOutputThread->GetReadyCount()); - */ -} -//////////////////////////////////////////////////////////////////////////////////////////// -bool CCrystalHD::extract_sps_pps_from_avcc(int extradata_size, void *extradata) -{ - // based on gstbcmdec.c (bcmdec_insert_sps_pps) - // which is Copyright(c) 2008 Broadcom Corporation. - // and Licensed LGPL 2.1 - - uint8_t *data = (uint8_t*)extradata; - uint32_t data_size = extradata_size; - int profile; - unsigned int nal_size; - unsigned int num_sps, num_pps; - - m_chd_params.sps_pps_size = 0; - - profile = (data[1] << 16) | (data[2] << 8) | data[3]; - CLog::Log(LOGDEBUG, "%s: profile %06x", __MODULE_NAME__, profile); - - m_chd_params.nal_size_bytes = (data[4] & 0x03) + 1; - - CLog::Log(LOGDEBUG, "%s: nal size %d", __MODULE_NAME__, m_chd_params.nal_size_bytes); - - num_sps = data[5] & 0x1f; - CLog::Log(LOGDEBUG, "%s: num sps %d", __MODULE_NAME__, num_sps); - - data += 6; - data_size -= 6; - - for (unsigned int i = 0; i < num_sps; i++) - { - if (data_size < 2) - return false; - - nal_size = (data[0] << 8) | data[1]; - data += 2; - data_size -= 2; - - if (data_size < nal_size) - return false; - - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size + 0] = 0; - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size + 1] = 0; - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size + 2] = 0; - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size + 3] = 1; - - m_chd_params.sps_pps_size += 4; - - memcpy(m_chd_params.sps_pps_buf + m_chd_params.sps_pps_size, data, nal_size); - m_chd_params.sps_pps_size += nal_size; - - data += nal_size; - data_size -= nal_size; - } - - if (data_size < 1) - return false; - - num_pps = data[0]; - data += 1; - data_size -= 1; - - for (unsigned int i = 0; i < num_pps; i++) - { - if (data_size < 2) - return false; - - nal_size = (data[0] << 8) | data[1]; - data += 2; - data_size -= 2; - - if (data_size < nal_size) - return false; - - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size+0] = 0; - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size+1] = 0; - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size+2] = 0; - m_chd_params.sps_pps_buf[m_chd_params.sps_pps_size+3] = 1; - - m_chd_params.sps_pps_size += 4; - - memcpy(m_chd_params.sps_pps_buf + m_chd_params.sps_pps_size, data, nal_size); - m_chd_params.sps_pps_size += nal_size; - - data += nal_size; - data_size -= nal_size; - } - - CLog::Log(LOGDEBUG, "%s: data size at end = %d ", __MODULE_NAME__, data_size); - - return true; -} - - -//////////////////////////////////////////////////////////////////////////////////////////// -bool CCrystalHD::bitstream_convert_init(void *in_extradata, int in_extrasize) -{ - // based on h264_mp4toannexb_bsf.c (ffmpeg) - // which is Copyright (c) 2007 Benoit Fouet <benoit.fouet@free.fr> - // and Licensed GPL 2.1 or greater - - m_sps_pps_size = 0; - m_sps_pps_context.sps_pps_data = NULL; - - // nothing to filter - if (!in_extradata || in_extrasize < 6) - return false; - - uint16_t unit_size; - uint32_t total_size = 0; - uint8_t *out = NULL, unit_nb, sps_done = 0; - const uint8_t *extradata = (uint8_t*)in_extradata + 4; - static const uint8_t nalu_header[4] = {0, 0, 0, 1}; - - // retrieve length coded size - m_sps_pps_context.length_size = (*extradata++ & 0x3) + 1; - if (m_sps_pps_context.length_size == 3) - return false; - - // retrieve sps and pps unit(s) - unit_nb = *extradata++ & 0x1f; // number of sps unit(s) - if (!unit_nb) - { - unit_nb = *extradata++; // number of pps unit(s) - sps_done++; - } - while (unit_nb--) - { - unit_size = extradata[0] << 8 | extradata[1]; - total_size += unit_size + 4; - if ( (extradata + 2 + unit_size) > ((uint8_t*)in_extradata + in_extrasize) ) - { - free(out); - return false; - } - uint8_t* new_out = (uint8_t*)realloc(out, total_size); - if (new_out) - { - out = new_out; - } - else - { - CLog::Log(LOGERROR, "bitstream_convert_init failed - %s : could not realloc the buffer out", __FUNCTION__); - free(out); - return false; - } - - memcpy(out + total_size - unit_size - 4, nalu_header, 4); - memcpy(out + total_size - unit_size, extradata + 2, unit_size); - extradata += 2 + unit_size; - - if (!unit_nb && !sps_done++) - unit_nb = *extradata++; // number of pps unit(s) - } - - m_sps_pps_context.sps_pps_data = out; - m_sps_pps_context.size = total_size; - m_sps_pps_context.first_idr = 1; - - return true; -} - -bool CCrystalHD::bitstream_convert(uint8_t* pData, int iSize, uint8_t **poutbuf, int *poutbuf_size) -{ - // based on h264_mp4toannexb_bsf.c (ffmpeg) - // which is Copyright (c) 2007 Benoit Fouet <benoit.fouet@free.fr> - // and Licensed GPL 2.1 or greater - - uint8_t *buf = pData; - uint32_t buf_size = iSize; - uint8_t unit_type; - int32_t nal_size; - uint32_t cumul_size = 0; - const uint8_t *buf_end = buf + buf_size; - - do - { - if (buf + m_sps_pps_context.length_size > buf_end) - goto fail; - - if (m_sps_pps_context.length_size == 1) - nal_size = buf[0]; - else if (m_sps_pps_context.length_size == 2) - nal_size = buf[0] << 8 | buf[1]; - else - nal_size = buf[0] << 24 | buf[1] << 16 | buf[2] << 8 | buf[3]; - - buf += m_sps_pps_context.length_size; - unit_type = *buf & 0x1f; - - if (buf + nal_size > buf_end || nal_size < 0) - goto fail; - - // prepend only to the first type 5 NAL unit of an IDR picture - if (m_sps_pps_context.first_idr && unit_type == 5) - { - bitstream_alloc_and_copy(poutbuf, poutbuf_size, - m_sps_pps_context.sps_pps_data, m_sps_pps_context.size, buf, nal_size); - m_sps_pps_context.first_idr = 0; - } - else - { - bitstream_alloc_and_copy(poutbuf, poutbuf_size, NULL, 0, buf, nal_size); - if (!m_sps_pps_context.first_idr && unit_type == 1) - m_sps_pps_context.first_idr = 1; - } - - buf += nal_size; - cumul_size += nal_size + m_sps_pps_context.length_size; - } while (cumul_size < buf_size); - - return true; - -fail: - free(*poutbuf); - *poutbuf = NULL; - *poutbuf_size = 0; - return false; -} - -void CCrystalHD::bitstream_alloc_and_copy( - uint8_t **poutbuf, int *poutbuf_size, - const uint8_t *sps_pps, uint32_t sps_pps_size, - const uint8_t *in, uint32_t in_size) -{ - // based on h264_mp4toannexb_bsf.c (ffmpeg) - // which is Copyright (c) 2007 Benoit Fouet <benoit.fouet@free.fr> - // and Licensed GPL 2.1 or greater - - #define CHD_WB32(p, d) { \ - ((uint8_t*)(p))[3] = (d); \ - ((uint8_t*)(p))[2] = (d) >> 8; \ - ((uint8_t*)(p))[1] = (d) >> 16; \ - ((uint8_t*)(p))[0] = (d) >> 24; } - - uint32_t offset = *poutbuf_size; - uint8_t nal_header_size = offset ? 3 : 4; - - *poutbuf_size += sps_pps_size + in_size + nal_header_size; - *poutbuf = (uint8_t*)realloc(*poutbuf, *poutbuf_size); - if (sps_pps) - memcpy(*poutbuf + offset, sps_pps, sps_pps_size); - - memcpy(*poutbuf + sps_pps_size + nal_header_size + offset, in, in_size); - if (!offset) - { - CHD_WB32(*poutbuf + sps_pps_size, 1); - } - else - { - (*poutbuf + offset + sps_pps_size)[0] = 0; - (*poutbuf + offset + sps_pps_size)[1] = 0; - (*poutbuf + offset + sps_pps_size)[2] = 1; - } -} - -//////////////////////////////////////////////////////////////////////////////////////////// -void PrintFormat(BCM::BC_PIC_INFO_BLOCK &pib) -{ - CLog::Log(LOGDEBUG, "----------------------------------\n%s",""); - CLog::Log(LOGDEBUG, "\tTimeStamp: %" PRIu64"\n", pib.timeStamp); - CLog::Log(LOGDEBUG, "\tPicture Number: %d\n", pib.picture_number); - CLog::Log(LOGDEBUG, "\tWidth: %d\n", pib.width); - CLog::Log(LOGDEBUG, "\tHeight: %d\n", pib.height); - CLog::Log(LOGDEBUG, "\tChroma: 0x%03x\n", pib.chroma_format); - CLog::Log(LOGDEBUG, "\tPulldown: %d\n", pib.pulldown); - CLog::Log(LOGDEBUG, "\tFlags: 0x%08x\n", pib.flags); - CLog::Log(LOGDEBUG, "\tFrame Rate/Res: %d\n", pib.frame_rate); - CLog::Log(LOGDEBUG, "\tAspect Ratio: %d\n", pib.aspect_ratio); - CLog::Log(LOGDEBUG, "\tColor Primaries: %d\n", pib.colour_primaries); - CLog::Log(LOGDEBUG, "\tMetaData: %d\n", pib.picture_meta_payload); - CLog::Log(LOGDEBUG, "\tSession Number: %d\n", pib.sess_num); - CLog::Log(LOGDEBUG, "\tTimeStamp: %d\n", pib.ycom); - CLog::Log(LOGDEBUG, "\tCustom Aspect: %d\n", pib.custom_aspect_ratio_width_height); - CLog::Log(LOGDEBUG, "\tFrames to Drop: %d\n", pib.n_drop); - CLog::Log(LOGDEBUG, "\tH264 Valid Fields: 0x%08x\n", pib.other.h264.valid); -} - -#endif diff --git a/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD.h b/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD.h deleted file mode 100644 index 451a107b22..0000000000 --- a/xbmc/cores/dvdplayer/DVDCodecs/Video/CrystalHD.h +++ /dev/null @@ -1,236 +0,0 @@ -#pragma once -/* - * Copyright (C) 2005-2013 Team XBMC - * http://xbmc.org - * - * This Program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This Program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with XBMC; see the file COPYING. If not, see - * <http://www.gnu.org/licenses/>. - * - */ - -#if defined(HAVE_LIBCRYSTALHD) - -#include <deque> - -#include "DVDVideoCodec.h" -#include "cores/dvdplayer/DVDStreamInfo.h" -#include "threads/SingleLock.h" - -//////////////////////////////////////////////////////////////////////////////////////////// -template <class T> -class CSyncPtrQueue -{ -public: - CSyncPtrQueue() { } - virtual ~CSyncPtrQueue() { } - void Push(T* p) - { - CSingleLock lock(m_Lock); - m_Queue.push_back(p); - } - - T* Pop() - { - T* p = NULL; - CSingleLock lock(m_Lock); - if (!m_Queue.empty()) - { - p = m_Queue.front(); - m_Queue.pop_front(); - } - return p; - } - unsigned int Count(){return m_Queue.size();} -protected: - std::deque<T*> m_Queue; - CCriticalSection m_Lock; -}; - -//////////////////////////////////////////////////////////////////////////////////////////// -class CPictureBuffer -{ -public: - CPictureBuffer(ERenderFormat format, int width, int height); - virtual ~CPictureBuffer(); - - unsigned int m_width; - unsigned int m_height; - unsigned int m_field; - bool m_interlace; - double m_framerate; - uint64_t m_timestamp; - int m_color_space; - unsigned int m_color_range; - unsigned int m_color_matrix; - uint64_t m_PictureNumber; - ERenderFormat m_format; - unsigned char *m_y_buffer_ptr; - unsigned char *m_u_buffer_ptr; - unsigned char *m_v_buffer_ptr; - unsigned char *m_uv_buffer_ptr; - int m_y_buffer_size; - int m_u_buffer_size; - int m_v_buffer_size; - int m_uv_buffer_size; -}; - - -//////////////////////////////////////////////////////////////////////////////////////////// -enum _CRYSTALHD_CODEC_TYPES -{ - CRYSTALHD_CODEC_ID_MPEG2 = 0, - CRYSTALHD_CODEC_ID_H264 = 1, - CRYSTALHD_CODEC_ID_AVC1 = 2, - CRYSTALHD_CODEC_ID_VC1 = 3, - CRYSTALHD_CODEC_ID_WMV3 = 4, - CRYSTALHD_CODEC_ID_WVC1 = 5, -}; - -typedef uint32_t CRYSTALHD_CODEC_TYPE; - -#if (HAVE_LIBCRYSTALHD == 2) - - typedef struct _BC_INFO_CRYSTAL_ { - uint8_t device; - union { - struct { - uint32_t dilRelease:8; - uint32_t dilMajor:8; - uint32_t dilMinor:16; - }; - uint32_t version; - } dilVersion; - - union { - struct { - uint32_t drvRelease:4; - uint32_t drvMajor:8; - uint32_t drvMinor:12; - uint32_t drvBuild:8; - }; - uint32_t version; - } drvVersion; - - union { - struct { - uint32_t fwRelease:4; - uint32_t fwMajor:8; - uint32_t fwMinor:12; - uint32_t fwBuild:8; - }; - uint32_t version; - } fwVersion; - - uint32_t Reserved1; // For future expansion - uint32_t Reserved2; // For future expansion - } BC_INFO_CRYSTAL, *PBC_INFO_CRYSTAL; - -#endif - -//////////////////////////////////////////////////////////////////////////////////////////// - -#define CRYSTALHD_FIELD_FULL 0x00 -#define CRYSTALHD_FIELD_BOT 0x01 -#define CRYSTALHD_FIELD_TOP 0x02 - -typedef struct CHD_CODEC_PARAMS { - uint8_t *sps_pps_buf; - uint32_t sps_pps_size; - uint8_t nal_size_bytes; -} CHD_CODEC_PARAMS; - -class DllLibCrystalHD; -class CMPCInputThread; -class CMPCOutputThread; - -class CCrystalHD -{ -public: - virtual ~CCrystalHD(); - - static void RemoveInstance(void); - static CCrystalHD* GetInstance(void); - - bool DevicePresent(void); - - void OpenDevice(); - void CloseDevice(); - - bool OpenDecoder(CRYSTALHD_CODEC_TYPE codec_type, CDVDStreamInfo &hints); - void CloseDecoder(void); - void Reset(void); - - bool AddInput(unsigned char *pData, size_t size, double dts, double pts); - - int GetReadyCount(void); - void BusyListFlush(void); - - bool GetPicture(DVDVideoPicture* pDvdVideoPicture); - void SetDropState(bool bDrop); - -protected: - - DllLibCrystalHD *m_dll; - void *m_device; - bool m_device_preset; - bool m_new_lib; - bool m_decoder_open; - bool m_has_bcm70015; - int m_color_space; - bool m_drop_state; - bool m_skip_state; - unsigned int m_timeout; - unsigned int m_wait_timeout; - unsigned int m_field; - unsigned int m_width; - unsigned int m_height; - int m_reset; - int m_last_pict_num; - double m_last_demuxer_pts; - double m_last_decoder_pts; - - CMPCOutputThread *m_pOutputThread; - CSyncPtrQueue<CPictureBuffer> m_BusyList; -#if (HAVE_LIBCRYSTALHD == 2) - BC_INFO_CRYSTAL m_bc_info_crystal; -#endif - -private: - CCrystalHD(); - CCrystalHD(const CCrystalHD& other); - CCrystalHD& operator=(const CCrystalHD&); - static CCrystalHD *m_pInstance; - - // bitstream to bytestream (Annex B) conversion support. - bool bitstream_convert_init(void *in_extradata, int in_extrasize); - bool bitstream_convert(uint8_t* pData, int iSize, uint8_t **poutbuf, int *poutbuf_size); - static void bitstream_alloc_and_copy( uint8_t **poutbuf, int *poutbuf_size, - const uint8_t *sps_pps, uint32_t sps_pps_size, const uint8_t *in, uint32_t in_size); - - typedef struct chd_bitstream_ctx { - uint8_t length_size; - uint8_t first_idr; - uint8_t *sps_pps_data; - uint32_t size; - } chd_bitstream_ctx; - - uint32_t m_sps_pps_size; - chd_bitstream_ctx m_sps_pps_context; - bool m_convert_bitstream; - - bool extract_sps_pps_from_avcc(int extradata_size, void *extradata); - CHD_CODEC_PARAMS m_chd_params; -}; - -#endif diff --git a/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp b/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp deleted file mode 100644 index 373ae2c8d7..0000000000 --- a/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp +++ /dev/null @@ -1,204 +0,0 @@ -/* - * Copyright (C) 2005-2013 Team XBMC - * http://xbmc.org - * - * This Program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This Program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with XBMC; see the file COPYING. If not, see - * <http://www.gnu.org/licenses/>. - * - */ - -#if (defined HAVE_CONFIG_H) && (!defined TARGET_WINDOWS) - #include "config.h" -#elif defined(TARGET_WINDOWS) -#include "system.h" -extern "C" { -#include "libavcodec/avcodec.h" -} -#endif - -#if defined(HAVE_LIBCRYSTALHD) -#include "DVDClock.h" -#include "DVDStreamInfo.h" -#include "DVDVideoCodecCrystalHD.h" -#include "settings/Settings.h" -#include "utils/log.h" -#include "utils/TimeUtils.h" - -#define __MODULE_NAME__ "DVDVideoCodecCrystalHD" - -CDVDVideoCodecCrystalHD::CDVDVideoCodecCrystalHD() : - m_Codec(NULL), - m_DropPictures(false), - m_Duration(0.0), - m_pFormatName(""), - m_CodecType(CRYSTALHD_CODEC_ID_MPEG2) -{ -} - -CDVDVideoCodecCrystalHD::~CDVDVideoCodecCrystalHD() -{ - Dispose(); -} - -bool CDVDVideoCodecCrystalHD::Open(CDVDStreamInfo &hints, CDVDCodecOptions &options) -{ - if (CSettings::Get().GetBool("videoplayer.usechd") && !hints.software) - { - switch (hints.codec) - { - case AV_CODEC_ID_MPEG2VIDEO: - m_CodecType = CRYSTALHD_CODEC_ID_MPEG2; - m_pFormatName = "chd-mpeg2"; - break; - case AV_CODEC_ID_H264: - switch(hints.profile) - { - case FF_PROFILE_H264_HIGH_10: - case FF_PROFILE_H264_HIGH_10_INTRA: - case FF_PROFILE_H264_HIGH_422: - case FF_PROFILE_H264_HIGH_422_INTRA: - case FF_PROFILE_H264_HIGH_444_PREDICTIVE: - case FF_PROFILE_H264_HIGH_444_INTRA: - case FF_PROFILE_H264_CAVLC_444: - CLog::Log(LOGNOTICE, "%s - unsupported h264 profile(%d)", __FUNCTION__, hints.profile); - return false; - break; - } - if (hints.extrasize < 7 || hints.extradata == NULL) - { - CLog::Log(LOGNOTICE, "%s - avcC atom too data small or missing", __FUNCTION__); - return false; - } - // valid avcC data (bitstream) always starts with the value 1 (version) - if ( *(char*)hints.extradata == 1 ) - m_CodecType = CRYSTALHD_CODEC_ID_AVC1; - else - m_CodecType = CRYSTALHD_CODEC_ID_H264; - - m_pFormatName = "chd-h264"; - break; - case AV_CODEC_ID_VC1: - m_CodecType = CRYSTALHD_CODEC_ID_VC1; - m_pFormatName = "chd-vc1"; - break; - case AV_CODEC_ID_WMV3: - m_CodecType = CRYSTALHD_CODEC_ID_WMV3; - m_pFormatName = "chd-wmv3"; - break; - default: - return false; - break; - } - - m_Codec = CCrystalHD::GetInstance(); - if (!m_Codec) - { - CLog::Log(LOGERROR, "%s: Failed to open Broadcom Crystal HD Codec", __MODULE_NAME__); - return false; - } - - if (m_Codec && !m_Codec->OpenDecoder(m_CodecType, hints)) - { - CLog::Log(LOGERROR, "%s: Failed to open Broadcom Crystal HD Codec", __MODULE_NAME__); - return false; - } - - // default duration to 23.976 fps, have to guess something. - m_Duration = (DVD_TIME_BASE / (24.0 * 1000.0/1001.0)); - m_DropPictures = false; - - CLog::Log(LOGINFO, "%s: Opened Broadcom Crystal HD Codec", __MODULE_NAME__); - return true; - } - - return false; -} - -void CDVDVideoCodecCrystalHD::Dispose(void) -{ - if (m_Codec) - { - m_Codec->CloseDecoder(); - m_Codec = NULL; - } -} - -int CDVDVideoCodecCrystalHD::Decode(uint8_t *pData, int iSize, double dts, double pts) -{ - if (!pData) - { - // if pData is nil, we are in dvdplayervideo's special loop - // where it checks for more picture frames, you must pass - // VC_BUFFER to get it to break out of this loop. - int ready_cnt = m_Codec->GetReadyCount(); - if (ready_cnt == 1) - return VC_PICTURE | VC_BUFFER; - if (ready_cnt > 2) - return VC_PICTURE; - else - return VC_BUFFER; - } - - // We are running a picture queue, picture frames are allocated - // in CrystalHD class if needed, then passed up. Need to return - // them back to CrystalHD class for re-queuing. This way we keep - // the memory alloc/free to a minimum and don't churn memory for - // each picture frame. - m_Codec->BusyListFlush(); - - if (pData) - { - // Handle Input, add demuxer packet to input queue, we must accept it or - // it will be discarded as DVDPlayerVideo has no concept of "try again". - if ( !m_Codec->AddInput(pData, iSize, dts, pts) ) - { - // Deep crap error, this should never happen unless we run away pulling demuxer pkts. - CLog::Log(LOGDEBUG, "%s: m_pInputThread->AddInput full.", __MODULE_NAME__); - Sleep(10); - } - } - - // if we have more than one frame ready, just return VC_PICTURE so - // dvdplayervideo will loop and drain them before sending another demuxer packet. - if (m_Codec->GetReadyCount() > 2) - return VC_PICTURE; - - int rtn = 0; - if (m_Codec->GetReadyCount()) - rtn = VC_PICTURE; - - return rtn | VC_BUFFER; -} - -void CDVDVideoCodecCrystalHD::Reset(void) -{ - m_Codec->Reset(); -} - -bool CDVDVideoCodecCrystalHD::GetPicture(DVDVideoPicture* pDvdVideoPicture) -{ - bool ret; - - ret = m_Codec->GetPicture(pDvdVideoPicture); - m_Duration = pDvdVideoPicture->iDuration; - return ret; -} - -void CDVDVideoCodecCrystalHD::SetDropState(bool bDrop) -{ - m_DropPictures = bDrop; - m_Codec->SetDropState(m_DropPictures); -} - -#endif diff --git a/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.h b/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.h deleted file mode 100644 index cc36c29859..0000000000 --- a/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.h +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (C) 2005-2013 Team XBMC - * http://xbmc.org - * - * This Program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This Program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with XBMC; see the file COPYING. If not, see - * <http://www.gnu.org/licenses/>. - * - */ - -#pragma once - -#if defined(HAVE_LIBCRYSTALHD) - -#include "CrystalHD.h" -#include "DVDVideoCodec.h" - -class CDVDVideoCodecCrystalHD : public CDVDVideoCodec -{ -public: - CDVDVideoCodecCrystalHD(); - virtual ~CDVDVideoCodecCrystalHD(); - - // Required overrides - virtual bool Open(CDVDStreamInfo &hints, CDVDCodecOptions &options); - virtual void Dispose(void); - virtual int Decode(uint8_t *pData, int iSize, double dts, double pts); - virtual void Reset(void); - virtual bool GetPicture(DVDVideoPicture *pDvdVideoPicture); - virtual void SetDropState(bool bDrop); - virtual const char* GetName(void) { return (const char*)m_pFormatName; } - -protected: - CCrystalHD *m_Codec; - bool m_DropPictures; - double m_Duration; - const char *m_pFormatName; - CRYSTALHD_CODEC_TYPE m_CodecType; -}; - -#endif diff --git a/xbmc/cores/dvdplayer/DVDCodecs/Video/Makefile.in b/xbmc/cores/dvdplayer/DVDCodecs/Video/Makefile.in index 8a97889b23..9c13da85b6 100644 --- a/xbmc/cores/dvdplayer/DVDCodecs/Video/Makefile.in +++ b/xbmc/cores/dvdplayer/DVDCodecs/Video/Makefile.in @@ -11,10 +11,6 @@ endif ifeq (@USE_VAAPI@,1) SRCS += VAAPI.cpp endif -ifeq (@USE_CRYSTALHD@,1) -SRCS += CrystalHD.cpp -SRCS += DVDVideoCodecCrystalHD.cpp -endif ifeq ($(findstring osx,@ARCH@),osx) SRCS += DVDVideoCodecVDA.cpp SRCS += VDA.cpp diff --git a/xbmc/settings/SettingConditions.cpp b/xbmc/settings/SettingConditions.cpp index db1526ab44..7b615127d1 100644 --- a/xbmc/settings/SettingConditions.cpp +++ b/xbmc/settings/SettingConditions.cpp @@ -29,9 +29,6 @@ #include "android/activity/AndroidFeatures.h" #endif // defined(TARGET_ANDROID) #include "cores/AudioEngine/AEFactory.h" -#if defined(HAVE_LIBCRYSTALHD) -#include "cores/dvdplayer/DVDCodecs/Video/CrystalHD.h" -#endif // defined(HAVE_LIBCRYSTALHD) #include "cores/dvdplayer/DVDCodecs/Video/DVDVideoCodec.h" #include "guilib/LocalizeStrings.h" #include "peripherals/Peripherals.h" @@ -227,11 +224,6 @@ void CSettingConditions::Initialize() #ifdef HAS_ZEROCONF m_simpleConditions.insert("has_zeroconf"); #endif -#ifdef HAVE_LIBCRYSTALHD - m_simpleConditions.insert("have_libcrystalhd"); - if (CCrystalHD::GetInstance()->DevicePresent()) - m_simpleConditions.insert("hascrystalhddevice"); -#endif #ifdef HAVE_LIBOPENMAX m_simpleConditions.insert("have_libopenmax"); #endif diff --git a/xbmc/system.h b/xbmc/system.h index a9668d47f2..1ca58d02fe 100644 --- a/xbmc/system.h +++ b/xbmc/system.h @@ -114,7 +114,6 @@ #define HAS_WIN32_NETWORK #define HAS_IRSERVERSUITE #define HAS_AUDIO -#define HAVE_LIBCRYSTALHD 2 #define HAS_WEB_SERVER #define HAS_WEB_INTERFACE #define HAVE_LIBSSH diff --git a/xbmc/win32/WIN32Util.cpp b/xbmc/win32/WIN32Util.cpp index 628e689a11..617477543e 100644 --- a/xbmc/win32/WIN32Util.cpp +++ b/xbmc/win32/WIN32Util.cpp @@ -43,12 +43,6 @@ #include "utils/URIUtils.h" #include "utils/StringUtils.h" -// default Broadcom registy bits (setup when installing a CrystalHD card) -#define BC_REG_PATH "Software\\Broadcom\\MediaPC" -#define BC_REG_PRODUCT "CrystalHD" // 70012/70015 -#define BC_BCM_DLL "bcmDIL.dll" -#define BC_REG_INST_PATH "InstallPath" - #define DLL_ENV_PATH "special://xbmc/system/;" \ "special://xbmc/system/players/dvdplayer/;" \ "special://xbmc/system/players/paplayer/;" \ @@ -1354,41 +1348,6 @@ bool CWIN32Util::UtilRegOpenKeyEx( const HKEY hKeyParent, const char *const pcKe return bRet; } -bool CWIN32Util::GetCrystalHDLibraryPath(std::string &strPath) -{ - // support finding library by windows registry - HKEY hKey; - std::string strRegKey; - - CLog::Log(LOGDEBUG, "CrystalHD: detecting CrystalHD installation path"); - strRegKey = StringUtils::Format("%s\\%s", BC_REG_PATH, BC_REG_PRODUCT ); - - if( CWIN32Util::UtilRegOpenKeyEx( HKEY_LOCAL_MACHINE, strRegKey.c_str(), KEY_READ, &hKey )) - { - DWORD dwType; - char *pcPath= NULL; - if( CWIN32Util::UtilRegGetValue( hKey, BC_REG_INST_PATH, &dwType, &pcPath, NULL, sizeof( pcPath ) ) == ERROR_SUCCESS ) - { - strPath = URIUtils::AddFileToFolder(pcPath, BC_BCM_DLL); - CLog::Log(LOGDEBUG, "CrystalHD: got CrystalHD installation path (%s)", strPath.c_str()); - return true; - } - else - { - CLog::Log(LOGDEBUG, "CrystalHD: getting CrystalHD installation path failed"); - } - } - else - { - CLog::Log(LOGDEBUG, "CrystalHD: CrystalHD software seems to be not installed."); - } - // check for dll in system dir - if(XFILE::CFile::Exists(DLL_PATH_LIBCRYSTALHD)) - return true; - else - return false; -} - // Retrieve the filename of the process that currently has the focus. // Typically this will be some process using the system tray grabbing // the focus and causing XBMC to minimise. Logging the offending diff --git a/xbmc/win32/WIN32Util.h b/xbmc/win32/WIN32Util.h index 210774bedb..1403724bfe 100644 --- a/xbmc/win32/WIN32Util.h +++ b/xbmc/win32/WIN32Util.h @@ -77,8 +77,6 @@ public: static LONG UtilRegGetValue( const HKEY hKey, const char *const pcKey, DWORD *const pdwType, char **const ppcBuffer, DWORD *const pdwSizeBuff, const DWORD dwSizeAdd ); static bool UtilRegOpenKeyEx( const HKEY hKeyParent, const char *const pcKey, const REGSAM rsAccessRights, HKEY *hKey, const bool bReadX64= false ); - static bool GetCrystalHDLibraryPath(std::string &strPath); - static bool GetFocussedProcess(std::string &strProcessFile); static void CropSource(CRect& src, CRect& dst, CRect target); |