/*	$OpenBSD: cgtwelvereg.h,v 1.2 2006/07/20 11:23:49 martin Exp $	*/

/*
 * Copyright (c) 2002 Miodrag Vallat.  All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

/*
 * cgtwelve (GS) accelerated 24-bit framebuffer driver.
 *
 * Memory layout and scarce register information from SMI's cg12reg.h
 */

#define	CG12_HEIGHT		900
#define	CG12_WIDTH		1152

#define	CG12_HEIGHT_HR		1024
#define	CG12_WIDTH_HR		1280

/* offsets from the card mapping */
#define	CG12_OFF_DPU		0x040100
#define	CG12_OFF_APU		0x040200
#define	CG12_OFF_DAC		0x040300
#define	CG12_OFF_OVERLAY0	0x700000
#define	CG12_OFF_OVERLAY1	0x780000
#define	CG12_OFF_INTEN		0xc00000

#define	CG12_OFF_OVERLAY0_HR	0xe00000
#define	CG12_OFF_OVERLAY1_HR	0xf00000
#define	CG12_OFF_INTEN_HR	0x800000

/* sizes of various parts */
#define	CG12_SIZE_DPU		0x000100
#define	CG12_SIZE_APU		0x000100
#define	CG12_SIZE_DAC		0x000400
#define	CG12_SIZE_OVERLAY	0x020000
#define	CG12_SIZE_ENABLE	0x020000
#define	CG12_SIZE_COLOR8	0x100000
#define	CG12_SIZE_COLOR24	0x400000

#define	CG12_SIZE_OVERLAY_HR	0x030000
#define	CG12_SIZE_ENABLE_HR	0x030000
#define	CG12_SIZE_COLOR8_HR	0x180000
#define	CG12_SIZE_COLOR24_HR	0x600000

/*
 * The "direct port access" register constants.
 * All HACCESS values include noHSTXY, noHCLIP, and SWAP.
 */

#define	CG12_HPAGE_OVERLAY	0x00000700	/* overlay page */
#define	CG12_HPAGE_OVERLAY_HR	0x00000e00
#define	CG12_HACCESS_OVERLAY	0x00000020	/* 1bit/pixel */
#define	CG12_PLN_SL_OVERLAY	0x00000017	/* plane 23 */
#define	CG12_PLN_WR_OVERLAY	0x00800000	/* write mask */
#define	CG12_PLN_RD_OVERLAY	0xffffffff	/* read mask */

#define	CG12_HPAGE_ENABLE	0x00000700	/* overlay page */
#define	CG12_HPAGE_ENABLE_HR	0x00000e00
#define	CG12_HACCESS_ENABLE	0x00000020	/* 1bit/pixel */
#define	CG12_PLN_SL_ENABLE	0x00000016	/* plane 22 */
#define	CG12_PLN_WR_ENABLE	0x00400000
#define	CG12_PLN_RD_ENABLE	0xffffffff

#define	CG12_HPAGE_24BIT	0x00000500	/* intensity page */
#define	CG12_HPAGE_24BIT_HR	0x00000a00
#define	CG12_HACCESS_24BIT	0x00000025	/* 32bits/pixel */
#define	CG12_PLN_SL_24BIT	0x00000000	/* planes 0-31 */
#define	CG12_PLN_WR_24BIT	0x00ffffff
#define	CG12_PLN_RD_24BIT	0x00ffffff

#define	CG12_HPAGE_8BIT		0x00000500	/* intensity page */
#define	CG12_HPAGE_8BIT_HR	0x00000a00
#define	CG12_HACCESS_8BIT	0x00000023	/* 8bits/pixel */
#define	CG12_PLN_SL_8BIT	0x00000000	/* planes 0-7 */
#define	CG12_PLN_WR_8BIT	0x00ffffff
#define	CG12_PLN_RD_8BIT	0x000000ff

#define	CG12_HPAGE_WID		0x00000700	/* overlay page */
#define	CG12_HPAGE_WID_HR	0x00000e00
#define	CG12_HACCESS_WID	0x00000023	/* 8bits/pixel */
#define	CG12_PLN_SL_WID		0x00000010	/* planes 16-23 */
#define	CG12_PLN_WR_WID		0x003f0000
#define	CG12_PLN_RD_WID		0x003f0000

#define	CG12_HPAGE_ZBUF		0x00000000	/* depth page */
#define	CG12_HPAGE_ZBUF_HR	0x00000000
#define	CG12_HACCESS_ZBUF	0x00000024	/* 16bits/pixel */
#define	CG12_PLN_SL_ZBUF	0x00000060
#define	CG12_PLN_WR_ZBUF	0xffffffff
#define	CG12_PLN_RD_ZBUF	0xffffffff

/* Direct Port Unit */
struct cgtwelve_dpu {
	u_int32_t	r[8];
	u_int32_t	reload_ctl;
	u_int32_t	reload_stb;
	u_int32_t	alu_ctl;
	u_int32_t	blu_ctl;
	u_int32_t	control;
	u_int32_t	xleft;
	u_int32_t	shift0;
	u_int32_t	shift1;
	u_int32_t	zoom;
	u_int32_t	bsr;
	u_int32_t	color0;
	u_int32_t	color1;
	u_int32_t	compout;
	u_int32_t	pln_rd_msk_host;
	u_int32_t	pln_wr_msk_host;
	u_int32_t	pln_rd_msk_local;
	u_int32_t	pln_wr_msk_local;
	u_int32_t	scis_ctl;
	u_int32_t	csr;
	u_int32_t	pln_reg_sl;
	u_int32_t	pln_sl_host;
	u_int32_t	pln_sl_local0;
	u_int32_t	pln_sl_local1;
	u_int32_t	broadcast;
};

/* APU */
struct cgtwelve_apu {   
	u_int32_t	imsg0;
	u_int32_t	msg0;
	u_int32_t	imsg1;
	u_int32_t	msg1;
	u_int32_t	ien0;
	u_int32_t	ien1;
	u_int32_t	iclear;
	u_int32_t	istatus;
	u_int32_t	cfcnt;
	u_int32_t	cfwptr;
	u_int32_t	cfrptr;
	u_int32_t	cfilev0;
	u_int32_t	cfilev1;
	u_int32_t	rfcnt;
	u_int32_t	rfwptr;
	u_int32_t	rfrptr;
	u_int32_t	rfilev0;
	u_int32_t	rfilev1;
	u_int32_t	size;
	u_int32_t	res0;
	u_int32_t	res1;
	u_int32_t	res2;
	u_int32_t	haccess;
	u_int32_t	hpage;
	u_int32_t	laccess;
	u_int32_t	lpage;
	u_int32_t	maccess;
	u_int32_t	ppage;
	u_int32_t	dwg_ctl;
	u_int32_t	sam;
	u_int32_t	sgn;
	u_int32_t	length;
	u_int32_t	dwg[8];
	u_int32_t	reload_ctl;
	u_int32_t	reload_stb;
	u_int32_t	c_xleft;
	u_int32_t	c_ytop;
	u_int32_t	c_xright;
	u_int32_t	c_ybot;
	u_int32_t	f_xleft;
	u_int32_t	f_xright;
	u_int32_t	x_dst;
	u_int32_t	y_dst;
	u_int32_t	dst_ctl;
	u_int32_t	morigin;
	u_int32_t	vsg_ctl;
	u_int32_t	h_sync;
	u_int32_t	hblank;
	u_int32_t	v_sync;
	u_int32_t	vblank;
	u_int32_t	vdpyint;
	u_int32_t	vssyncs;
	u_int32_t	hdelays;
	u_int32_t	stdaddr;
	u_int32_t	hpitches;
	u_int32_t	zoom;
	u_int32_t	test;
};

struct cgtwelve_dac
{
	u_int32_t	addr_lo;
	u_int8_t	pad1[0x100 - 4];
	u_int32_t	addr_hi;
	u_int8_t	pad2[0x100 - 4];
	u_int32_t	control;
	u_int8_t	pad3[0x100 - 4];
	u_int32_t	color;
	u_int8_t	pad4[0x100 - 4];
};