Browse Source

more or less working

master
Robin Thoni 9 years ago
parent
commit
fcbc9590fa
4 changed files with 35 additions and 37 deletions
  1. 4
    8
      UsbRawHid.h
  2. 27
    28
      UsbRawHid.hxx
  3. 3
    0
      examples/UsbRawHidDemo1/main.ino
  4. 1
    1
      usbconfig.h

+ 4
- 8
UsbRawHid.h View File

@@ -25,14 +25,8 @@ typedef uint8_t byte;
25 25
   }                             \
26 26
 } while(0)
27 27
 
28
-#define BUFFER_SIZE 4 // Minimum of 2: 1 for modifiers + 1 for keystroke 
28
+#define BUFFER_SIZE 64
29 29
 
30
-typedef struct{
31
-    uchar   buttonMask;
32
-    char    dx;
33
-    char    dy;
34
-    char    dWheel;
35
-}report_t;
36 30
 
37 31
 static uchar    idleRate;/* repeat rate for keyboards, never used for mice */
38 32
 
@@ -45,9 +39,11 @@ public:
45 39
     void update() {
46 40
         usbPoll();
47 41
     }
42
+
43
+    void sendData(const char* data, unsigned size = 0);
48 44
     
49 45
     //private: TODO: Make friend?
50
-    report_t reportBuffer;    // buffer for HID reports [ 1 modifier byte + (len-1) key strokes]
46
+    byte reportBuffer[BUFFER_SIZE];    // buffer for HID reports [ 1 modifier byte + (len-1) key strokes]
51 47
 
52 48
 private:
53 49
 

+ 27
- 28
UsbRawHid.hxx View File

@@ -13,34 +13,20 @@ UsbRawHidDevice UsbRawHid = UsbRawHidDevice();
13 13
  * Redundant entries (such as LOGICAL_MINIMUM and USAGE_PAGE) have been omitted
14 14
  * for the second INPUT item.
15 15
  */
16
-PROGMEM const char usbHidReportDescriptor[52] = { /* USB report descriptor, size must match usbconfig.h */
17
-        0x05, 0x01,                    // USAGE_PAGE (Generic Desktop)
18
-        0x09, 0x02,                    // USAGE (Mouse)
19
-        0xa1, 0x01,                    // COLLECTION (Application)
20
-        0x09, 0x01,                    //   USAGE (Pointer)
21
-        0xA1, 0x00,                    //   COLLECTION (Physical)
22
-        0x05, 0x09,                    //     USAGE_PAGE (Button)
23
-        0x19, 0x01,                    //     USAGE_MINIMUM
24
-        0x29, 0x03,                    //     USAGE_MAXIMUM
25
-        0x15, 0x00,                    //     LOGICAL_MINIMUM (0)
26
-        0x25, 0x01,                    //     LOGICAL_MAXIMUM (1)
27
-        0x95, 0x03,                    //     REPORT_COUNT (3)
28
-        0x75, 0x01,                    //     REPORT_SIZE (1)
29
-        0x81, 0x02,                    //     INPUT (Data,Var,Abs)
30
-        0x95, 0x01,                    //     REPORT_COUNT (1)
31
-        0x75, 0x05,                    //     REPORT_SIZE (5)
32
-        0x81, 0x03,                    //     INPUT (Const,Var,Abs)
33
-        0x05, 0x01,                    //     USAGE_PAGE (Generic Desktop)
34
-        0x09, 0x30,                    //     USAGE (X)
35
-        0x09, 0x31,                    //     USAGE (Y)
36
-        0x09, 0x38,                    //     USAGE (Wheel)
37
-        0x15, 0x81,                    //     LOGICAL_MINIMUM (-127)
38
-        0x25, 0x7F,                    //     LOGICAL_MAXIMUM (127)
39
-        0x75, 0x08,                    //     REPORT_SIZE (8)
40
-        0x95, 0x03,                    //     REPORT_COUNT (3)
41
-        0x81, 0x06,                    //     INPUT (Data,Var,Rel)
42
-        0xC0,                          //   END_COLLECTION
43
-        0xC0,                          // END COLLECTION
16
+PROGMEM const char usbHidReportDescriptor[32] = {
17
+        0x06, 0x42, 0xff,
18
+        0x0A, 0x42, 0xff,
19
+        0xA1, 0x01,				// Collection 0x01
20
+        0x75, 0x08,				// report size = 8 bits
21
+        0x15, 0x00,				// logical minimum = 0
22
+        0x26, 0xFF, 0x00,			// logical maximum = 255
23
+        0x95, RAWHID_TX_SIZE,			// report count
24
+        0x09, 0x01,				// usage
25
+        0x81, 0x02,				// Input (array)
26
+        0x95, RAWHID_RX_SIZE,			// report count
27
+        0x09, 0x02,				// usage
28
+        0x91, 0x02,				// Output (array)
29
+        0xC0					// end collection
44 30
 };
45 31
 
46 32
 UsbRawHidDevice::UsbRawHidDevice()
@@ -53,6 +39,7 @@ UsbRawHidDevice::UsbRawHidDevice()
53 39
     usbDeviceConnect();
54 40
     usbInit();
55 41
     sei();
42
+    //sendData("", 0);
56 43
 }
57 44
 
58 45
 bool UsbRawHidDevice::isUsbReady()
@@ -61,6 +48,18 @@ bool UsbRawHidDevice::isUsbReady()
61 48
     return usbInterruptIsReady();
62 49
 }
63 50
 
51
+void UsbRawHidDevice::sendData(const char* data, unsigned size)
52
+{
53
+    if (size > RAWHID_TX_SIZE || size == 0)
54
+    {
55
+        size = RAWHID_TX_SIZE;
56
+    }
57
+    memcpy(reportBuffer, data, size);
58
+    memset(reportBuffer + size, 0, RAWHID_TX_SIZE - size);
59
+
60
+    usbSetInterrupt((unsigned char*)(void *)&reportBuffer, sizeof(reportBuffer));
61
+}
62
+
64 63
 usbMsgLen_t usbFunctionSetup(uchar data[8])
65 64
 {
66 65
     usbRequest_t    *rq = (usbRequest_t*)(void*)data;

+ 3
- 0
examples/UsbRawHidDemo1/main.ino View File

@@ -1,6 +1,8 @@
1 1
 #define ARD_UTILS_DELAYMS
2 2
 #include "ArdUtils/ArdUtils.h"
3 3
 
4
+#define RAWHID_TX_SIZE       64
5
+#define RAWHID_RX_SIZE       64
4 6
 #include "UsbRawHid.h"
5 7
 
6 8
 #define ledPin 13
@@ -15,6 +17,7 @@ void loop()
15 17
 {
16 18
     WAIT_USB;
17 19
 
20
+    //UsbRawHid.sendData("test", 4);
18 21
 
19 22
     ArdUtils::delayMs(1000);
20 23
     digitalWrite(ledPin, !digitalRead(ledPin));

+ 1
- 1
usbconfig.h View File

@@ -273,7 +273,7 @@ section at the end of this file).
273 273
  * HID class is 3, no subclass and protocol required (but may be useful!)
274 274
  * CDC class is 2, use subclass 2 and protocol 1 for ACM
275 275
  */
276
-#define USB_CFG_HID_REPORT_DESCRIPTOR_LENGTH    52
276
+#define USB_CFG_HID_REPORT_DESCRIPTOR_LENGTH    32
277 277
 /* Define this to the length of the HID report descriptor, if you implement
278 278
  * an HID device. Otherwise don't define it or define it to 0.
279 279
  * If you use this define, you must add a PROGMEM character array named

Loading…
Cancel
Save