[Core] PMW33XX drivers overhaul (#17613)
* PMW33XX drivers overhaul This combines the PMW3389 and PM3360 drivers as they only differ in the firmware blobs and CPI get and set functions. The following changes have been made: * PMW3389 now gets the same multi-sensor feature that is already available on the PMW3360. * Introduced a shared pmw33xx_report_t struct is now directly readable via SPI transactions instead of individual byte-sized reads, saving multiple copies and bitshift operations. * pmw33(89/60)_get_report functions had unreachable branches in their motion detection logic these have been simplied as much as possible. * The fast firmware upload option has been removed as this becomes obsolete by the newly introduced polled waiting functions for ChibiOS polled waiting * PMW33(60/89)_SPI_LSBFIRST and PMW33(60/89)_SPI_MODE config options have been removed as they don't need to be configurable. * All PMW3389 and PMW3360 defines have been unified to a PMW33XX prefix to reduce code duplication and make the defines interchangeable * Adjust keyboards to PMW33XX naming scheme
This commit is contained in:
		
							parent
							
								
									82685fc2ac
								
							
						
					
					
						commit
						3c58f98929
					
				
					 26 changed files with 1179 additions and 1456 deletions
				
			
		| 
						 | 
				
			
			@ -58,8 +58,8 @@
 | 
			
		|||
/* Set 0 if debouncing isn't needed. */
 | 
			
		||||
#define DEBOUNCE 5
 | 
			
		||||
 | 
			
		||||
/* PMW3360 settings. */
 | 
			
		||||
#define PMW3360_CS_PIN B0
 | 
			
		||||
/* PMW33XX settings. */
 | 
			
		||||
#define PMW33XX_CS_PIN B0
 | 
			
		||||
 | 
			
		||||
// Trackball angle adjustment.
 | 
			
		||||
#define ROTATIONAL_TRANSFORM_ANGLE -25
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -98,10 +98,8 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
// #define EXTERNAL_EEPROM_ADDRESS_SIZE         2
 | 
			
		||||
 | 
			
		||||
/* pmw3360 config  */
 | 
			
		||||
#undef PMW3360_CS_PIN
 | 
			
		||||
#define PMW3360_CS_PIN                       B0
 | 
			
		||||
#define PMW3360_SPI_MODE                     3
 | 
			
		||||
#define PMW3360_SPI_DIVISOR                  64
 | 
			
		||||
#undef PMW33XX_CS_PIN
 | 
			
		||||
#define PMW33XX_CS_PIN                       B0
 | 
			
		||||
 | 
			
		||||
#define CHARYBDIS_MINIMUM_DEFAULT_DPI 1200
 | 
			
		||||
#define CHARYBDIS_DEFAULT_DPI_CONFIG_STEP 400
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -60,8 +60,8 @@
 | 
			
		|||
/* Set 0 if debouncing isn't needed */
 | 
			
		||||
#define DEBOUNCE 5
 | 
			
		||||
 | 
			
		||||
/* PMW3360 settings. */
 | 
			
		||||
#define PMW3360_CS_PIN B0
 | 
			
		||||
/* PMW33XX settings. */
 | 
			
		||||
#define PMW33XX_CS_PIN B0
 | 
			
		||||
 | 
			
		||||
#define RGB_DI_PIN D3
 | 
			
		||||
#define RGBLED_NUM 56
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -87,11 +87,9 @@
 | 
			
		|||
#define EXTERNAL_EEPROM_SPI_SLAVE_SELECT_PIN A4
 | 
			
		||||
#define EXTERNAL_EEPROM_SPI_CLOCK_DIVISOR    64
 | 
			
		||||
 | 
			
		||||
#undef PMW3360_CS_PIN
 | 
			
		||||
#define PMW3360_CS_PIN                       A15  // b14
 | 
			
		||||
#define PMW3360_CS_MODE 3
 | 
			
		||||
#define PMW3360_CS_DIVISOR 64
 | 
			
		||||
#define PMW3360_LIFTOFF_DISTANCE 0b1111
 | 
			
		||||
#undef PMW33XX_CS_PIN
 | 
			
		||||
#define PMW33XX_CS_PIN                       A15  // b14
 | 
			
		||||
#define PMW33XX_LIFTOFF_DISTANCE 0b1111
 | 
			
		||||
#undef ROTATIONAL_TRANSFORM_ANGLE
 | 
			
		||||
#define ROTATIONAL_TRANSFORM_ANGLE -65
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -52,5 +52,5 @@
 | 
			
		|||
#define ENCODERS_PAD_A { B7 }
 | 
			
		||||
#define ENCODERS_PAD_B { E6 }
 | 
			
		||||
 | 
			
		||||
#define PMW3360_CS_PIN SPI_SS_PIN
 | 
			
		||||
#define PMW33XX_CS_PIN SPI_SS_PIN
 | 
			
		||||
#define POINTING_DEVICE_INVERT_Y
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -85,7 +85,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
//#define NO_ACTION_TAPPING
 | 
			
		||||
//#define NO_ACTION_ONESHOT
 | 
			
		||||
 | 
			
		||||
/* PMW3360 Settings */
 | 
			
		||||
#define PMW3360_CS_PIN           B0
 | 
			
		||||
/* PMW33XX Settings */
 | 
			
		||||
#define PMW33XX_CS_PIN           B0
 | 
			
		||||
 | 
			
		||||
#define POINTING_DEVICE_RIGHT
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -3,7 +3,7 @@
 | 
			
		|||
    "url": "",
 | 
			
		||||
    "maintainer": "drashna",
 | 
			
		||||
    "layouts": {
 | 
			
		||||
        "LAYOUT_5x6_right": {
 | 
			
		||||
        "LAYOUT_4x6_right": {
 | 
			
		||||
            "layout": [
 | 
			
		||||
                {"label":"L00", "x":0, "y":0},
 | 
			
		||||
                {"label":"L01", "x":1, "y":0},
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -47,5 +47,5 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
#define ENCODERS_PAD_B \
 | 
			
		||||
    { C7 }
 | 
			
		||||
 | 
			
		||||
/* PMW3360 Settings */
 | 
			
		||||
#define PMW3360_CS_PIN B6
 | 
			
		||||
/* PMW33XX Settings */
 | 
			
		||||
#define PMW33XX_CS_PIN B6
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -99,6 +99,5 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
// #define DEBUG_EEPROM_OUTPUT
 | 
			
		||||
 | 
			
		||||
/* pmw3360 config  */
 | 
			
		||||
#define PMW3360_CS_PIN                       B9
 | 
			
		||||
#define PMW3360_SPI_MODE                     3
 | 
			
		||||
#define PMW3360_SPI_DIVISOR                  8
 | 
			
		||||
#define PMW33XX_CS_PIN                       B9
 | 
			
		||||
#define PMW33XX_SPI_DIVISOR                  8
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -102,7 +102,4 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
#define EXTERNAL_EEPROM_SPI_CLOCK_DIVISOR    64
 | 
			
		||||
 | 
			
		||||
/* pmw3360 config  */
 | 
			
		||||
#define PMW3360_CS_PIN                       B0
 | 
			
		||||
#define PMW3360_SPI_MODE                     3
 | 
			
		||||
#define PMW3360_SPI_DIVISOR                  64
 | 
			
		||||
#define PMW3360_FIRMWARE_UPLOAD_FAST
 | 
			
		||||
#define PMW33XX_CS_PIN                       B0
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -51,5 +51,5 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
#define ENCODERS_PAD_B \
 | 
			
		||||
    { D4 }
 | 
			
		||||
 | 
			
		||||
/* PMW3360 Settings */
 | 
			
		||||
#define PMW3360_CS_PIN B0
 | 
			
		||||
/* PMW33XX Settings */
 | 
			
		||||
#define PMW33XX_CS_PIN B0
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -56,4 +56,4 @@
 | 
			
		|||
// #define BOOTMAGIC_LITE_COLUMN 0
 | 
			
		||||
 | 
			
		||||
#define ADNS9800_CS_PIN SPI_SS_PIN
 | 
			
		||||
#define PMW3360_CS_PIN SPI_SS_PIN
 | 
			
		||||
#define PMW33XX_CS_PIN SPI_SS_PIN
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -77,5 +77,5 @@
 | 
			
		|||
 | 
			
		||||
// #define DEBUG_LED_PIN F7
 | 
			
		||||
 | 
			
		||||
/* PMW3360 Settings */
 | 
			
		||||
#define PMW3360_CS_PIN B0
 | 
			
		||||
/* PMW33XX Settings */
 | 
			
		||||
#define PMW33XX_CS_PIN B0
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -53,6 +53,6 @@
 | 
			
		|||
// If board has a debug LED, you can enable it by defining this
 | 
			
		||||
// #define DEBUG_LED_PIN F7
 | 
			
		||||
 | 
			
		||||
/* PMW3360 Settings */
 | 
			
		||||
#define PMW3360_CS_PIN             B0
 | 
			
		||||
/* PMW33XX Settings */
 | 
			
		||||
#define PMW33XX_CS_PIN             B0
 | 
			
		||||
#define POINTING_DEVICE_INVERT_Y
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue