Blame SOURCES/0005-begin-work-on-input-devices.patch

33b0a4
From 691ed58e2838ca3e50e899f013e259ea84f6bfe9 Mon Sep 17 00:00:00 2001
33b0a4
From: Lyonel Vincent <lyonel@ezix.org>
33b0a4
Date: Wed, 1 Apr 2020 00:43:15 +0200
33b0a4
Subject: [PATCH 05/17] begin work on input devices
33b0a4
33b0a4
still missing:
33b0a4
 * capabilities
33b0a4
 * properties
33b0a4
 * report at least as much information as /proc/bus/input/devices
33b0a4
33b0a4
---
33b0a4
 src/core/hw.cc    |   2 +-
33b0a4
 src/core/input.cc | 146 ++++++++++++++++++++++++++++++++++++++++++++++
33b0a4
 src/core/input.h  |   8 +++
33b0a4
 src/core/main.cc  |   4 ++
33b0a4
 4 files changed, 159 insertions(+), 1 deletions(-)
33b0a4
 create mode 100644 src/core/input.cc
33b0a4
 create mode 100644 src/core/input.h
33b0a4
33b0a4
diff --git a/src/core/hw.cc b/src/core/hw.cc
33b0a4
index a59273008862..f7da370816c5 100644
33b0a4
--- a/src/core/hw.cc
33b0a4
+++ b/src/core/hw.cc
33b0a4
@@ -1083,7 +1083,7 @@ void hwNode::setLogicalName(const string & name)
33b0a4
       This->logicalnames.push_back("/dev/" + n);
33b0a4
     }
33b0a4
     else
33b0a4
-      This->logicalnames.push_back(n);
33b0a4
+      This->logicalnames.push_back(basename(n.c_str()));
33b0a4
 
33b0a4
     if(This->dev == "")
33b0a4
       This->dev = get_devid(n);
33b0a4
diff --git a/src/core/input.cc b/src/core/input.cc
33b0a4
new file mode 100644
33b0a4
index 000000000000..1f14fa9d8b56
33b0a4
--- /dev/null
33b0a4
+++ b/src/core/input.cc
33b0a4
@@ -0,0 +1,146 @@
33b0a4
+#include "version.h"
33b0a4
+#include "hw.h"
33b0a4
+#include "sysfs.h"
33b0a4
+#include "osutils.h"
33b0a4
+#include "input.h"
33b0a4
+#include "disk.h"
33b0a4
+#include "heuristics.h"
33b0a4
+
33b0a4
+#include <vector>
33b0a4
+#include <iostream>
33b0a4
+
33b0a4
+__ID("@(#) $Id$");
33b0a4
+
33b0a4
+#define BUS_PCI                 0x01
33b0a4
+#define BUS_ISAPNP              0x02
33b0a4
+#define BUS_USB                 0x03
33b0a4
+#define BUS_HIL                 0x04
33b0a4
+#define BUS_BLUETOOTH           0x05
33b0a4
+#define BUS_VIRTUAL             0x06
33b0a4
+
33b0a4
+#define BUS_ISA                 0x10
33b0a4
+#define BUS_I8042               0x11
33b0a4
+#define BUS_XTKBD               0x12
33b0a4
+#define BUS_RS232               0x13
33b0a4
+#define BUS_GAMEPORT            0x14
33b0a4
+#define BUS_PARPORT             0x15
33b0a4
+#define BUS_AMIGA               0x16
33b0a4
+#define BUS_ADB                 0x17
33b0a4
+#define BUS_I2C                 0x18
33b0a4
+#define BUS_HOST                0x19
33b0a4
+#define BUS_GSC                 0x1A
33b0a4
+#define BUS_ATARI               0x1B
33b0a4
+#define BUS_SPI                 0x1C
33b0a4
+#define BUS_RMI                 0x1D
33b0a4
+#define BUS_CEC                 0x1E
33b0a4
+#define BUS_INTEL_ISHTP         0x1F
33b0a4
+
33b0a4
+using namespace std;
33b0a4
+
33b0a4
+bool scan_input(hwNode & n)
33b0a4
+{
33b0a4
+  vector < sysfs::entry > entries = sysfs::entries_by_class("input");
33b0a4
+
33b0a4
+  if (entries.empty())
33b0a4
+    return false;
33b0a4
+
33b0a4
+  for (vector < sysfs::entry >::iterator it = entries.begin();
33b0a4
+      it != entries.end(); ++it)
33b0a4
+  {
33b0a4
+    const sysfs::entry & e = *it;
33b0a4
+
33b0a4
+    if(!e.hassubdir("id")) continue;
33b0a4
+
33b0a4
+    hwNode *device = n.findChildByBusInfo(e.leaf().businfo());
33b0a4
+    if(!device)
33b0a4
+      device = n.addChild(hwNode("input", hw::input));
33b0a4
+    else
33b0a4
+    {
33b0a4
+      if(device->getClass() == hw::generic)
33b0a4
+        device->setClass(hw::input);
33b0a4
+    }
33b0a4
+    device->claim();
33b0a4
+    device->setLogicalName("input/"+e.name());
33b0a4
+    device->setProduct(e.string_attr("name"));
33b0a4
+    device->setModalias(e.modalias());
33b0a4
+    switch(e.hex_attr("id/bustype"))
33b0a4
+    {
33b0a4
+      case BUS_PCI:
33b0a4
+	      device->addCapability("pci", "PCI");
33b0a4
+	      break;
33b0a4
+      case BUS_ISAPNP:
33b0a4
+	      device->addCapability("isa", "ISA");
33b0a4
+	      device->addCapability("pnp", "PnP");
33b0a4
+	      break;
33b0a4
+      case BUS_USB:
33b0a4
+	      device->addCapability("usb", "USB");
33b0a4
+	      break;
33b0a4
+      case BUS_HIL:
33b0a4
+	      device->addCapability("hil", "HP-HIL");
33b0a4
+	      break;
33b0a4
+      case BUS_BLUETOOTH:
33b0a4
+	      device->addCapability("bt", "Bluetooth");
33b0a4
+	      break;
33b0a4
+      case BUS_VIRTUAL:
33b0a4
+	      device->addCapability("virtual");
33b0a4
+	      break;
33b0a4
+      case BUS_ISA:
33b0a4
+	      device->addCapability("isa", "ISA bus");
33b0a4
+	      break;
33b0a4
+      case BUS_I8042:
33b0a4
+	      device->addCapability("i8042", "i8042 PC AT keyboard controller");
33b0a4
+	      break;
33b0a4
+      case BUS_XTKBD:
33b0a4
+	      device->addCapability("xtkbd", "XT keyboard controller");
33b0a4
+	      break;
33b0a4
+      case BUS_RS232:
33b0a4
+	      device->addCapability("rs232", "RS-232 serial");
33b0a4
+	      break;
33b0a4
+      case BUS_GAMEPORT:
33b0a4
+	      device->addCapability("gameport", "game port");
33b0a4
+	      break;
33b0a4
+      case BUS_PARPORT:
33b0a4
+	      device->addCapability("parport", "parallel port");
33b0a4
+	      break;
33b0a4
+      case BUS_AMIGA:
33b0a4
+	      device->addCapability("amiga", "Amiga bus");
33b0a4
+	      break;
33b0a4
+      case BUS_ADB:
33b0a4
+	      device->addCapability("adb", "Apple Desktop Bus");
33b0a4
+	      break;
33b0a4
+      case BUS_I2C:
33b0a4
+	      device->addCapability("i2c", "I²C bus");
33b0a4
+	      break;
33b0a4
+      case BUS_HOST:
33b0a4
+	      device->addCapability("host");
33b0a4
+	      break;
33b0a4
+      case BUS_GSC:
33b0a4
+	      device->addCapability("gsc", "GSC bus");
33b0a4
+	      break;
33b0a4
+      case BUS_ATARI:
33b0a4
+	      device->addCapability("atari", "Atari bus");
33b0a4
+	      break;
33b0a4
+      case BUS_SPI:
33b0a4
+	      device->addCapability("spi", "SPI");
33b0a4
+	      break;
33b0a4
+      case BUS_RMI:
33b0a4
+	      device->addCapability("rmi", "RMI");
33b0a4
+	      break;
33b0a4
+      case BUS_CEC:
33b0a4
+	      device->addCapability("cec", "CEC");
33b0a4
+	      break;
33b0a4
+      case BUS_INTEL_ISHTP:
33b0a4
+	      device->addCapability("intelishtp", "Intel Integrated Sensor Hub");
33b0a4
+	      break;
33b0a4
+    }
33b0a4
+
33b0a4
+    vector < sysfs::entry > events = e.devices();
33b0a4
+    for(vector < sysfs::entry >::iterator i = events.begin(); i != events.end(); ++i)
33b0a4
+    {
33b0a4
+      const sysfs::entry & d = *i;
33b0a4
+      device->setLogicalName("input/"+d.name());
33b0a4
+    }
33b0a4
+  }
33b0a4
+
33b0a4
+  return true;
33b0a4
+}
33b0a4
diff --git a/src/core/input.h b/src/core/input.h
33b0a4
new file mode 100644
33b0a4
index 000000000000..1bf2383bc53b
33b0a4
--- /dev/null
33b0a4
+++ b/src/core/input.h
33b0a4
@@ -0,0 +1,8 @@
33b0a4
+#ifndef _INPUT_H_
33b0a4
+#define _INPUT_H_
33b0a4
+
33b0a4
+#include "hw.h"
33b0a4
+
33b0a4
+bool scan_input(hwNode &);
33b0a4
+
33b0a4
+#endif
33b0a4
diff --git a/src/core/main.cc b/src/core/main.cc
33b0a4
index d0d7f1057c29..ad0e586ef549 100644
33b0a4
--- a/src/core/main.cc
33b0a4
+++ b/src/core/main.cc
33b0a4
@@ -45,6 +45,7 @@
33b0a4
 #include "vio.h"
33b0a4
 #include "nvme.h"
33b0a4
 #include "mmc.h"
33b0a4
+#include "input.h"
33b0a4
 #include "smp.h"
33b0a4
 #include "abi.h"
33b0a4
 #include "s390.h"
33b0a4
@@ -140,6 +141,9 @@ bool scan_system(hwNode & system)
33b0a4
     status("MMC");
33b0a4
     if (enabled("mmc"))
33b0a4
       scan_mmc(computer);
33b0a4
+    status("input");
33b0a4
+    if (enabled("input"))
33b0a4
+      scan_input(computer);
33b0a4
     status("S/390 devices");
33b0a4
     if (enabled("s390"))
33b0a4
       scan_s390_devices(computer);
33b0a4
-- 
33b0a4
2.17.1
33b0a4