Merge branch 'ni/tuxbox' into ni/mp/tuxbox

Conflicts:
	lib/Makefile.am
	src/Makefile.am
	src/neutrino.cpp


Origin commit data
------------------
Branch: ni/coolstream
Commit: e2d5f6ebf1
Author: vanhofen <vanhofen@gmx.de>
Date: 2017-03-06 (Mon, 06 Mar 2017)



------------------
This commit was generated by Migit
This commit is contained in:
vanhofen
2017-03-06 22:40:18 +01:00
50 changed files with 110 additions and 368 deletions

View File

@@ -273,20 +273,22 @@ fi
if test "$BOXTYPE" = "coolstream"; then
if test -e ${srcdir}/lib/libcoolstream/nevis_ir.h; then
if test -e ${srcdir}/lib/hardware/coolstream/hd1/libcoolstream/nevis_ir.h; then
AC_DEFINE(HAVE_COOLSTREAM_NEVIS_IR_H,1,[Define to 1 if you have the <nevis_ir.h> header file.])
fi
HWLIB_CFLAGS='-I$(top_srcdir)/lib/libcoolstream -I$(top_srcdir)/src/zapit/include/private'
HWLIB_CFLAGS='-I$(top_srcdir)/lib/hardware/coolstream/hd1/libcoolstream'
if test "$BOXMODEL" = "hd2"; then
if test -e ${srcdir}/lib/libcoolstream2/cs_ir_generic.h; then
if test -e ${srcdir}/lib/hardware/coolstream/hd2/libcoolstream/cs_ir_generic.h; then
AC_DEFINE(HAVE_COOLSTREAM_CS_IR_GENERIC_H,1,[Define to 1 if you have the <cs_ir_generic.h> header file.])
fi
if test -e ${srcdir}/lib/libcoolstream2/cs_frontpanel.h; then
if test -e ${srcdir}/lib/hardware/coolstream/hd2/libcoolstream/cs_frontpanel.h; then
AC_DEFINE(HAVE_COOLSTREAM_CS_FRONTPANEL_H,1,[Define to 1 if you have the <cs_frontpanel.h> header file.])
fi
HWLIB_CFLAGS='-I$(top_srcdir)/lib/libcoolstream2 -I$(top_srcdir)/src/zapit/include/private'
HWLIB_CFLAGS='-I$(top_srcdir)/lib/hardware/coolstream/hd2/libcoolstream'
fi
HWLIB_CFLAGS="$HWLIB_CFLAGS "'-I$(top_srcdir)/src/zapit/include/private'
HWLIB_CFLAGS="$HWLIB_CFLAGS "'-I$(top_srcdir)/lib/hardware/coolstream'
fi
# hack, so that framebuffer.h does not need to be included everywhere...
@@ -356,6 +358,7 @@ data/y-web/scripts/Makefile
data/y-web/styles/Makefile
lib/Makefile
lib/connection/Makefile
lib/hardware/coolstream/Makefile
lib/jsoncpp/Makefile
lib/libconfigfile/Makefile
lib/libcoolstream/Makefile

View File

@@ -19,11 +19,6 @@ SUBDIRS += \
endif
if BOXTYPE_COOL
if BOXMODEL_CS_HD2
SUBDIRS += \
libcoolstream2
else
SUBDIRS += \
libcoolstream
endif
hardware/coolstream
endif

View File

@@ -0,0 +1,12 @@
noinst_LIBRARIES = libhwcaps.a
AM_CXXFLAGS = -fno-rtti -fno-exceptions -fno-strict-aliasing
if BOXMODEL_CS_HD2
AM_CPPFLAGS = -I$(top_srcdir)/lib/hardware/coolstream/hd2/libcoolstream
else
AM_CPPFLAGS = -I$(top_srcdir)/lib/hardware/coolstream/hd1/libcoolstream
endif
libhwcaps_a_SOURCES = \
hardware_caps.cpp

View File

@@ -0,0 +1,72 @@
/*
* determine the capabilities of the hardware.
* part of libstb-hal
*
* (C) 2010-2012,2016 Stefan Seyfried
*
* License: GPL v2 or later
*/
#include "cs_api.h"
#include <stdio.h>
#include <string.h>
#include "hardware_caps.h"
static int initialized = 0;
static hw_caps_t caps;
hw_caps_t *get_hwcaps(void) {
if (initialized)
return &caps;
int rev = cs_get_revision();
caps.has_fan = (rev < 8);
caps.has_HDMI = 1;
caps.has_SCART = (rev != 10);
caps.has_SCART_input = 0;
caps.has_YUV_cinch = 1;
caps.can_shutdown = (rev > 7);
caps.can_cec = 1;
caps.display_type = HW_DISPLAY_LINE_TEXT;
caps.display_xres = 12;
caps.display_yres = 0;
caps.can_set_display_brightness = 1;
caps.can_ar_14_9 = 1;
caps.can_ps_14_9 = 1;
caps.force_tuner_2G = 0;
strcpy(caps.boxvendor, "Coolstream");
/* list of boxnames from neutrinoyparser.cpp */
strcpy(caps.boxarch, "Nevis");
switch (rev) {
case 6:
case 7: // Black Stallion Edition
strcpy(caps.boxname, "HD1");
caps.force_tuner_2G = 1;
break;
case 8:
strcpy(caps.boxname, "Neo");
caps.force_tuner_2G = 1;
break;
case 9:
strcpy(caps.boxname, "Tank");
strcpy(caps.boxarch, "Apollo");
break;
case 10:
strcpy(caps.boxname, "Zee");
caps.force_tuner_2G = 1;
break;
case 11:
strcpy(caps.boxname, "Trinity");
strcpy(caps.boxarch, "Shiner");
break;
case 12:
strcpy(caps.boxname, "Zee2");
strcpy(caps.boxarch, "Kronos");
break;
default:
strcpy(caps.boxname, "UNKNOWN_BOX");
strcpy(caps.boxarch, "Unknown");
fprintf(stderr, "[%s] unhandled box revision %d\n", __func__, rev);
}
initialized = 1;
return &caps;
}

View File

@@ -3,18 +3,14 @@
* part of libstb-hal
*
* (C) 2010-2012,2016 Stefan Seyfried
* (C) 2016 M. Liebmann
*
* License: GPL v2 or later
*/
#ifndef __HARDWARE_CAPS_H__
#define __HARDWARE_CAPS_H__
#include "cs_api.h"
#include <string.h>
#include <string>
typedef enum {
typedef enum
{
HW_DISPLAY_NONE,
HW_DISPLAY_LED_NUM, /* simple 7 segment LED display */
HW_DISPLAY_LINE_TEXT, /* 1 line text display */
@@ -22,7 +18,8 @@ typedef enum {
} display_type_t;
typedef struct hw_caps {
typedef struct hw_caps
{
int has_fan;
int has_HDMI;
int has_SCART;
@@ -30,6 +27,9 @@ typedef struct hw_caps {
int has_YUV_cinch;
int can_shutdown;
int can_cec;
int can_ar_14_9; /* video drivers have 14:9 aspect ratio mode */
int can_ps_14_9; /* video drivers have 14:9 panscan mode */
int force_tuner_2G; /* force DVB-S2 even though driver may not advertise it */
display_type_t display_type;
int display_xres; /* x resolution or chars per line */
int display_yres;
@@ -37,10 +37,7 @@ typedef struct hw_caps {
char boxvendor[64];
char boxname[64];
char boxarch[64];
char chipset[64];
char frontend[64];
} hw_caps_t;
std::string getTuner();
hw_caps_t *get_hwcaps(void);
#endif

View File

@@ -1,5 +0,0 @@
Makefile.in
.libs
.deps
*.la
*.lo

View File

@@ -1,16 +0,0 @@
noinst_LIBRARIES = libhwcaps.a
AM_CXXFLAGS = -fno-rtti -fno-exceptions -fno-strict-aliasing
AM_CPPFLAGS = \
-I$(top_builddir) \
-I$(top_srcdir)/src \
-I$(top_srcdir)/src/zapit/include \
-I$(top_srcdir)/lib \
-I$(top_srcdir)/lib/libeventserver \
-I$(top_srcdir)/lib/libconfigfile \
-I$(top_srcdir)/lib/libcoolstream \
@HWLIB_CFLAGS@
libhwcaps_a_SOURCES = \
hardware_caps.cpp

View File

@@ -1,87 +0,0 @@
/*
* determine the capabilities of the hardware.
* part of libstb-hal
*
* (C) 2010-2012,2016 Stefan Seyfried
* (C) 2016 M. Liebmann
*
* License: GPL v2 or later
*/
#include <global.h>
#include <zapit/femanager.h>
#include <sys/utsname.h>
#include "hardware_caps.h"
static int initialized = 0;
static bool frontend_check = false;
static hw_caps_t caps;
hw_caps_t *get_hwcaps(void)
{
if (initialized && frontend_check)
return &caps;
struct utsname u;
unsigned int system_rev = cs_get_revision();
CFEManager* fem = CFEManager::getInstance();
int frontendCount = fem->getFrontendCount();
frontend_check = frontendCount > 0;
caps.has_fan = (system_rev < 8);
caps.has_HDMI = 1;
caps.has_SCART = (system_rev != 10);
caps.has_SCART_input = 0;
caps.has_YUV_cinch = 1;
caps.can_shutdown = (system_rev > 7);
caps.can_cec = 1;
caps.display_type = (system_rev != 10) ? HW_DISPLAY_LINE_TEXT : HW_DISPLAY_NONE;
caps.display_xres = 12;
caps.display_yres = 0;
caps.can_set_display_brightness = 1;
strcpy(caps.boxvendor, "CST");
const char* boxname;
switch (system_rev) {
case 6:
boxname = "HD1";
break;
case 7:
boxname = "BSE";
break;
case 8:
boxname = "Neo";
break;
case 10:
boxname = "Zee";
break;
default:
char buffer[512];
snprintf(buffer, sizeof(buffer)-1, "Unknown nr. %u\n", system_rev);
boxname = buffer;
break;
}
strcpy(caps.boxname, boxname);
CFrontend *frontend = fem->getFE(0);
uint32_t mask = frontend->getSupportedDeliverySystems();
std::string tuner = "";
if (frontendCount > 1)
tuner += "Twin ";
tuner += ((mask & DVB_C) == DVB_C) ? g_Locale->getText(LOCALE_SATSETUP_FE_DELSYS_MODE_CABLE) : "Sat";
strcpy(caps.frontend, tuner.c_str());
strcpy(caps.chipset, "Nevis");
if (! uname(&u))
strncpy(caps.boxarch, u.machine, sizeof(caps.boxarch));
else
fprintf(stderr, "%s: uname() failed: %m\n", __func__);
initialized = 1;
return &caps;
}

View File

@@ -1,15 +0,0 @@
noinst_LIBRARIES = libhwcaps.a
AM_CXXFLAGS = -fno-rtti -fno-exceptions -fno-strict-aliasing
AM_CPPFLAGS = \
-I$(top_builddir) \
-I$(top_srcdir)/src \
-I$(top_srcdir)/src/zapit/include \
-I$(top_srcdir)/lib \
-I$(top_srcdir)/lib/libeventserver \
-I$(top_srcdir)/lib/libconfigfile \
-I$(top_srcdir)/lib/libcoolstream2
libhwcaps_a_SOURCES = \
hardware_caps.cpp

View File

@@ -1,170 +0,0 @@
/*
* determine the capabilities of the hardware.
* part of libstb-hal
*
* (C) 2010-2012 Stefan Seyfried
* (C) 2016 M. Liebmann
*
* License: GPL v2 or later
*/
#include <global.h>
#include <zapit/femanager.h>
#include <sys/utsname.h>
#include "hardware_caps.h"
static int initialized = 0;
static bool frontend_check = false;
static hw_caps_t caps;
std::string getTuner()
{
std::string tuner;
char buff1[64];
CFEManager* fem = CFEManager::getInstance();
int frontendCount = fem->getFrontendCount();
frontend_check = frontendCount > 0;
int satCount = 0;
int cableCount = 0;
int dvbtCount = 0;
int dvbc_tCount = 0;
for (int i = 0; i < frontendCount; i++) {
bool has_dvb_s = false;
bool has_dvb_s2 = false;
bool has_dvb_c = false;
bool has_dvb_t = false;
bool has_dvb_t2 = false;
// bool has_dtmb = false;
CFrontend *frontend = fem->getFE(i);
uint32_t mask = frontend->getSupportedDeliverySystems();
if ((mask & DVB_S) == DVB_S) has_dvb_s = true;
if ((mask & DVB_S2) == DVB_S2) has_dvb_s2 = true;
if ((mask & DVB_C) == DVB_C) has_dvb_c = true;
if ((mask & DVB_T) == DVB_T) has_dvb_t = true;
if ((mask & DVB_T2) == DVB_T2) has_dvb_t2 = true;
// if ((mask & DTMB) == DTMB) has_dtmb = true;
if (has_dvb_s || has_dvb_s2) satCount++;
if (has_dvb_c && (has_dvb_t || has_dvb_t2))
dvbc_tCount++;
else {
if (has_dvb_c) cableCount++;
if (has_dvb_t || has_dvb_t2) dvbtCount++;
}
}
if (satCount > 0) {
memset(buff1, 0, sizeof(buff1));
snprintf(buff1, sizeof(buff1)-1, "%dx Sat", satCount);
tuner += buff1;
}
if (cableCount > 0) {
if (satCount > 0) tuner += ", ";
memset(buff1, 0, sizeof(buff1));
snprintf(buff1, sizeof(buff1)-1, "%dx %s", cableCount, g_Locale->getText(LOCALE_SATSETUP_FE_DELSYS_MODE_CABLE));
tuner += buff1;
}
if (dvbtCount > 0) {
if ((satCount > 0) || (cableCount > 0)) tuner += ", ";
memset(buff1, 0, sizeof(buff1));
snprintf(buff1, sizeof(buff1)-1, "%dx DVB-T", dvbtCount);
tuner += buff1;
}
if (dvbc_tCount > 0) {
if ((satCount > 0) || (cableCount > 0) || (dvbtCount > 0)) tuner += ", ";
memset(buff1, 0, sizeof(buff1));
snprintf(buff1, sizeof(buff1)-1, "%dx %s/DVB-T", dvbc_tCount, g_Locale->getText(LOCALE_SATSETUP_FE_DELSYS_MODE_CABLE));
tuner += buff1;
}
return tuner;
}
hw_caps_t *get_hwcaps(void)
{
if (!frontend_check)
strcpy(caps.frontend, getTuner().c_str());
if (initialized)
return &caps;
struct utsname u;
unsigned int system_rev = cs_get_revision();
caps.has_fan = 0;
caps.has_HDMI = 1;
caps.has_SCART = (system_rev != 10);
caps.has_SCART_input = 0;
caps.has_YUV_cinch = 1;
caps.can_shutdown = 1;
caps.can_cec = 1;
switch (system_rev) {
case 9: /* Tank */
case 12: /* Zee2 */
caps.display_type = HW_DISPLAY_LINE_TEXT;
break;
case 11: /* Trinity */
caps.display_type = HW_DISPLAY_NONE;
break;
case 13: /* Link */
caps.display_type = HW_DISPLAY_LED_NUM;
break;
default:
caps.display_type = HW_DISPLAY_NONE;
break;
}
caps.display_xres = 12;
caps.display_yres = 0;
caps.can_set_display_brightness = 1;
strcpy(caps.boxvendor, "CST");
const char* boxname;
switch (system_rev) {
case 9:
boxname = "Tank";
break;
case 11:
boxname = "Trinity";
break;
case 12:
boxname = "Zee2";
break;
case 13:
boxname = "Link";
break;
default:
char buffer[512];
snprintf(buffer, sizeof(buffer)-1, "Unknown nr. %u\n", system_rev);
boxname = buffer;
break;
}
strcpy(caps.boxname, boxname);
const char* chipset;
switch (system_rev) {
case 9:
chipset = "Apollo";
break;
case 11:
chipset = "Shiner";
break;
case 12:
case 13:
chipset = "Kronos";
break;
default:
chipset = "";
break;
}
strcpy(caps.chipset, chipset);
if (! uname(&u))
strncpy(caps.boxarch, u.machine, sizeof(caps.boxarch));
else
fprintf(stderr, "%s: uname() failed: %m\n", __func__);
initialized = 1;
return &caps;
}

View File

@@ -1,46 +0,0 @@
/*
* determine the capabilities of the hardware.
* part of libstb-hal
*
* (C) 2010-2012 Stefan Seyfried
* (C) 2016 M. Liebmann
*
* License: GPL v2 or later
*/
#ifndef __HARDWARE_CAPS_H__
#define __HARDWARE_CAPS_H__
#include "cs_api.h"
#include <string.h>
#include <string>
typedef enum {
HW_DISPLAY_NONE,
HW_DISPLAY_LED_NUM, /* simple 7 segment LED display */
HW_DISPLAY_LINE_TEXT, /* 1 line text display */
HW_DISPLAY_GFX
} display_type_t;
typedef struct hw_caps {
int has_fan;
int has_HDMI;
int has_SCART;
int has_SCART_input;
int has_YUV_cinch;
int can_shutdown;
int can_cec;
display_type_t display_type;
int display_xres; /* x resolution or chars per line */
int display_yres;
int can_set_display_brightness;
char boxvendor[64];
char boxname[64];
char boxarch[64];
char chipset[64];
char frontend[64];
} hw_caps_t;
std::string getTuner();
hw_caps_t *get_hwcaps(void);
#endif

View File

@@ -150,6 +150,8 @@ neutrino_LDADD += \
endif
if BOXTYPE_COOL
neutrino_LDADD += \
$(top_builddir)/lib/hardware/coolstream/libhwcaps.a
if ENABLE_LIBCOOLSTREAM_STATIC
neutrino_LDADD += -lca-sc
neutrino_LDADD += @LIBCOOLSTREAM_STATIC_DIR@/libcoolstream-mt.a

View File

@@ -284,7 +284,7 @@ int CIMDB::getIMDb(const std::string& epgTitle)
std::string url = IMDburl + imdb_ID;
if(httpTool.downloadFile(url, IMDbAPI.c_str(), -1, /*connecttimeout*/2, /*timeout*/5))
if (httpTool.downloadFile(url, IMDbAPI.c_str()))
{
initMap(m);

View File

@@ -1391,12 +1391,12 @@ void CMoviePlayerGui::PlayFileLoop(void)
}
#endif
/* in case ffmpeg report incorrect values */
if((playstate == CMoviePlayerGui::PLAY) && (speed == 1)){
if(file_prozent > 96 && (playstate == CMoviePlayerGui::PLAY) && (speed == 1)){
if(position_tmp != position){
position_tmp = position ;
eof2 = 0;
}else{
if (++eof2 > 6) {
if (++eof2 > 12) {
at_eof = true;
break;
}

View File

@@ -299,9 +299,9 @@ void CTextBox::initFramesRel(void)
if(m_nMode & SCROLL)
{
m_cFrameScrollRel.iX = m_cFrame.iWidth - SCROLL_FRAME_WIDTH;
m_cFrameScrollRel.iY = m_cFrameTextRel.iY + m_nBgRadius;
m_cFrameScrollRel.iWidth = SCROLL_FRAME_WIDTH;
m_cFrameScrollRel.iX = m_cFrame.iWidth - m_cFrameScrollRel.iWidth;
m_cFrameScrollRel.iY = m_cFrameTextRel.iY + m_nBgRadius;
m_cFrameScrollRel.iHeight = m_cFrameTextRel.iHeight - 2*m_nBgRadius;
}
else
@@ -708,7 +708,7 @@ void CTextBox::refreshText(void)
if (m_nMode & CENTER)
x_center /= 2;
if (m_nMode & SCROLL)
x_center -= SCROLL_FRAME_WIDTH;
x_center -= m_cFrameScrollRel.iWidth;
}
x_center = std::max(x_center, 0);