DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - download
Index: ┃ T a

⟦b16a1acf4⟧ TextFile

    Length: 4022 (0xfb6)
    Types: TextFile
    Names: »apa8.h«

Derivation

└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
    └─ ⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« 
        └─⟦2109abc41⟧ 
            └─ ⟦this⟧ »./X.V10R4/libibm/libsrc/apa8.h« 

TextFile

/* $Header: apa8.h,v 10.1 86/11/19 10:45:09 jg Exp $ */
/* apa8.h - Definition and macros required to access APA8
 *
 *	Defines required to support APA8
 *
 *  	Author:
 *		Scott Bates
 *		Brown University
 *		IRIS, Box 1946
 *      	Providence, RI 02912
 *
 *
 *		Copyright (c) 1986 Brown University
 *
 * Permission to use, copy, modify and distribute this software and its
 * documentation for any purpose and without fee is hereby granted, provided
 * that the above copyright notice appear in all copies, and that both
 * that copyright notice and this permission notice appear in supporting
 * documentation, and that the name of Brown University not be used in
 * advertising or publicity pertaining to distribution of the software
 * without specific, written prior permission. Brown University makes no
 * representations about the suitability of this software for any purpose.
 * It is provided "as-is" without express or implied warranty.
 */

#define SCREEN_BASE (0xF4D00000)	/* base address for screen bitmap */
#define XDEV_ID	XDEV_IBMAPA8		/* device id for info structure */

#define REAL_SCREEN_WIDTH 	1024	/* number of bits/line for apa8 */
#define REAL_SCREEN_HEIGHT	512	/* Number of lines on apa8 */

#define X_SCREEN_WIDTH 	720		/* visible bits/line for apa8 */
#define X_SCREEN_HEIGHT	512		/* visible lines on the screen */

#define SCREEN_DEVICE   "/dev/apa8"	/* device name */
#define MOUSE_DEVICE	"/dev/msapa8"	/* device name of mouse for display */

#define CURSOR_TYPE	SOFT_CURSOR	/* apa8 uses software cursor */

#define DISPLAY_INIT()	apa8_init()	/* display initialization routine */

/*
 * Control register (short)
 */

#define FC 0xF0000160

/*
 * Data mask registers (2 each 8 bits)
 */

#define DM 0xF0000162

/*
 * Display memory for the APA8
 */

#define FB SCREEN_BASE

/*
 * bits 0-2  rotate count
 */

#define DCR_ROTMASK 0x0007

/*
 * bits 3-5  logic unit function control
 */

#define DCR_FCMASK	0x0038
#define DCR_FCOR	0x0028
#define DCR_FCNOR	0x0038
#define DCR_FCPA	0x0010
#define DCR_FCPB	0x0000
#define DCR_FCPNA	0x0030
#define DCR_FCPNB	0x0020

#define DEFAULT_FUNC	DCR_FCPNB
#define HIDDEN_FUNC     DCR_FCPA
#define RDWR_FUNC	DCR_FCPA

/*
 * 8-9 memory mode
 */

#define DCR_MEMMODE	0x0300
#define DCR_SWR		0x0000
#define DCR_ISWR	0x0100
#define DCR_ADWR	0x0200
#define DCR_AURW	0x0300

/*
 * 10 inc/dec of the address counter
 */

#define DCR_DEC		0x0400
#define DCR_INC		~0x0400

/*
 * 11 x/y stepping
 */

#define DCR_X		0x0800
#define DCR_Y		~0x0800

/*
 * 12  1 means block transfer
 */

#define DCR_BT		0x1000

/*
 * 13  1 means interrupt enable
 */

#define DCR_IEN		0x2000

/*
 * 14  1 means Sync enable
 */

#define DCR_SEN		0x4000

/*
 * 15  1 means Video enable
 */

#define DCR_VEN		0x8000

/*
 * Data Mask Register masks (typically are the inverse of each other)
 */

#define DM_A		0xFF00
#define DM_B		0x00FF

#define CLEAR_DM	0x0000
#define DEFAULT_DM	DM_B
#define HIDDEN_DM       DM_A
#define RDWR_DM		DM_A

/*
 * values for the writemask.
 */

#define NOMASK 0x0000
#define MASKBYTE2 0x00FF
#define MASKBYTE1 0xFF00

/*
 * Bitmap to BUS address offsets.  All address offsets in the bitmap area
 * must be multiplied by 2 before being used as BUS offsets.
 */

#define BM_TO_BUS(n)	((n) << 1)

/*
 * The physical bitmap addresses on the apa8 adaptor card go
 * from 0x0000 to 0xFFFF. (the size of a short or word, 16 bits
 * addresses these spots.
 */

#define MAXOFFSET 0xFFFF

/*
 * This is defined to be the last scan line in the hidden area.
 * It is needed because the side affect of setting the writemask
 * registers is the mask is also written to the bitmap.
 */

#define WRMASK_SCREEN_BASE					\
	(*(u_short *)(SCREEN_BASE + BM_TO_BUS(MAXOFFSET - 1)))

#define SET_FC(control_info)	{			\
	*(u_short *) FC = (u_short)(control_info);	\
}

#define SET_WRITEMASK(mask) {						\
	SET_FC(DCR_SEN | DCR_VEN | DCR_ISWR | DCR_X | DCR_FCOR);	\
	WRMASK_SCREEN_BASE = (u_short) mask;				\
}

#define SET_DATAMASK(mask) {			\
	*(u_short *)DM = (u_short) mask;	\
}