X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/e1730a134f0c2f1ca8f4383b62d6c2798d9e567f..f24b1a713e78a462c279c8fcb10e0a1d1b9b9caa:/lib/driver/avswitch.cpp diff --git a/lib/driver/avswitch.cpp b/lib/driver/avswitch.cpp index 0fc53da5..dbfebf5f 100644 --- a/lib/driver/avswitch.cpp +++ b/lib/driver/avswitch.cpp @@ -24,7 +24,7 @@ eAVSwitch::eAVSwitch() } else { - m_fp_notifier = new eSocketNotifier(eApp, m_fp_fd, eSocketNotifier::Read|POLLERR); + m_fp_notifier = eSocketNotifier::create(eApp, m_fp_fd, eSocketNotifier::Read|POLLERR); CONNECT(m_fp_notifier->activated, eAVSwitch::fp_event); } } @@ -46,7 +46,14 @@ int eAVSwitch::getVCRSlowBlanking() int val=0; if (m_fp_fd >= 0) { - if (ioctl(m_fp_fd, FP_IOCTL_GET_VCR, &val) < 0) + FILE *f = fopen("/proc/stb/fp/vcr_fns", "r"); + if (f) + { + if (fscanf(f, "%d", &val) != 1) + eDebug("read /proc/stb/fp/vcr_fns failed!! (%m)"); + fclose(f); + } + else if (ioctl(m_fp_fd, FP_IOCTL_GET_VCR, &val) < 0) eDebug("FP_GET_VCR failed (%m)"); } return val; @@ -61,11 +68,24 @@ void eAVSwitch::fp_event(int what) } else { - int val = FP_EVENT_VCR_SB_CHANGED; // ask only for this event - if (ioctl(m_fp_fd, FP_IOCTL_GET_EVENT, &val) < 0) - eDebug("FP_IOCTL_GET_EVENT failed (%m)"); - else if (val & FP_EVENT_VCR_SB_CHANGED) - /* emit */ vcr_sb_notifier(getVCRSlowBlanking()); + FILE *f = fopen("/proc/stb/fp/events", "r"); + if (f) + { + int events; + if (fscanf(f, "%d", &events) != 1) + eDebug("read /proc/stb/fp/events failed!! (%m)"); + else if (events & FP_EVENT_VCR_SB_CHANGED) + /* emit */ vcr_sb_notifier(getVCRSlowBlanking()); + fclose(f); + } + else + { + int val = FP_EVENT_VCR_SB_CHANGED; // ask only for this event + if (ioctl(m_fp_fd, FP_IOCTL_GET_EVENT, &val) < 0) + eDebug("FP_IOCTL_GET_EVENT failed (%m)"); + else if (val & FP_EVENT_VCR_SB_CHANGED) + /* emit */ vcr_sb_notifier(getVCRSlowBlanking()); + } } } @@ -73,8 +93,6 @@ eAVSwitch::~eAVSwitch() { if ( m_fp_fd >= 0 ) close(m_fp_fd); - if (m_fp_notifier) - delete m_fp_notifier; } eAVSwitch *eAVSwitch::getInstance()