-
Notifications
You must be signed in to change notification settings - Fork 2
Home
This is being tested with:
- Mac & Linux hosts (should be fine on anything that will take libusb)
- PCLK-MN10 (should be at least partly compatible with PCLK-MN10a and PCLK-MN20 but I have no way of knowing)
- DHC-MD595 (should be compatible with anything that the above plug into but, again, I have no way of knowing)
- Windows 2000(!) VM + M-Crew
- success! even though none of the installers seemed to work.
- usb sniffing
- success! here are the raw usb logs and here are all the output commands
- some fiddling with pyUSB (because why not)
- success! we have limited device control.
- mapping functions, etc.
- ...
- profit? (lawyers: I'm joking)
There is bound to be a more intelligent way to do most of this stuff but I'm just stumbling around for fun.
The tutorial boilerplate seems to work...
DEVICE ID 054c:0034 on Bus 020 Address 012 =================
bLength : 0x12 (18 bytes)
bDescriptorType : 0x1 Device
bcdUSB : 0x110 USB 1.1
bDeviceClass : 0xff Vendor-specific
bDeviceSubClass : 0x0
bDeviceProtocol : 0x0
bMaxPacketSize0 : 0x40 (64 bytes)
idVendor : 0x054c
idProduct : 0x0034
bcdDevice : 0x100 Device 1.0
iManufacturer : 0x1 xxxx
iProduct : 0x2 PCLK-MN10
iSerialNumber : 0x0
bNumConfigurations : 0x1
CONFIGURATION 1: 100 mA ==================================
bLength : 0x9 (9 bytes)
bDescriptorType : 0x2 Configuration
wTotalLength : 0x20 (32 bytes)
bNumInterfaces : 0x1
bConfigurationValue : 0x1
iConfiguration : 0x2 PCLK-MN10
bmAttributes : 0x80 Bus Powered
bMaxPower : 0x32 (100 mA)
INTERFACE 0: Reserved ==================================
bLength : 0x9 (9 bytes)
bDescriptorType : 0x4 Interface
bInterfaceNumber : 0x0
bAlternateSetting : 0x0
bNumEndpoints : 0x2
bInterfaceClass : 0x0 Reserved
bInterfaceSubClass : 0x0
bInterfaceProtocol : 0x0
iInterface : 0x0
ENDPOINT 0x1: Bulk OUT ===============================
bLength : 0x7 (7 bytes)
bDescriptorType : 0x5 Endpoint
bEndpointAddress : 0x1 OUT
bmAttributes : 0x2 Bulk
wMaxPacketSize : 0x40 (64 bytes)
bInterval : 0x0
ENDPOINT 0x82: Bulk IN ===============================
bLength : 0x7 (7 bytes)
bDescriptorType : 0x5 Endpoint
bEndpointAddress : 0x82 IN
bmAttributes : 0x2 Bulk
wMaxPacketSize : 0x40 (64 bytes)
bInterval : 0x0
Some random commands that I sniffed seem to work when replayed:
write(0x00,0x60,0x00), read()
turns it on!
write([0x04,0x00,0x60,0xc0,0x2f]), read()
write([0x04,0x00,0x60,0x90,0x26]), read()
write([0x04,0x00,0x60,0xb0,0x26]), read()
(no more, no less) turns it off... is it mere coincidence that ASCII 0x4F, 0x46, 0x46 would read 'OFF'?
Output data from repeated read() seems at times almost completely random (though the first int clearly contains the message length) but it does have something to do with the state of the hifi device behind the link; the message length increases significantly I fiddle with the controls. I captured some output but lost the full log.
Lots more to discover. I can't get it to do anything else yet (source switching would be a good next win), but I've barely tried.
Looks like they made a PCLK-MN10a and a PCLK-MN20 using supersets of the MN10's functionality. So I assume these should work with the same USB commands, but I have no way of knowing.
- http://web.archive.org/web/20151127003611/http://benoit.papillault.free.fr/usbsnoop/
- https://github.com/walac/pyusb/blob/master/docs/tutorial.rst#id8
- https://learn.adafruit.com/hacking-the-kinect/command-number-1-and-2-led-blinky
I find it hard to believe nobody's been here before me. If I'm really lucky the PCLK-MN10 simply passes data through to the underlying device using a variant of one of their existing protocols which others have investigated in detail before, e.g. S-Link described by http://www.brian-patti.com/s-link/CAVuser.htm http://www.edcheung.com/automa/sircs.htm and http://www.armory.com/~spcecdt/remote/control-S.html, but there's lots more reading to be done...