mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 d6b98c8d24
			
		
	
	
		d6b98c8d24
		
	
	
	
	
		
			
			Add the possibility to write raw bytes to the GNSS module through the first TTY device. This allows user to configure the module. Create a second read-only TTY device. Signed-off-by: Karol Kolacinski <karol.kolacinski@intel.com> Tested-by: Gurucharan <gurucharanx.g@intel.com> (A Contingent worker at Intel) Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
		
			
				
	
	
		
			75 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /* Copyright (C) 2021-2022, Intel Corporation. */
 | |
| 
 | |
| #ifndef _ICE_GNSS_H_
 | |
| #define _ICE_GNSS_H_
 | |
| 
 | |
| #include <linux/tty.h>
 | |
| #include <linux/tty_flip.h>
 | |
| 
 | |
| #define ICE_E810T_GNSS_I2C_BUS		0x2
 | |
| #define ICE_GNSS_TIMER_DELAY_TIME	(HZ / 10) /* 0.1 second per message */
 | |
| /* Create 2 minor devices, both using the same GNSS module. First one is RW,
 | |
|  * second one RO.
 | |
|  */
 | |
| #define ICE_GNSS_TTY_MINOR_DEVICES	2
 | |
| #define ICE_GNSS_TTY_WRITE_BUF		250
 | |
| #define ICE_MAX_I2C_DATA_SIZE		FIELD_MAX(ICE_AQC_I2C_DATA_SIZE_M)
 | |
| #define ICE_MAX_I2C_WRITE_BYTES		4
 | |
| 
 | |
| /* u-blox ZED-F9T specific definitions */
 | |
| #define ICE_GNSS_UBX_I2C_BUS_ADDR	0x42
 | |
| /* Data length register is big endian */
 | |
| #define ICE_GNSS_UBX_DATA_LEN_H		0xFD
 | |
| #define ICE_GNSS_UBX_DATA_LEN_WIDTH	2
 | |
| #define ICE_GNSS_UBX_EMPTY_DATA		0xFF
 | |
| /* For u-blox writes are performed without address so the first byte to write is
 | |
|  * passed as I2C addr parameter.
 | |
|  */
 | |
| #define ICE_GNSS_UBX_WRITE_BYTES	(ICE_MAX_I2C_WRITE_BYTES + 1)
 | |
| #define ICE_MAX_UBX_READ_TRIES		255
 | |
| #define ICE_MAX_UBX_ACK_READ_TRIES	4095
 | |
| 
 | |
| struct gnss_write_buf {
 | |
| 	struct list_head queue;
 | |
| 	unsigned int size;
 | |
| 	unsigned char *buf;
 | |
| };
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * struct gnss_serial - data used to initialize GNSS TTY port
 | |
|  * @back: back pointer to PF
 | |
|  * @tty: pointer to the tty for this device
 | |
|  * @open_count: number of times this port has been opened
 | |
|  * @gnss_mutex: gnss_mutex used to protect GNSS serial operations
 | |
|  * @kworker: kwork thread for handling periodic work
 | |
|  * @read_work: read_work function for handling GNSS reads
 | |
|  * @write_work: write_work function for handling GNSS writes
 | |
|  * @queue: write buffers queue
 | |
|  */
 | |
| struct gnss_serial {
 | |
| 	struct ice_pf *back;
 | |
| 	struct tty_struct *tty;
 | |
| 	int open_count;
 | |
| 	struct mutex gnss_mutex; /* protects GNSS serial structure */
 | |
| 	struct kthread_worker *kworker;
 | |
| 	struct kthread_delayed_work read_work;
 | |
| 	struct kthread_work write_work;
 | |
| 	struct list_head queue;
 | |
| };
 | |
| 
 | |
| #if IS_ENABLED(CONFIG_TTY)
 | |
| void ice_gnss_init(struct ice_pf *pf);
 | |
| void ice_gnss_exit(struct ice_pf *pf);
 | |
| bool ice_gnss_is_gps_present(struct ice_hw *hw);
 | |
| #else
 | |
| static inline void ice_gnss_init(struct ice_pf *pf) { }
 | |
| static inline void ice_gnss_exit(struct ice_pf *pf) { }
 | |
| static inline bool ice_gnss_is_gps_present(struct ice_hw *hw)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| #endif /* IS_ENABLED(CONFIG_TTY) */
 | |
| #endif /* _ICE_GNSS_H_ */
 |