Home | History | Annotate | Line # | Download | only in ic
      1 /*	$NetBSD: bt462reg.h,v 1.1 2010/06/24 03:30:36 macallan Exp $ */
      2 
      3 /*-
      4  * Copyright (c) 2010 Michael Lorenz
      5  * All rights reserved.
      6  *
      7  * Redistribution and use in source and binary forms, with or without
      8  * modification, are permitted provided that the following conditions
      9  * are met:
     10  * 1. Redistributions of source code must retain the above copyright
     11  *    notice, this list of conditions and the following disclaimer.
     12  * 2. Redistributions in binary form must reproduce the above copyright
     13  *    notice, this list of conditions and the following disclaimer in the
     14  *    documentation and/or other materials provided with the distribution.
     15  *
     16  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     17  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     18  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     19  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     20  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     21  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     22  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     23  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     24  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     25  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     26  * POSSIBILITY OF SUCH DAMAGE.
     27  */
     28 
     29 /*
     30  * register definitions for the Bt461/Bt462 RAMDAC
     31  *
     32  * There are four registers, how exactly to access them depends on the host so
     33  * we don't provide constants for them. All registers are 8 bit wide:
     34  * - register 0 provides the lower 8 index bits
     35  * - register 1 provides the upper 2 index bits
     36  * - register 2 accesses the alternate colour map ( 256 entries ), overlay
     37  *   colour map ( 32 enttries ) and control registers
     38  * - register 3 accesses the main colour map ( 1024 entries )
     39  */
     40 
     41 #ifndef BT462REG_H
     42 #define BT462REG_H
     43 
     44 /* offsets for register 2 */
     45 #define BT462_ALT_CMAP		0x0000
     46 #define BT462_OVL_CMAP		0x0100
     47 #define BT462_ID		0x0200
     48 	#define ID_BT461	0x4d
     49 	#define	ID_BT462	0x4c
     50 
     51 #define BT462_CMD_0		0x0201
     52 	#define BT462_C0_BLINK_16_48	0x00
     53 	#define BT462_C0_BLINK_16_16	0x04
     54 	#define BT462_C0_BLINK_32_32	0x08
     55 	#define BT462_C0_BLINK_64_64	0x0c
     56 	#define BT462_C0_ALT_ENABLE	0x10
     57 	#define BT462_C0_OVL_OPAQUE	0x20	/* use ovl 0, not cmap */
     58 	#define BT462_C0_MULT_3_1	0x00
     59 	#define BT462_C0_MULT_4_1	0x40
     60 	#define BT462_C0_MULT_5_1	0xc0
     61 
     62 #define BT462_CMD_1		0x0202
     63 	#define BT462_C1_PAN_0		0x00
     64 	#define BT462_C1_PAN_1		0x20
     65 	#define BT462_C1_PAN_2		0x40
     66 	#define BT462_C1_PAN_3		0x80
     67 	#define BT462_C1_PAN_4		0xa0
     68 
     69 #define BT462_CMD_2		0x0203
     70 	#define BT462_C2_TEST_ENABLE	0x01
     71 	#define BT462_C2_UNDERLAY_EN	0x04	/* Bt462 only */
     72 	#define BT462_C2_PLL_USE_BLANK	0x08	/* SYNC otherwise */
     73 	#define BT462_C2_LOAD_ALWAYS	0x00
     74 	#define BT462_C2_LOAD_ON_RED	0x10
     75 	#define BT462_C2_LOAD_ON_GREEN	0x20
     76 	#define BT462_C2_LOAD_ON_BLUE	0x30
     77 	#define BT462_C2_PEDESTAL_EN	0x40
     78 	#define BT462_C2_SYNC_ENABLE	0x80
     79 
     80 #define BT462_PIXEL_READ_MSK_L	0x0204
     81 #define BT462_PIXEL_READ_MSK_H	0x0205
     82 #define BT462_PIXEL_BLNK_MSK_L	0x0206
     83 #define BT462_PIXEL_BLNK_MSK_H	0x0207
     84 #define BT462_OVL_READ_MSK	0x0208
     85 #define BT462_OVL_BLNK_MSK	0x0209
     86 #define BT462_TEST		0x020c
     87 
     88 #endif /* BT462REG_H */
     89