aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--xbmc/cores/VideoPlayer/DVDCodecs/Video/AMLCodec.cpp85
-rw-r--r--xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.cpp33
-rw-r--r--xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.h1
-rw-r--r--xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAmlogic.cpp11
-rw-r--r--xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp8
-rw-r--r--xbmc/cores/VideoPlayer/VideoRenderers/HwDecRender/RendererAML.cpp5
6 files changed, 29 insertions, 114 deletions
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/AMLCodec.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/AMLCodec.cpp
index d83fbda65b..d5100a6436 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/AMLCodec.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/AMLCodec.cpp
@@ -55,8 +55,7 @@
// amcodec include
extern "C" {
-#include <codec.h>
-#include <amports/amstream.h>
+#include <amcodec/codec.h>
} // extern "C"
CEvent g_aml_sync_event;
@@ -346,44 +345,11 @@ typedef struct vframe_states
int buf_avail_num;
} vframe_states_t;
-static int aml_ioctl_get(CODEC_HANDLE h, int subcmd, unsigned long paramter)
-{
- struct am_ioctl_parm parm;
- memset(&parm, 0, sizeof(parm));
- parm.cmd = subcmd;
- parm.data_32 = *(unsigned int *)paramter;
- if (ioctl(h, AMSTREAM_IOC_GET, (unsigned long)&parm) < 0)
- {
- CLog::Log(LOGERROR, "aml_ioctl_get failed: subcmd=%x, errno=%d", subcmd, errno);
- return -1;
- }
- *(unsigned int *)paramter = parm.data_32;
- return 0;
-}
-
-
-#ifndef AMSTREAM_IOC_MAGIC
-#define AMSTREAM_IOC_MAGIC 'S'
-#endif
-
#ifndef AMSTREAM_IOC_VF_STATUS
+#define AMSTREAM_IOC_MAGIC 'S'
#define AMSTREAM_IOC_VF_STATUS _IOR(AMSTREAM_IOC_MAGIC, 0x60, unsigned long)
#endif
-#ifndef AMSTREAM_IOC_GET_3D_TYPE
-#define AMSTREAM_IOC_GET_3D_TYPE _IOW((AMSTREAM_IOC_MAGIC), 0x3d, unsigned int)
-#endif
-
-
-enum
-{
- VPP_3D_MODE_NULL = 0,
- VPP_3D_MODE_LR,
- VPP_3D_MODE_TB,
- VPP_3D_MODE_LA,
- VPP_3D_MODE_FA
-};
-
/*************************************************************************/
/*************************************************************************/
void dumpfile_open(am_private_t *para)
@@ -1512,8 +1478,8 @@ CAMLCodec::CAMLCodec(CProcessInfo &processInfo)
, m_ptsIs64us(false)
, m_speed(DVD_PLAYSPEED_NORMAL)
, m_cur_pts(INT64_0)
- , m_last_pts(0)
, m_ptsOverflow(0)
+ , m_last_pts(0)
, m_bufferIndex(-1)
, m_state(0)
, m_frameSizeSum(0)
@@ -2282,45 +2248,18 @@ bool CAMLCodec::SetVideo3dMode(const int mode3d)
std::string CAMLCodec::GetStereoMode()
{
- std::string stereoMode;
-
- //Get Decoder Stereo mode
- int decoder_sm(VPP_3D_MODE_NULL);
- aml_ioctl_get(am_private->vcodec.handle, AMSTREAM_IOC_GET_3D_TYPE, (unsigned long)&decoder_sm);
-
- switch (decoder_sm)
- {
- case VPP_3D_MODE_LR:
- stereoMode = "left_right";
- break;
- case VPP_3D_MODE_TB:
- stereoMode = "top_bottom";
- break;
- case VPP_3D_MODE_LA:
- case VPP_3D_MODE_FA:
- default:
- switch(m_processInfo.GetVideoSettings().m_StereoMode)
- {
- case RENDER_STEREO_MODE_SPLIT_VERTICAL:
- stereoMode = "left_right";
- break;
- case RENDER_STEREO_MODE_SPLIT_HORIZONTAL:
- stereoMode = "top_bottom";
- break;
- default:
- stereoMode = m_hints.stereo_mode;
- break;
- }
- }
+ std::string stereo_mode;
- if (m_processInfo.GetVideoSettings().m_StereoInvert)
+ switch(m_processInfo.GetVideoSettings().m_StereoMode)
{
- if (stereoMode == "top_bottom")
- stereoMode = "bottom_top";
- else if (stereoMode == "left_right")
- stereoMode = "right_left";
+ case RENDER_STEREO_MODE_SPLIT_VERTICAL: stereo_mode = "left_right"; break;
+ case RENDER_STEREO_MODE_SPLIT_HORIZONTAL: stereo_mode = "top_bottom"; break;
+ default: stereo_mode = m_hints.stereo_mode; break;
}
- return stereoMode;
+
+ if(m_processInfo.GetVideoSettings().m_StereoInvert)
+ stereo_mode = RenderManager::GetStereoModeInvert(stereo_mode);
+ return stereo_mode;
}
void CAMLCodec::SetVideoRect(const CRect &SrcRect, const CRect &DestRect)
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.cpp
index 50c020e69e..e12dc7c869 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.cpp
@@ -42,39 +42,6 @@ VideoPicture::~VideoPicture()
}
}
-void VideoPicture::Reset()
-{
- if (videoBuffer)
- videoBuffer->Reset();
- videoBuffer = nullptr;
- pts = DVD_NOPTS_VALUE;
- dts = DVD_NOPTS_VALUE;
- iFlags = 0;
- iRepeatPicture = 0;
- iDuration = 0;
- iFrameType = 0;
- color_space = AVCOL_SPC_UNSPECIFIED;
- color_range = 0;
- chroma_position = 0;
- color_primaries = 0;
- color_transfer = 0;
- colorBits = 8;
- stereoMode.clear();
-
- qp_table = nullptr;
- qstride = 0;
- qscale_type = 0;
- pict_type = 0;
-
- hasDisplayMetadata = false;
- hasLightMetadata = false;
-
- iWidth = 0;
- iHeight = 0;
- iDisplayWidth = 0;
- iDisplayHeight = 0;
-}
-
VideoPicture& VideoPicture::CopyRef(const VideoPicture &pic)
{
if (videoBuffer)
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.h b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.h
index 20a13d8c93..e482ea9e73 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.h
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodec.h
@@ -53,7 +53,6 @@ public:
~VideoPicture();
VideoPicture& CopyRef(const VideoPicture &pic);
VideoPicture& SetParams(const VideoPicture &pic);
- void Reset(); // reinitialize members, videoBuffer will be released if set!
CVideoBuffer *videoBuffer = nullptr;
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAmlogic.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAmlogic.cpp
index 1e5dd5a164..f84c6573d2 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAmlogic.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAmlogic.cpp
@@ -280,10 +280,17 @@ bool CDVDVideoCodecAmlogic::Open(CDVDStreamInfo &hints, CDVDCodecOptions &option
}
// allocate a dummy VideoPicture buffer.
- m_videobuffer.Reset();
-
+ // first make sure all properties are reset.
+ memset(&m_videobuffer, 0, sizeof(VideoPicture));
+
+ m_videobuffer.dts = DVD_NOPTS_VALUE;
+ m_videobuffer.pts = DVD_NOPTS_VALUE;
+ m_videobuffer.color_range = 0;
+ m_videobuffer.color_matrix = 4;
+ m_videobuffer.iFlags = 0;
m_videobuffer.iWidth = m_hints.width;
m_videobuffer.iHeight = m_hints.height;
+ m_videobuffer.videoBuffer = nullptr;
m_videobuffer.iDisplayWidth = m_videobuffer.iWidth;
m_videobuffer.iDisplayHeight = m_videobuffer.iHeight;
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp
index 8676b292ef..c3fc3e95ff 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp
@@ -355,7 +355,7 @@ CDVDVideoCodecAndroidMediaCodec::CDVDVideoCodecAndroidMediaCodec(CProcessInfo &p
, m_render_surface(surface_render)
, m_mpeg2_sequence(nullptr)
{
- m_videobuffer.Reset();
+ memset(&m_videobuffer, 0x00, sizeof(VideoPicture));
}
CDVDVideoCodecAndroidMediaCodec::~CDVDVideoCodecAndroidMediaCodec()
@@ -681,8 +681,12 @@ bool CDVDVideoCodecAndroidMediaCodec::Open(CDVDStreamInfo &hints, CDVDCodecOptio
// setup a YUV420P VideoPicture buffer.
// first make sure all properties are reset.
- m_videobuffer.Reset();
+ memset(&m_videobuffer, 0x00, sizeof(VideoPicture));
+ m_videobuffer.dts = DVD_NOPTS_VALUE;
+ m_videobuffer.pts = DVD_NOPTS_VALUE;
+ m_videobuffer.color_range = 0;
+ m_videobuffer.color_space = 4;
m_videobuffer.iWidth = m_hints.width;
m_videobuffer.iHeight = m_hints.height;
// these will get reset to crop values later
diff --git a/xbmc/cores/VideoPlayer/VideoRenderers/HwDecRender/RendererAML.cpp b/xbmc/cores/VideoPlayer/VideoRenderers/HwDecRender/RendererAML.cpp
index 726424fc7e..cbfb32fd09 100644
--- a/xbmc/cores/VideoPlayer/VideoRenderers/HwDecRender/RendererAML.cpp
+++ b/xbmc/cores/VideoPlayer/VideoRenderers/HwDecRender/RendererAML.cpp
@@ -27,8 +27,7 @@
#include "utils/ScreenshotAML.h"
#include "settings/MediaSettings.h"
#include "cores/VideoPlayer/VideoRenderers/RenderCapture.h"
-#include "cores/VideoPlayer/VideoRenderers/RenderFactory.h"
-#include "cores/VideoPlayer/VideoRenderers/RenderFlags.h"
+#include "../RenderFactory.h"
#include "settings/AdvancedSettings.h"
CRendererAML::CRendererAML()
@@ -63,7 +62,7 @@ bool CRendererAML::Configure(const VideoPicture &picture, float fps, unsigned in
m_renderOrientation = orientation;
m_iFlags = GetFlagsChromaPosition(picture.chroma_position) |
- GetFlagsColorMatrix(picture.color_space, picture.iWidth, picture.iHeight) |
+ GetFlagsColorMatrix(picture.color_matrix, picture.iWidth, picture.iHeight) |
GetFlagsColorPrimaries(picture.color_primaries) |
GetFlagsStereoMode(picture.stereoMode);