Switch pointer gadget to non-blocking
Writes to the pointer gadget can hang if the host has no cursor. Using
non-blocking mode prevents this hanging. Also prevent repeated error
logging due to pointer write failures in this case.
Change-Id: I9c423a4a0af4b37a69ae20650b86a6266e5b4b41
Signed-off-by: Eddie James <eajames@linux.ibm.com>
diff --git a/ikvm_input.cpp b/ikvm_input.cpp
index fbe917b..202b761 100644
--- a/ikvm_input.cpp
+++ b/ikvm_input.cpp
@@ -23,6 +23,7 @@
using namespace sdbusplus::xyz::openbmc_project::Common::File::Error;
Input::Input(const std::string& kbdPath, const std::string& ptrPath) :
+ pointerError(false), sendKeyboard(false), sendPointer(false),
keyboardFd(-1), pointerFd(-1), keyboardReport{0}, pointerReport{0},
keyboardPath(kbdPath), pointerPath(ptrPath)
{
@@ -42,7 +43,7 @@
if (!pointerPath.empty())
{
- pointerFd = open(pointerPath.c_str(), O_RDWR | O_CLOEXEC);
+ pointerFd = open(pointerPath.c_str(), O_RDWR | O_CLOEXEC | O_NONBLOCK);
if (pointerFd < 0)
{
log<level::ERR>("Failed to open input device",
@@ -218,8 +219,12 @@
if (write(pointerFd, pointerReport, PTR_REPORT_LENGTH) !=
PTR_REPORT_LENGTH)
{
- log<level::ERR>("Failed to write pointer report",
- entry("ERROR=%s", strerror(errno)));
+ if (!pointerError)
+ {
+ log<level::ERR>("Failed to write pointer report",
+ entry("ERROR=%s", strerror(errno)));
+ pointerError = true;
+ }
}
sendPointer = false;
diff --git a/ikvm_input.hpp b/ikvm_input.hpp
index f7413a4..394591c 100644
--- a/ikvm_input.hpp
+++ b/ikvm_input.hpp
@@ -85,6 +85,8 @@
*/
static uint8_t keyToScancode(rfbKeySym key);
+ /* @brief Indicates whether or not a pointer report error has occurred */
+ bool pointerError;
/* @brief Indicates whether or not to send a keyboard report */
bool sendKeyboard;
/* @brief Indicates whether or not to send a pointer report */