diff options
author | tmk <nobody@nowhere> | 2012-12-05 13:38:16 +0900 |
---|---|---|
committer | tmk <nobody@nowhere> | 2013-04-09 14:27:29 +0900 |
commit | 9bdd89980f9d377304f79db5d36b19a8536edfd0 (patch) | |
tree | 81ede7ec75d29dfc2a947b092b81d3390cf13fad | |
parent | de7b46cd7db2928d342a0c3e06f03c19e96f984b (diff) | |
download | qmk_firmware-9bdd89980f9d377304f79db5d36b19a8536edfd0.tar.gz qmk_firmware-9bdd89980f9d377304f79db5d36b19a8536edfd0.zip |
Fix comment of ADB signaling.
-rw-r--r-- | protocol/adb.c | 54 |
1 files changed, 39 insertions, 15 deletions
diff --git a/protocol/adb.c b/protocol/adb.c index 9e8d76832d..a92e81f1f6 100644 --- a/protocol/adb.c +++ b/protocol/adb.c @@ -199,24 +199,48 @@ static inline bool read_bit(void) { // ADB Bit Cells // - // bit0: ______~~~ - // 65 :35us + // bit cell time: 70-130us + // low part of bit0: 60-70% of bit cell + // low part of bit1: 30-40% of bit cell // - // bit1: ___~~~~~~ - // 35 :65us + // bit cell time 70us 130us + // -------------------------------------------- + // low part of bit0 42-49 78-91 + // high part of bit0 21-28 39-52 + // low part of bit1 21-28 39-52 + // high part of bit1 42-49 78-91 // - // bit0 low time: 60-70% of bit cell(42-91us) - // bit1 low time: 30-40% of bit cell(21-52us) - // bit cell time: 70-130us - // [from Apple IIgs Hardware Reference Second Edition] // - // After 55us if data line is low/high then bit is 0/1. - // Too simple to rely on? + // bit0: + // 70us bit cell: + // ____________~~~~~~ + // 42-49 21-28 + // + // 130us bit cell: + // ____________~~~~~~ + // 78-91 39-52 + // + // bit1: + // 70us bit cell: + // ______~~~~~~~~~~~~ + // 21-28 42-49 + // + // 130us bit cell: + // ______~~~~~~~~~~~~ + // 39-52 78-91 + // + // read: + // ________|~~~~~~~~~ + // 55us + // Read data line after 55us. If data line is low/high then bit is 0/1. + // This method might not work at <90us bit cell time. + // + // [from Apple IIgs Hardware Reference Second Edition] bool bit; - wait_data_lo(75); // wait the beginning of bit cell + wait_data_lo(75); // wait the start of bit cell at least 130ms(55+0+75) _delay_us(55); bit = data_in(); - wait_data_hi(36); // wait high part of bit cell + wait_data_hi(36); // wait high part of bit cell at least 91ms(55+36) return bit; } @@ -258,7 +282,7 @@ Resources --------- ADB - The Untold Story: Space Aliens Ate My Mouse http://developer.apple.com/legacy/mac/library/#technotes/hw/hw_01.html -Apple IIgs Hardware Reference Second Edition [p80(Chapter6 p121)] +Apple IIgs Hardware Reference Second Edition [Chapter6 p121] ftp://ftp.apple.asimov.net/pub/apple_II/documentation/Apple%20IIgs%20Hardware%20Reference.pdf ADB Keycode http://72.0.193.250/Documentation/macppc/adbkeycodes/ @@ -376,9 +400,9 @@ Communication Global reset: Host asserts low in 2.8-5.2ms. All devices are forced to reset. - Send request from device(Srq): + Service request from device(Srq): Device can request to send at commad(Global only?) stop bit. - keep low for 300us to request. + Requesting device keeps low for 140-260us at stop bit of command. Keyboard Data(Register0) |