Improved service.
This commit is contained in:
@@ -1 +0,0 @@
|
|||||||
/usr/bin/isticktoit_usb
|
|
||||||
2
Makefile
2
Makefile
@@ -15,7 +15,7 @@ U2FDevice: $(OBJECTS) libuECC.o libcppb64.o
|
|||||||
|
|
||||||
install: U2FDevice
|
install: U2FDevice
|
||||||
install -m775 -t /usr/bin U2FDevice
|
install -m775 -t /usr/bin U2FDevice
|
||||||
install -m775 -t /etc/systemd/system U2FDevice.service
|
install -m775 -t /etc/systemd/system Services/U2FDevice.service
|
||||||
install -d /usr/share/U2FDevice/
|
install -d /usr/share/U2FDevice/
|
||||||
|
|
||||||
$(OBJ_DIR)/%.o: $(SRC_DIR)/%.cpp
|
$(OBJ_DIR)/%.o: $(SRC_DIR)/%.cpp
|
||||||
|
|||||||
13
Readme.txt
13
Readme.txt
@@ -1,13 +1,22 @@
|
|||||||
|
To make HID work
|
||||||
|
|
||||||
|
sudo install -m755 Scripts/Kernel_HID_Config.sh /usr/bin/Kernel_HID_Config.sh
|
||||||
|
sudoedit /etc/rc.local # Add '/usr/bin/Kernel_HID_Config.sh' on a new line before 'exit 0'
|
||||||
|
|
||||||
Things to install
|
Things to install
|
||||||
|
|
||||||
//To provide HW RNG facilities
|
To provide HW RNG facilities
|
||||||
|
|
||||||
sudo apt-get install rng-tools
|
sudo apt-get install rng-tools
|
||||||
|
|
||||||
//To provide ECC facilities
|
To provide ECC facilities
|
||||||
|
|
||||||
git submodule update --init --recursive
|
git submodule update --init --recursive
|
||||||
cp Scripts/uECC-Makefile micro-ecc/Makefile
|
cp Scripts/uECC-Makefile micro-ecc/Makefile
|
||||||
cp Scripts/cpp-base64-Makefile cpp-base64/Makefile
|
cp Scripts/cpp-base64-Makefile cpp-base64/Makefile
|
||||||
|
|
||||||
|
To change the Attestation certificate, see the Attestation readme
|
||||||
|
|
||||||
To build
|
To build
|
||||||
|
|
||||||
make
|
make
|
||||||
|
|||||||
68
Scripts/Kernel_HID_Config.sh
Executable file
68
Scripts/Kernel_HID_Config.sh
Executable file
@@ -0,0 +1,68 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Directly from http://isticktoit.net/?p=1383
|
||||||
|
|
||||||
|
# Load libcomposite
|
||||||
|
modprobe libcomposite
|
||||||
|
|
||||||
|
cd /sys/kernel/config/usb_gadget/
|
||||||
|
|
||||||
|
# Create gadget
|
||||||
|
mkdir -p /sys/kernel/config/usb_gadget/hidraw
|
||||||
|
cd /sys/kernel/config/usb_gadget/hidraw
|
||||||
|
|
||||||
|
# Add basic information
|
||||||
|
echo 0x0100 > bcdDevice # Version 1.0.0
|
||||||
|
echo 0x0200 > bcdUSB # USB 2.0
|
||||||
|
|
||||||
|
# For this part, used the Linux idVendor
|
||||||
|
# Of course, no official spec for Raspberry Pi 0 acting as U2F device, so self defined product here we go
|
||||||
|
echo 0x1d6b > idVendor # Linux Foundation
|
||||||
|
echo 0x0400 > idProduct # Self defined U2F device
|
||||||
|
|
||||||
|
echo 0x0000 > bDeviceClass # RAW HID?
|
||||||
|
echo 0x0000 > bDeviceSubClass #
|
||||||
|
echo 0x0040 > bMaxPacketSize0 # Max Packet Size
|
||||||
|
|
||||||
|
# Create English locale
|
||||||
|
mkdir -p strings/0x409
|
||||||
|
|
||||||
|
# Obviously, feel free to change these however you want
|
||||||
|
echo "Michael Kuc" > strings/0x409/manufacturer
|
||||||
|
echo "Raspberry U2f" > strings/0x409/product
|
||||||
|
echo "0123456789" > strings/0x409/serialnumber
|
||||||
|
|
||||||
|
# Create HIDRAW function
|
||||||
|
mkdir -p functions/hid.usb0
|
||||||
|
|
||||||
|
echo 0 > functions/hid.usb0/protocol
|
||||||
|
echo 8 > functions/hid.usb0/report_length
|
||||||
|
echo 1 > functions/hid.usb0/subclass
|
||||||
|
printf '\x06\xD0\xF1\x09\x01\xA1\x01\x09\x20\x15\x00\x26\xFF\x00\x75\x08\x95\x40\x81\x02\x09\x21\x15\x00\x26\xFF\x00\x75\x08\x95\x40\x91\x02\xC0' > functions/hid.usb0/report_desc
|
||||||
|
|
||||||
|
# Create ECM function
|
||||||
|
mkdir -p functions/ecm.usb0
|
||||||
|
|
||||||
|
# An attempt at keeping addresses constant
|
||||||
|
echo "DD:03:52:23:18:4C" > functions/ecm.usb0/host_addr
|
||||||
|
echo "62:30:54:93:06:DE" > functions/ecm.usb0/dev_addr
|
||||||
|
|
||||||
|
# Create configuration
|
||||||
|
mkdir -p configs/c.1
|
||||||
|
mkdir -p configs/c.1/strings/0x409
|
||||||
|
|
||||||
|
echo 0x80 > configs/c.1/bmAttributes
|
||||||
|
echo 200 > configs/c.1/MaxPower
|
||||||
|
echo "HIDRAW" > configs/c.1/strings/0x409/configuration
|
||||||
|
|
||||||
|
# Link HID function to configuration
|
||||||
|
ln -s functions/hid.usb0 configs/c.1
|
||||||
|
|
||||||
|
# Link g_ether function to configuration
|
||||||
|
ln -s functions/ecm.usb0 configs/c.1
|
||||||
|
|
||||||
|
# Sleep for 1 second
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
# Enable gadget
|
||||||
|
ls /sys/class/udc > UDC
|
||||||
Reference in New Issue
Block a user