Home | History | Annotate | Line # | Download | only in usb
      1  1.6      nat /*	$NetBSD: udl.h,v 1.6 2022/09/06 02:20:17 nat Exp $	*/
      2  1.1  tsutsui 
      3  1.1  tsutsui /*-
      4  1.1  tsutsui  * Copyright (c) 2009 FUKAUMI Naoki.
      5  1.1  tsutsui  * All rights reserved.
      6  1.1  tsutsui  *
      7  1.1  tsutsui  * Redistribution and use in source and binary forms, with or without
      8  1.1  tsutsui  * modification, are permitted provided that the following conditions
      9  1.1  tsutsui  * are met:
     10  1.1  tsutsui  * 1. Redistributions of source code must retain the above copyright
     11  1.1  tsutsui  *    notice, this list of conditions and the following disclaimer.
     12  1.1  tsutsui  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1  tsutsui  *    notice, this list of conditions and the following disclaimer in the
     14  1.1  tsutsui  *    documentation and/or other materials provided with the distribution.
     15  1.1  tsutsui  *
     16  1.1  tsutsui  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     17  1.1  tsutsui  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     18  1.1  tsutsui  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     19  1.1  tsutsui  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     20  1.1  tsutsui  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     21  1.1  tsutsui  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     22  1.1  tsutsui  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     23  1.1  tsutsui  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     24  1.1  tsutsui  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     25  1.1  tsutsui  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     26  1.1  tsutsui  */
     27  1.1  tsutsui 
     28  1.1  tsutsui /*
     29  1.1  tsutsui  * Copyright (c) 2009 Marcus Glocker <mglocker (at) openbsd.org>
     30  1.1  tsutsui  *
     31  1.1  tsutsui  * Permission to use, copy, modify, and distribute this software for any
     32  1.1  tsutsui  * purpose with or without fee is hereby granted, provided that the above
     33  1.1  tsutsui  * copyright notice and this permission notice appear in all copies.
     34  1.1  tsutsui  *
     35  1.1  tsutsui  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
     36  1.1  tsutsui  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
     37  1.1  tsutsui  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
     38  1.1  tsutsui  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
     39  1.1  tsutsui  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
     40  1.1  tsutsui  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
     41  1.1  tsutsui  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     42  1.1  tsutsui  */
     43  1.1  tsutsui 
     44  1.1  tsutsui #ifdef UDL_EVENT_COUNTERS
     45  1.1  tsutsui #define UDL_EVCNT_INCR(ev)	(ev)->ev_count++
     46  1.1  tsutsui #else
     47  1.1  tsutsui #define UDL_EVCNT_INCR(ev)	do {} while (/* CONSTCOND */ 0)
     48  1.1  tsutsui #endif
     49  1.1  tsutsui 
     50  1.1  tsutsui /*
     51  1.1  tsutsui  * Bulk command xfer structure.
     52  1.1  tsutsui  */
     53  1.1  tsutsui #define UDL_CMD_BUFFER_SIZE	(64 * 1024)
     54  1.1  tsutsui #define UDL_CMD_HEADER_SIZE	6
     55  1.1  tsutsui #define UDL_CMD_WIDTH_MAX	256
     56  1.1  tsutsui #define UDL_CMD_DRAW_SIZE(width) \
     57  1.1  tsutsui 				(UDL_CMD_HEADER_SIZE + (width) * 2)
     58  1.1  tsutsui #define UDL_CMD_FILL_SIZE	(UDL_CMD_HEADER_SIZE + 3)
     59  1.1  tsutsui #define UDL_CMD_COPY_SIZE	(UDL_CMD_HEADER_SIZE + 3)
     60  1.1  tsutsui #define UDL_CMD_COMP_WORD_SIZE	4
     61  1.1  tsutsui #define UDL_CMD_COMP_MIN_SIZE	(UDL_CMD_HEADER_SIZE + UDL_CMD_COMP_WORD_SIZE)
     62  1.1  tsutsui #define UDL_CMD_COMP_BLOCK_SIZE	512
     63  1.1  tsutsui #define UDL_CMD_COMP_THRESHOLD \
     64  1.1  tsutsui     (UDL_CMD_BUFFER_SIZE - (UDL_CMD_COMP_BLOCK_SIZE * 2))
     65  1.1  tsutsui 
     66  1.1  tsutsui #define UDL_NCMDQ	32
     67  1.1  tsutsui 
     68  1.1  tsutsui struct udl_cmdq {
     69  1.1  tsutsui 	TAILQ_ENTRY(udl_cmdq)	 cq_chain;
     70  1.1  tsutsui 	struct udl_softc	*cq_sc;
     71  1.2    skrll 	struct usbd_xfer	*cq_xfer;
     72  1.1  tsutsui 	uint8_t			*cq_buf;
     73  1.1  tsutsui };
     74  1.1  tsutsui 
     75  1.1  tsutsui /*
     76  1.1  tsutsui  * Our per device structure.
     77  1.1  tsutsui  */
     78  1.1  tsutsui struct udl_softc {
     79  1.1  tsutsui 	device_t		 sc_dev;
     80  1.2    skrll 	struct usbd_device *	 sc_udev;
     81  1.2    skrll 	struct usbd_interface *	 sc_iface;
     82  1.2    skrll 	struct usbd_pipe *	 sc_tx_pipeh;
     83  1.1  tsutsui 
     84  1.5     maxv 	enum {
     85  1.5     maxv 		UDL_INIT_NONE,
     86  1.5     maxv 		UDL_INIT_MIDWAY,
     87  1.5     maxv 		UDL_INIT_INITED
     88  1.5     maxv 	} sc_init_state;
     89  1.5     maxv 
     90  1.1  tsutsui 	struct udl_cmdq		 sc_cmdq[UDL_NCMDQ];
     91  1.1  tsutsui 	TAILQ_HEAD(udl_cmdq_head, udl_cmdq)	sc_freecmd,
     92  1.1  tsutsui 						sc_xfercmd;
     93  1.1  tsutsui 
     94  1.1  tsutsui 	struct udl_cmdq		*sc_cmd_cur;
     95  1.1  tsutsui 	uint8_t			*sc_cmd_buf;
     96  1.1  tsutsui #define UDL_CMD_BUFINIT(sc)	((sc)->sc_cmd_buf = (sc)->sc_cmd_cur->cq_buf)
     97  1.1  tsutsui #define UDL_CMD_BUFSIZE(sc)	((sc)->sc_cmd_buf - (sc)->sc_cmd_cur->cq_buf)
     98  1.1  tsutsui 	int			 sc_cmd_cblen;
     99  1.1  tsutsui 
    100  1.1  tsutsui 	struct edid_info	 sc_ei;
    101  1.1  tsutsui 	int			 sc_width;
    102  1.1  tsutsui 	int			 sc_height;
    103  1.1  tsutsui 	int			 sc_offscreen;
    104  1.1  tsutsui 	uint8_t			 sc_depth;
    105  1.1  tsutsui 
    106  1.1  tsutsui 	/* wsdisplay glue */
    107  1.1  tsutsui 	struct wsscreen_descr	 sc_defaultscreen;
    108  1.1  tsutsui 	const struct wsscreen_descr	*sc_screens[1];
    109  1.1  tsutsui 	struct wsscreen_list	 sc_screenlist;
    110  1.1  tsutsui 	struct rasops_info	 sc_ri;
    111  1.1  tsutsui 	device_t		 sc_wsdisplay;
    112  1.1  tsutsui 	u_int			 sc_mode;
    113  1.1  tsutsui 	u_int			 sc_blank;
    114  1.6      nat 	bool			 sc_clear;
    115  1.1  tsutsui 	uint8_t			 sc_nscreens;
    116  1.1  tsutsui 
    117  1.1  tsutsui 	uint8_t			*sc_fbmem;	/* framebuffer for X11 */
    118  1.3      nat 	uint8_t			*sc_fbmem_prev;	/* prev. framebuffer */
    119  1.1  tsutsui #define UDL_FBMEM_SIZE(sc) \
    120  1.1  tsutsui     ((sc)->sc_width * (sc)->sc_height * ((sc)->sc_depth / 8))
    121  1.1  tsutsui 
    122  1.1  tsutsui 	uint8_t			*sc_huffman;
    123  1.1  tsutsui 	uint8_t			*sc_huffman_base;
    124  1.1  tsutsui 	size_t			 sc_huffman_size;
    125  1.1  tsutsui 
    126  1.3      nat 	kcondvar_t		 sc_thread_cv;
    127  1.3      nat 	kmutex_t		 sc_thread_mtx;
    128  1.3      nat 	bool			 sc_dying;
    129  1.4      nat 	bool			 sc_thread_stop;
    130  1.3      nat 	lwp_t			*sc_thread;
    131  1.3      nat 
    132  1.1  tsutsui 	kcondvar_t		 sc_cv;
    133  1.1  tsutsui 	kmutex_t		 sc_mtx;
    134  1.1  tsutsui 
    135  1.1  tsutsui #define UDL_DECOMPRDY	(1 << 0)
    136  1.1  tsutsui #define UDL_COMPRDY	(1 << 1)
    137  1.1  tsutsui 	uint32_t		 sc_flags;
    138  1.1  tsutsui #ifdef UDL_EVENT_COUNTERS
    139  1.1  tsutsui 	struct evcnt		 sc_ev_cmdq_get;
    140  1.1  tsutsui 	struct evcnt		 sc_ev_cmdq_put;
    141  1.1  tsutsui 	struct evcnt		 sc_ev_cmdq_wait;
    142  1.1  tsutsui 	struct evcnt		 sc_ev_cmdq_timeout;
    143  1.1  tsutsui #endif
    144  1.1  tsutsui };
    145  1.1  tsutsui 
    146  1.1  tsutsui /*
    147  1.1  tsutsui  * Chip commands.
    148  1.1  tsutsui  */
    149  1.1  tsutsui #define UDL_CTRL_CMD_READ_EDID		0x02
    150  1.1  tsutsui #define UDL_CTRL_CMD_WRITE_1		0x03
    151  1.1  tsutsui #define UDL_CTRL_CMD_READ_1		0x04
    152  1.1  tsutsui #define UDL_CTRL_CMD_READ_STATUS	0x06
    153  1.1  tsutsui #define UDL_CTRL_CMD_SET_KEY		0x12
    154  1.1  tsutsui 
    155  1.1  tsutsui #define UDL_BULK_SOC			0xaf	/* start of command token */
    156  1.1  tsutsui 
    157  1.1  tsutsui #define UDL_BULK_CMD_REG_WRITE_1	0x20	/* write 1 byte to register */
    158  1.1  tsutsui #define UDL_BULK_CMD_EOC		0xa0	/* end of command stack */
    159  1.1  tsutsui #define UDL_BULK_CMD_DECOMP		0xe0	/* send decompression table */
    160  1.1  tsutsui 
    161  1.1  tsutsui #define UDL_BULK_CMD_FB_BASE8		0x60
    162  1.1  tsutsui #define UDL_BULK_CMD_FB_WRITE8		(UDL_BULK_CMD_FB_BASE8 | 0x00)
    163  1.1  tsutsui #define UDL_BULK_CMD_FB_RLE8		(UDL_BULK_CMD_FB_BASE8 | 0x01)
    164  1.1  tsutsui #define UDL_BULK_CMD_FB_COPY8		(UDL_BULK_CMD_FB_BASE8 | 0x02)
    165  1.1  tsutsui #define UDL_BULK_CMD_FB_BASE16		0x68
    166  1.1  tsutsui #define UDL_BULK_CMD_FB_WRITE16		(UDL_BULK_CMD_FB_BASE16 | 0x00)
    167  1.1  tsutsui #define UDL_BULK_CMD_FB_RLE16		(UDL_BULK_CMD_FB_BASE16 | 0x01)
    168  1.1  tsutsui #define UDL_BULK_CMD_FB_COPY16		(UDL_BULK_CMD_FB_BASE16 | 0x02)
    169  1.1  tsutsui #define UDL_BULK_CMD_FB_COMP		0x10
    170  1.1  tsutsui 
    171  1.1  tsutsui /*
    172  1.1  tsutsui  * Chip registers.
    173  1.1  tsutsui  */
    174  1.1  tsutsui #define UDL_REG_COLORDEPTH		0x00
    175  1.1  tsutsui  #define UDL_REG_COLORDEPTH_16		0x00
    176  1.1  tsutsui  #define UDL_REG_COLORDEPTH_24		0x01
    177  1.1  tsutsui #define UDL_REG_XDISPLAYSTART		0x01
    178  1.1  tsutsui #define UDL_REG_XDISPLAYEND		0x03
    179  1.1  tsutsui #define UDL_REG_YDISPLAYSTART		0x05
    180  1.1  tsutsui #define UDL_REG_YDISPLAYEND		0x07
    181  1.1  tsutsui #define UDL_REG_XENDCOUNT		0x09
    182  1.1  tsutsui #define UDL_REG_HSYNCSTART		0x0b
    183  1.1  tsutsui #define UDL_REG_HSYNCEND		0x0d
    184  1.1  tsutsui #define UDL_REG_HPIXELS			0x0f
    185  1.1  tsutsui #define UDL_REG_YENDCOUNT		0x11
    186  1.1  tsutsui #define UDL_REG_VSYNCSTART		0x13
    187  1.1  tsutsui #define UDL_REG_VSYNCEND		0x15
    188  1.1  tsutsui #define UDL_REG_VPIXELS			0x17
    189  1.1  tsutsui #define UDL_REG_PIXELCLOCK5KHZ		0x1b
    190  1.1  tsutsui #define UDL_REG_BLANK			0x1f
    191  1.1  tsutsui  #define UDL_REG_BLANK_OFF		0x00
    192  1.1  tsutsui  #define UDL_REG_BLANK_ON		0x01
    193  1.1  tsutsui #define UDL_REG_ADDR_START16		0x20
    194  1.1  tsutsui #define UDL_REG_ADDR_STRIDE16		0x23
    195  1.1  tsutsui #define UDL_REG_ADDR_START8		0x26
    196  1.1  tsutsui #define UDL_REG_ADDR_STRIDE8		0x29
    197  1.1  tsutsui #define UDL_REG_SYNC			0xff
    198  1.1  tsutsui 
    199  1.1  tsutsui /*
    200  1.1  tsutsui  * Compression.
    201  1.1  tsutsui  */
    202  1.1  tsutsui struct udl_huffman {
    203  1.1  tsutsui 	uint8_t		bit_count;
    204  1.1  tsutsui 	uint8_t		pad[3];
    205  1.1  tsutsui 	uint32_t	bit_pattern;
    206  1.1  tsutsui };
    207  1.1  tsutsui #define UDL_HUFFMAN_RECORD_SIZE		sizeof(struct udl_huffman)
    208  1.1  tsutsui #define UDL_HUFFMAN_RECORDS		(65536 + 1)
    209  1.1  tsutsui #define UDL_HUFFMAN_BASE		(((UDL_HUFFMAN_RECORDS - 1) / 2) * \
    210  1.1  tsutsui 					    UDL_HUFFMAN_RECORD_SIZE)
    211