xref: /openbmc/linux/drivers/net/ieee802154/atusb.h (revision c84d59e72830ce7a7ce67cf7509d37342aa235db)
17490b008SAlexander Aring /*
27490b008SAlexander Aring  * atusb.h - Definitions shared between kernel and ATUSB firmware
37490b008SAlexander Aring  *
47490b008SAlexander Aring  * Written 2013 by Werner Almesberger <werner@almesberger.net>
57490b008SAlexander Aring  *
67490b008SAlexander Aring  * This program is free software; you can redistribute it and/or
77490b008SAlexander Aring  * modify it under the terms of the GNU General Public License as
87490b008SAlexander Aring  * published by the Free Software Foundation, version 2, or
97490b008SAlexander Aring  * (at your option) any later version.
107490b008SAlexander Aring  *
117490b008SAlexander Aring  * This file should be identical for kernel and firmware.
127490b008SAlexander Aring  * Kernel: drivers/net/ieee802154/atusb.h
137490b008SAlexander Aring  * Firmware: ben-wpan/atusb/fw/include/atusb/atusb.h
147490b008SAlexander Aring  */
157490b008SAlexander Aring 
167490b008SAlexander Aring #ifndef	_ATUSB_H
177490b008SAlexander Aring #define	_ATUSB_H
187490b008SAlexander Aring 
197490b008SAlexander Aring #define ATUSB_VENDOR_ID	0x20b7	/* Qi Hardware*/
207490b008SAlexander Aring #define ATUSB_PRODUCT_ID 0x1540	/* 802.15.4, device 0 */
217490b008SAlexander Aring 				/*     -- -         - */
227490b008SAlexander Aring 
237490b008SAlexander Aring #define ATUSB_BUILD_SIZE 256	/* maximum build version/date message length */
247490b008SAlexander Aring 
257490b008SAlexander Aring /* Commands to our device. Make sure this is synced with the firmware */
267490b008SAlexander Aring enum atusb_requests {
277490b008SAlexander Aring 	ATUSB_ID			= 0x00,	/* system status/control grp */
287490b008SAlexander Aring 	ATUSB_BUILD,
297490b008SAlexander Aring 	ATUSB_RESET,
307490b008SAlexander Aring 	ATUSB_RF_RESET			= 0x10,	/* debug/test group */
317490b008SAlexander Aring 	ATUSB_POLL_INT,
327490b008SAlexander Aring 	ATUSB_TEST,			/* atusb-sil only */
337490b008SAlexander Aring 	ATUSB_TIMER,
347490b008SAlexander Aring 	ATUSB_GPIO,
357490b008SAlexander Aring 	ATUSB_SLP_TR,
367490b008SAlexander Aring 	ATUSB_GPIO_CLEANUP,
377490b008SAlexander Aring 	ATUSB_REG_WRITE			= 0x20,	/* transceiver group */
387490b008SAlexander Aring 	ATUSB_REG_READ,
397490b008SAlexander Aring 	ATUSB_BUF_WRITE,
407490b008SAlexander Aring 	ATUSB_BUF_READ,
417490b008SAlexander Aring 	ATUSB_SRAM_WRITE,
427490b008SAlexander Aring 	ATUSB_SRAM_READ,
437490b008SAlexander Aring 	ATUSB_SPI_WRITE			= 0x30,	/* SPI group */
447490b008SAlexander Aring 	ATUSB_SPI_READ1,
457490b008SAlexander Aring 	ATUSB_SPI_READ2,
467490b008SAlexander Aring 	ATUSB_SPI_WRITE2_SYNC,
477490b008SAlexander Aring 	ATUSB_RX_MODE			= 0x40, /* HardMAC group */
487490b008SAlexander Aring 	ATUSB_TX,
49*c84d59e7SStefan Schmidt 	ATUSB_EUI64_WRITE		= 0x50, /* Parameter in EEPROM grp */
50*c84d59e7SStefan Schmidt 	ATUSB_EUI64_READ,
517490b008SAlexander Aring };
527490b008SAlexander Aring 
53*c84d59e7SStefan Schmidt /*
54*c84d59e7SStefan Schmidt  * Direction	bRequest		wValue		wIndex	wLength
557490b008SAlexander Aring  *
567490b008SAlexander Aring  * ->host	ATUSB_ID		-		-	3
577490b008SAlexander Aring  * ->host	ATUSB_BUILD		-		-	#bytes
587490b008SAlexander Aring  * host->	ATUSB_RESET		-		-	0
597490b008SAlexander Aring  *
607490b008SAlexander Aring  * host->	ATUSB_RF_RESET		-		-	0
617490b008SAlexander Aring  * ->host	ATUSB_POLL_INT		-		-	1
627490b008SAlexander Aring  * host->	ATUSB_TEST		-		-	0
637490b008SAlexander Aring  * ->host	ATUSB_TIMER		-		-	#bytes (6)
647490b008SAlexander Aring  * ->host	ATUSB_GPIO		dir+data	mask+p#	3
657490b008SAlexander Aring  * host->	ATUSB_SLP_TR		-		-	0
667490b008SAlexander Aring  * host->	ATUSB_GPIO_CLEANUP	-		-	0
677490b008SAlexander Aring  *
687490b008SAlexander Aring  * host->	ATUSB_REG_WRITE		value		addr	0
697490b008SAlexander Aring  * ->host	ATUSB_REG_READ		-		addr	1
707490b008SAlexander Aring  * host->	ATUSB_BUF_WRITE		-		-	#bytes
717490b008SAlexander Aring  * ->host	ATUSB_BUF_READ		-		-	#bytes
727490b008SAlexander Aring  * host->	ATUSB_SRAM_WRITE	-		addr	#bytes
737490b008SAlexander Aring  * ->host	ATUSB_SRAM_READ		-		addr	#bytes
747490b008SAlexander Aring  *
757490b008SAlexander Aring  * host->	ATUSB_SPI_WRITE		byte0		byte1	#bytes
767490b008SAlexander Aring  * ->host	ATUSB_SPI_READ1		byte0		-	#bytes
777490b008SAlexander Aring  * ->host	ATUSB_SPI_READ2		byte0		byte1	#bytes
787490b008SAlexander Aring  * ->host	ATUSB_SPI_WRITE2_SYNC	byte0		byte1	0/1
797490b008SAlexander Aring  *
807490b008SAlexander Aring  * host->	ATUSB_RX_MODE		on		-	0
817490b008SAlexander Aring  * host->	ATUSB_TX		flags		ack_seq	#bytes
82*c84d59e7SStefan Schmidt  * host->	ATUSB_EUI64_WRITE	-		-	#bytes (8)
83*c84d59e7SStefan Schmidt  * ->host	ATUSB_EUI64_READ	-		-	#bytes (8)
847490b008SAlexander Aring  */
857490b008SAlexander Aring 
867490b008SAlexander Aring #define ATUSB_REQ_FROM_DEV	(USB_TYPE_VENDOR | USB_DIR_IN)
877490b008SAlexander Aring #define ATUSB_REQ_TO_DEV	(USB_TYPE_VENDOR | USB_DIR_OUT)
887490b008SAlexander Aring 
897490b008SAlexander Aring #endif /* !_ATUSB_H */
90