11589a993f074124c3edfff03656e910bb472eeaaUwe Bugla/*
21589a993f074124c3edfff03656e910bb472eeaaUwe Bugla * Linux driver for digital TV devices equipped with B2C2 FlexcopII(b)/III
31589a993f074124c3edfff03656e910bb472eeaaUwe Bugla * flexcop-usb.h - header file for the USB part
41589a993f074124c3edfff03656e910bb472eeaaUwe Bugla * see flexcop.c for copyright information
51589a993f074124c3edfff03656e910bb472eeaaUwe Bugla */
62add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach#ifndef __FLEXCOP_USB_H_INCLUDED__
72add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach#define __FLEXCOP_USB_H_INCLUDED__
82add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
92add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach#include <linux/usb.h>
102add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
112add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach/* transfer parameters */
121589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_USB_FRAMES_PER_ISO 4
131589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_USB_NUM_ISO_URB 4
142add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
151589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_USB_CTRL_PIPE_IN usb_rcvctrlpipe(fc_usb->udev, 0)
161589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_USB_CTRL_PIPE_OUT usb_sndctrlpipe(fc_usb->udev, 0)
171589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_USB_DATA_PIPE usb_rcvisocpipe(fc_usb->udev, 0x81)
182add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
192add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbachstruct flexcop_usb {
202add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	struct usb_device *udev;
212add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	struct usb_interface *uintf;
222add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
232add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	u8 *iso_buffer;
242add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	int buffer_size;
252add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	dma_addr_t dma_addr;
262add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
271589a993f074124c3edfff03656e910bb472eeaaUwe Bugla	struct urb *iso_urb[B2C2_USB_NUM_ISO_URB];
282add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	struct flexcop_device *fc_dev;
297635acd2d927578495c692056d0e7dabd06afc89Johannes Stezenbach
307635acd2d927578495c692056d0e7dabd06afc89Johannes Stezenbach	u8 tmp_buffer[1023+190];
317635acd2d927578495c692056d0e7dabd06afc89Johannes Stezenbach	int tmp_buffer_length;
322add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach};
332add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
342add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach#if 0
352add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach/* request types TODO What is its use?*/
362add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbachtypedef enum {
372add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
382add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach} flexcop_usb_request_type_t;
392add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach#endif
402add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
412add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach/* request */
422add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbachtypedef enum {
432add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_WRITE_V8_MEM = 0x04,
442add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_READ_V8_MEM  = 0x05,
452add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_READ_REG     = 0x08,
462add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_WRITE_REG    = 0x0A,
472add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_WRITEREGHI   = 0x0B,
482add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_FLASH_BLOCK  = 0x10,
492add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_I2C_REQUEST  = 0x11,
502add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	B2C2_USB_UTILITY      = 0x12,
512add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach} flexcop_usb_request_t;
522add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
532add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach/* function definition for I2C_REQUEST */
542add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbachtypedef enum {
552add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_WRITE       = 0x01,
562add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_MULTIWRITE  = 0x02,
572add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_READ        = 0x03,
582add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_REPEATWRITE = 0x04,
592add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_GET_DESCRIPTOR  = 0x05,
602add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_REPEATREAD  = 0x06,
611589a993f074124c3edfff03656e910bb472eeaaUwe Bugla	/* DKT 020208 - add this to support special case of DiSEqC */
622add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_CHECKWRITE  = 0x07,
632add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	USB_FUNC_I2C_CHECKRESULT = 0x08,
642add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach} flexcop_usb_i2c_function_t;
652add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
661589a993f074124c3edfff03656e910bb472eeaaUwe Bugla/* function definition for UTILITY request 0x12
671589a993f074124c3edfff03656e910bb472eeaaUwe Bugla * DKT 020304 - new utility function */
682add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbachtypedef enum {
692add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SET_FILTER          = 0x01,
702add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_DATA_ENABLE         = 0x02,
712add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_FLEX_MULTIWRITE     = 0x03,
722add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SET_BUFFER_SIZE     = 0x04,
732add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_FLEX_OPERATOR       = 0x05,
742add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_FLEX_RESET300_START = 0x06,
752add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_FLEX_RESET300_STOP  = 0x07,
762add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_FLEX_RESET300       = 0x08,
772add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SET_ISO_SIZE        = 0x09,
782add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_DATA_RESET          = 0x0A,
792add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_GET_DATA_STATUS     = 0x10,
802add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_GET_V8_REG          = 0x11,
811589a993f074124c3edfff03656e910bb472eeaaUwe Bugla	/* DKT 020326 - add function for v1.14 */
822add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SRAM_WRITE          = 0x12,
832add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SRAM_READ           = 0x13,
842add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SRAM_TESTFILL       = 0x14,
852add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SRAM_TESTSET        = 0x15,
862add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	UTILITY_SRAM_TESTVERIFY     = 0x16,
872add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach} flexcop_usb_utility_function_t;
882add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
891589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_WAIT_FOR_OPERATION_RW (1*HZ)
901589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_WAIT_FOR_OPERATION_RDW (3*HZ)
911589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_WAIT_FOR_OPERATION_WDW (1*HZ)
922add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
931589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_WAIT_FOR_OPERATION_V8READ (3*HZ)
941589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_WAIT_FOR_OPERATION_V8WRITE (3*HZ)
951589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define B2C2_WAIT_FOR_OPERATION_V8FLASH (3*HZ)
962add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
972add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbachtypedef enum {
982add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	V8_MEMORY_PAGE_DVB_CI = 0x20,
992add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	V8_MEMORY_PAGE_DVB_DS = 0x40,
1002add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	V8_MEMORY_PAGE_MULTI2 = 0x60,
1012add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach	V8_MEMORY_PAGE_FLASH  = 0x80
1022add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach} flexcop_usb_mem_page_t;
1032add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
1041589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define V8_MEMORY_EXTENDED (1 << 15)
1051589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define USB_MEM_READ_MAX   32
1061589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define USB_MEM_WRITE_MAX   1
1071589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define USB_FLASH_MAX       8
1081589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define V8_MEMORY_PAGE_SIZE 0x8000 /* 32K */
1091589a993f074124c3edfff03656e910bb472eeaaUwe Bugla#define V8_MEMORY_PAGE_MASK 0x7FFF
1102add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach
1112add87a95068d6457d4e5824d0417d39007665a4Johannes Stezenbach#endif
112