-
-
Notifications
You must be signed in to change notification settings - Fork 39.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update pmw3360 driver after reading the datasheet top to bottom. Fix some outdated refs. #15682
Conversation
We should de-assert NCS after waiting for tSCLK-NCS, so move spi_stop() around a little. This was missed in PR#11519. I'm less certain about adding the (quite long) tSRAD delay, but the datasheet clearly indicates so. Not sure how this worked before, but we don't actually use the read function, but read_burst instead. Only the init phase and get_cpi() would be affected, and no one uses get_cpi, only set_cpi, of course. Also use the more natual spi_read() to discard the observation data, this also saves 2 bytes in the firmware :) Remove references to the no longer existing pmw_set_cpi, and use pointing_device_set_cpi like in all other pointing devices
@Alabastard-64 ping! Curious to know what you think of the tSRAD sleep as well as ordering fixes (and because it also relates to you pmw3389 driver) |
I'm actually curious and want to do some timing tests to see if spi_read() happens to somehow wait for all bits to arrive. hid_listen doesn't quite work on FreeBSD though and I'm not sure how accurate I can print timers on the console, but give me a week or so to verify. I'm also curious what the possible rate of updates is for this sensor. Not that I'm gonna use it for gaming, but I do wonder if 1ms USB polling even makes sense for it (and they actually call it a "gaming sensor") ... |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can confirm that it works and doesn't break anything.
Soooo, good news / bad news. I did some testing w/o the 160us delay, and the read then often returns garbage, e.g. 9700 cpi instead of the 100 cpi I was setting before: (this is with me still using TCNT0, so 1ms resolution):
ignore the stray Then I started using the TCNT3 timer with a 64 scaler, so I think that should work out to 4us per tick (16MHz controller). The no-delay read then takes about 13 or 14 ticks. The bad news? I'm pretty sure the ADNS9800 driver also does this wrong, but I have no hardware to test this on. |
* Start `develop` for 2022q1. * Added cancel_key_lock function (qmk#15321) * [Core] Remove matrix_is_modified() and debounce_is_active() (qmk#15349) * [Keyboard] Added Wakizashi 40 (qmk#15336) Co-authored-by: Ryan <fauxpark@gmail.com> * Change default USB Polling rate to 1kHz (qmk#15352) * [Keyboard] Convert ergoinu to SPLIT_KEYBOARD (qmk#15305) * Implement MAGIC_TOGGLE_CONTROL_CAPSLOCK (qmk#15368) * Convert not_so_minidox to SPLIT_KEYBOARD (qmk#15306) * Convert ai03/orbit to SPLIT_KEYBOARD (qmk#15340) * Tidy up existing i2c_master implementations (qmk#15376) * Move chibios defines out of header * Make some avr defines internal * Generalize Unicode defines (qmk#15409) * Add missing define for unicode common (qmk#15416) * Remove Deprecated USB Polling comment from vusb.c (qmk#15420) * Expand rotational range for PMW3360 Optical Sensor (qmk#15431) * Add support for 21.11.x, remove 21.6.x as ChibiOS "canceled" it. (qmk#15435) * added missing audio_off_user() callback (qmk#15457) Co-authored-by: Raoul Rubien <raoul.rubienr@gmail.com> * [Core] Don't send keyboard reports that propagate no changes to the host (qmk#14065) * Migrate serial_uart usages to UART driver (qmk#15479) * Migrate Thermal Printer feature to UART driver * Migrate 40percentclub UT47 to UART driver * Migrate Centromere to UART driver * Migrate Chimera Ergo to UART driver * Migrate Chimera Let's Split to UART driver * Migrate Chimera Ortho to UART driver * Migrate Chimera Ortho Plus to UART driver * Migrate Comet46 to UART driver * Migrate Palm USB converter to UART driver * Migrate Sun USB converter to UART driver * Migrate Dichotomy to UART driver * Migrate Honeycomb to UART driver * Migrate Mitosis to UART driver * Migrate Redox W to UART driver * Migrate Uni660 to UART driver * Migrate Telophase to UART driver * Fix build failure for UT47 (qmk#15483) * Use the PR title rather than parsing the commit message. (qmk#15537) * Migrate RN42 to UART driver and refactor (qmk#15492) * [CI] Format code according to conventions (qmk#15541) * Documentation Typo fix (qmk#15538) * Fix some typos, especially the sensor name. (qmk#15557) * Add open-drain GPIO support. (qmk#15282) * Add open-drain GPIO support. * `qmk format-c` * Wording. * Remove port GPIO implementations as the only board that uses it has its own internal defs anyway. Will wait for first-class handling of ports in core before reimplementing. * Fixes potential wpm sampling overflow, along with code comment fixes (qmk#15277) Co-authored-by: Trevor Powell <trevor@vectorstorm.com.au> * Add a clarification to an error message (qmk#15207) Makes this a bit more foolproof. See qmk#15202 * [Core] Split support for pointing devices. (qmk#15304) * Draft implementation * formatting * fix combined buttons * remove pimoroni throttle * sync pointing on a throttle loop with checksum * no longer used * doh Co-authored-by: Drashna Jaelre <drashna@live.com> * switch pimoroni to a cpi equivalent * add cpi support * allow user modification of seperate mouse reports * a little tidy up * add *_RIGHT defines. * docs * doxygen comments * basic changelog * clean up pimoroni * small doc fixes * Update docs/feature_pointing_device.md Co-authored-by: Drashna Jaelre <drashna@live.com> * performance tweak if side has usb * Don't run init funtions on wrong side * renamed some variables for consistency * fix pimoroni typos * Clamp instead of OR * Promote combined values to uint16_t * Update pointing_device.c Co-authored-by: Drashna Jaelre <drashna@live.com> Co-authored-by: Nick Brassel <nick@tzarc.org> * Format code according to conventions (qmk#15588) * Make (un)register code functions weak (qmk#15285) * Defer pin operations to gpio.h (qmk#15589) * Add sym_defer_pr debouncer type (qmk#14948) * Durgod: Increase scan rate by using wait_us GPT timer (qmk#14091) Lower the tick rate from 10kHz to 1kHz (otherwise all the extra interrupts reduce the achievable scan rate). Enable the WAIT_US_TIMER using GPT TIM3. Observed scan rate on the K320 is increased from 625Hz to 2090-2120Hz. * Format code according to conventions (qmk#15590) * Fixup line endings * More GPIO compilation fixes. (qmk#15592) * Custom matrix lite support for split keyboards (qmk#14674) * Custom matrix lite support for split keyboards * WIP: matrix -> matrix_common refactor * Move matrix_post_scan() to matrix_common.c * Refactor `bootloader_jump()` implementations (qmk#15450) * Refactor `bootloader_jump()` implementations * Fix tests? * Rename `atmel-samba` to `md-boot` * [Keymap] Add vitoni keymap for GMMK Pro (ISO) (qmk#15006) * [Keymap] Add vitoni layout for GMMK Pro (ISO) Keymap has layered cursor keys similar to laptop keyboards. * Configure RGB defaults for startup * Configure encoder to change value/brightness on FN layer * Remove FN layer and add dedicated RGB layer * Make RGB layer sticky (using TG) to avoid holding FN while configuring RGB * Add RGB indicators for active layers * Add RGB indicator for active RESET mode Signed-off-by: Victor Toni <victor.toni@gmail.com> * Configure idle / USB suspend settings * Add RGB fade in when resuming after suspend * Add RGB fade out before suspend * Add fade out before idle * Add breathe effect when idle * Convert some more boards to Matrix Lite (qmk#15489) * Fix for SPI write timing in PMW3360 driver (qmk#15519) Timing does not match Pixart documentation for this sensor (may have been carried forward from adns9800). Not aware of any issues coming from this currently. It should only cause issues when writing to multiple registers in succession which currently only happens during initialization for the PMW3360. This should prevent future issues with write operations if other features of the sensor are added. * Format code according to conventions (qmk#15593) * pwm3360 driver cleanup and diff reduction to adns9800 (qmk#15559) * Diff reduction between ADNS9800 and PMW3360 drivers. They are very similar devices. This (somewhat) unreadable diff is essentially a no-op, but it makes a `vimdiff` between the 2 drivers much more readable. * Cleanup pwm3360 driver some more. Remove redundant calls to spi_start() and spi_stop(), as pmw3360_write() will already call these. * [Core] Fix bug and code regression for Split Common (qmk#15603) * Format code according to conventions (qmk#15604) * [Bug] Include missing string.h include (qmk#15606) * move bm65hsrgb_iso and bm68hsrgb to rev1/ (qmk#15132) * Move to organization folder (qmk#15481) * move directory * fix * move wings42 to dailycraft * Adjust wings42 to work with organization folder. * [Keyboard] Update Tractyl Manuform to use Split Pointing Device Sync * [Keyboard] Update grs_70ec to use newer custom matrix (qmk#15609) * [Keyboard] Fix compiler issue with tractyl manuform 4x6 (qmk#15646) * Fix split pointing for analog joystick (qmk#15691) Co-authored-by: Nick Brassel <nick@tzarc.org> * Format code according to conventions (qmk#15693) * Update pmw3360 comments to match the datasheet better, fix delays. (qmk#15682) * move @yangdigi 's keyboards to a YDKB folder (qmk#15681) * Format code according to conventions (qmk#15705) Co-authored-by: Nick Brassel <nick@tzarc.org> Co-authored-by: QMK Bot <hello@qmk.fm> Co-authored-by: wheredoesyourmindgo <moemanchu@icloud.com> Co-authored-by: Stefan Kerkmann <karlk90@pm.me> Co-authored-by: xiao <307671+xia0@users.noreply.github.com> Co-authored-by: Ryan <fauxpark@gmail.com> Co-authored-by: Drashna Jaelre <drashna@live.com> Co-authored-by: Joel Challis <git@zvecr.com> Co-authored-by: Dipl.-Ing. Raoul Rubien, BSc <rubienr@sbox.tugraz.at> Co-authored-by: Raoul Rubien <raoul.rubienr@gmail.com> Co-authored-by: SmollChungus <38044391+SmollChungus@users.noreply.github.com> Co-authored-by: uqs <uqs@FreeBSD.org> Co-authored-by: vectorstorm <github@gridbug.org> Co-authored-by: Trevor Powell <trevor@vectorstorm.com.au> Co-authored-by: Hugo Osvaldo Barrera <hugo@barrera.io> Co-authored-by: Dasky <32983009+daskygit@users.noreply.github.com> Co-authored-by: Chad Austin <chad@chadaustin.me> Co-authored-by: Simon Arlott <70171+nomis@users.noreply.github.com> Co-authored-by: Jay Greco <jayv.greco@gmail.com> Co-authored-by: Victor Toni <ViToni@users.noreply.github.com> Co-authored-by: Alabastard-64 <96358682+Alabastard-64@users.noreply.github.com> Co-authored-by: peepeetee <43021794+peepeetee@users.noreply.github.com> Co-authored-by: yfuku <30647434+yfuku@users.noreply.github.com>
Add some timing stuff that was used to debug the 160us delay in qmk#15682
Update pmw3360 comments to match the datasheet better, fix delays.
We should de-assert NCS after waiting for tSCLK-NCS, so move spi_stop()
around a little. This was missed in PR#11519.
I'm less certain about adding the (quite long) tSRAD delay, but the
datasheet clearly indicates so. Not sure how this worked before, but we
don't actually use the read function, but read_burst instead. Only the
init phase and get_cpi() would be affected, and no one uses get_cpi,
only set_cpi, of course.
Also use the more natual spi_read() to discard the observation data,
this also saves 2 bytes in the firmware :)
Remove references to the no longer existing pmw_set_cpi, and use
pointing_device_set_cpi like in all other pointing devices
Description
Types of Changes
Issues Fixed or Closed by This PR
Checklist