X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/75b5dff4878843dec6913364bc044ab25c3b78a2..90518479f5cf86c713702cc78e2af583b0234676:/lib/driver/avswitch.cpp diff --git a/lib/driver/avswitch.cpp b/lib/driver/avswitch.cpp index d582db81..0fc53da5 100644 --- a/lib/driver/avswitch.cpp +++ b/lib/driver/avswitch.cpp @@ -1,6 +1,7 @@ #include #include #include +#include #include #include @@ -81,6 +82,19 @@ eAVSwitch *eAVSwitch::getInstance() return instance; } +bool eAVSwitch::haveScartSwitch() +{ + char tmp[255]; + int fd = open("/proc/stb/avs/0/input_choices", O_RDONLY); + if(fd < 0) { + eDebug("cannot open /proc/stb/avs/0/input_choices"); + return false; + } + read(fd, tmp, 255); + close(fd); + return !!strstr(tmp, "scart"); +} + void eAVSwitch::setInput(int val) { /* @@ -89,7 +103,7 @@ void eAVSwitch::setInput(int val) 2-aux */ - char *input[] = {"encoder", "scart", "aux"}; + const char *input[] = {"encoder", "scart", "aux"}; int fd; @@ -108,7 +122,7 @@ void eAVSwitch::setInput(int val) void eAVSwitch::setFastBlank(int val) { int fd; - char *fb[] = {"low", "high", "vcr"}; + const char *fb[] = {"low", "high", "vcr"}; if((fd = open("/proc/stb/avs/0/fb", O_WRONLY)) < 0) { eDebug("cannot open /proc/stb/avs/0/fb"); @@ -126,10 +140,10 @@ void eAVSwitch::setColorFormat(int format) 1-RGB 2-S-Video */ - char *cvbs="cvbs"; - char *rgb="rgb"; - char *svideo="svideo"; - char *yuv="yuv"; + const char *cvbs="cvbs"; + const char *rgb="rgb"; + const char *svideo="svideo"; + const char *yuv="yuv"; int fd; if((fd = open("/proc/stb/avs/0/colorformat", O_WRONLY)) < 0) { @@ -164,8 +178,8 @@ void eAVSwitch::setAspectRatio(int ratio) 5-16:10 PanScan 6-16:9 forced ("letterbox") */ - char *aspect[] = {"4:3", "4:3", "any", "16:9", "16:10", "16:10", "16:9", "16:9"}; - char *policy[] = {"letterbox", "panscan", "bestfit", "panscan", "letterbox", "panscan", "letterbox"}; + const char *aspect[] = {"4:3", "4:3", "any", "16:9", "16:10", "16:10", "16:9", "16:9"}; + const char *policy[] = {"letterbox", "panscan", "bestfit", "panscan", "letterbox", "panscan", "letterbox"}; int fd; if((fd = open("/proc/stb/video/aspect", O_WRONLY)) < 0) { @@ -188,8 +202,8 @@ void eAVSwitch::setAspectRatio(int ratio) void eAVSwitch::setVideomode(int mode) { - char *pal="pal"; - char *ntsc="ntsc"; + const char *pal="pal"; + const char *ntsc="ntsc"; if (mode == m_video_mode) return; @@ -242,7 +256,7 @@ void eAVSwitch::setWSS(int val) // 0 = auto, 1 = auto(4:3_off) eDebug("cannot open /proc/stb/denc/0/wss"); return; } - char *wss[] = { + const char *wss[] = { "off", "auto", "auto(4:3_off)", "4:3_full_format", "16:9_full_format", "14:9_letterbox_center", "14:9_letterbox_top", "16:9_letterbox_center", "16:9_letterbox_top", ">16:9_letterbox_center", "14:9_full_format" @@ -259,7 +273,7 @@ void eAVSwitch::setSlowblank(int val) eDebug("cannot open /proc/stb/avs/0/sb"); return; } - char *sb[] = {"0", "6", "12", "vcr", "auto"}; + const char *sb[] = {"0", "6", "12", "vcr", "auto"}; write(fd, sb[val], strlen(sb[val])); // eDebug("set slow blanking to %s", sb[val]); close(fd);