1
0
Fork 0
Signed-off-by: fly <merspieler@alwaysdata.com>
This commit is contained in:
fly 2024-04-11 02:31:40 +02:00
parent e0449c9ac8
commit e8774ca450
2 changed files with 37 additions and 37 deletions

View file

@ -22,11 +22,11 @@ pub const CUSTOM_DESCRIPTOR: &[u8] = &[
0x09, 0x01, // UsageId(Pointer[0x0001]) 0x09, 0x01, // UsageId(Pointer[0x0001])
0xA1, 0x00, // Collection(Physical) 0xA1, 0x00, // Collection(Physical)
0x09, 0x30, // UsageId(X[0x0030]) 0x09, 0x30, // UsageId(X[0x0030])
0x09, 0x31, // UsageId(Y[0x0031]) 0x09, 0x32, // UsageId(Z[0x0032])
0x15, 0x00, // LogicalMinimum(0) 0x15, 0x00, // LogicalMinimum(0)
0x27, 0xFF, 0xFF, 0x00, 0x00, // LogicalMaximum(65,535) 0x26, 0xFF, 0x0F, // LogicalMaximum(4,095)
0x95, 0x02, // ReportCount(2) 0x95, 0x02, // ReportCount(2)
0x75, 0x10, // ReportSize(16) 0x75, 0x0C, // ReportSize(12)
0x81, 0x02, // Input(Data, Variable, Absolute, NoWrap, Linear, PreferredState, NoNullPosition, BitField) 0x81, 0x02, // Input(Data, Variable, Absolute, NoWrap, Linear, PreferredState, NoNullPosition, BitField)
0xC0, // EndCollection() 0xC0, // EndCollection()
0x05, 0x09, // UsagePage(Button[0x0009]) 0x05, 0x09, // UsagePage(Button[0x0009])
@ -46,14 +46,14 @@ pub const CUSTOM_DESCRIPTOR: &[u8] = &[
]; ];
#[derive(Clone, Copy, Debug, Eq, PartialEq, Default, PackedStruct)] #[derive(Clone, Copy, Debug, Eq, PartialEq, Default, PackedStruct)]
#[packed_struct(endian = "lsb", size_bytes = "5")] #[packed_struct(endian = "lsb", size_bytes = "6")]
pub struct CustomInputReport { pub struct CustomInputReport {
#[packed_field]
pub y: u16,
#[packed_field]
pub x: u16,
#[packed_field] #[packed_field]
pub buttons: u16, pub buttons: u16,
#[packed_field]
pub y: Integer<i16, packed_bits::Bits<12>>,
#[packed_field]
pub x: Integer<i16, packed_bits::Bits<12>>,
} }
#[derive(Clone, Copy, Debug, Eq, PartialEq, Default, PackedStruct)] #[derive(Clone, Copy, Debug, Eq, PartialEq, Default, PackedStruct)]

View file

@ -96,7 +96,7 @@ fn main() -> ! {
loop { loop {
let report = get_report(&mut input_pins, &mut adc1); let report = get_report(&mut input_pins, &mut adc1);
// if report != last { if report != last {
match consumer.device().write_report(&report) { match consumer.device().write_report(&report) {
Err(UsbHidError::WouldBlock) => {} Err(UsbHidError::WouldBlock) => {}
Ok(_) => { Ok(_) => {
@ -106,7 +106,7 @@ fn main() -> ! {
core::panic!("Failed to write consumer report: {:?}", e) core::panic!("Failed to write consumer report: {:?}", e)
} }
} }
// } }
if usb_dev.poll(&mut [&mut consumer]) { if usb_dev.poll(&mut [&mut consumer]) {
match consumer.device().read_report() { match consumer.device().read_report() {
@ -131,14 +131,14 @@ fn main() -> ! {
fn get_report(pins: &mut MyPins, adc1: &mut adc::Adc<pac::ADC1>) -> CustomInputReport { fn get_report(pins: &mut MyPins, adc1: &mut adc::Adc<pac::ADC1>) -> CustomInputReport {
let integLT: u16 = adc1.read(&mut pins.pa1).unwrap(); let integLT: u16 = adc1.read(&mut pins.pa1).unwrap();
let floodLT: u16 = adc1.read(&mut pins.pa2).unwrap(); let floodLT: u16 = adc1.read(&mut pins.pa2).unwrap();
let retX = (integLT / 4) as i16; let retX = integLT as i16;
let retY = floodLT as i16; let retY = floodLT as i16;
let buttons: u16 = 0; let buttons: u16 = 0;
CustomInputReport { CustomInputReport {
x: retX.into(), x: floodLT.into(),
y: retY.into(), y: floodLT.into(),
buttons, buttons,
} }
} }