NetBSD/sys/arch/amiga/dev/itevar.h
gehenna 77a6b82b27 Merge the gehenna-devsw branch into the trunk.
This merge changes the device switch tables from static array to
dynamically generated by config(8).

- All device switches is defined as a constant structure in device drivers.

- The new grammer ``device-major'' is introduced to ``files''.

	device-major <prefix> char <num> [block <num>] [<rules>]

- All device major numbers must be listed up in port dependent majors.<arch>
  by using this grammer.

- Added the new naming convention.
  The name of the device switch must be <prefix>_[bc]devsw for auto-generation
  of device switch tables.

- The backward compatibility of loading block/character device
  switch by LKM framework is broken. This is necessary to convert
  from block/character device major to device name in runtime and vice versa.

- The restriction to assign device major by LKM is completely removed.
  We don't need to reserve LKM entries for dynamic loading of device switch.

- In compile time, device major numbers list is packed into the kernel and
  the LKM framework will refer it to assign device major number dynamically.
2002-09-06 13:18:43 +00:00

213 lines
5.4 KiB
C

/* $NetBSD: itevar.h,v 1.16 2002/09/06 13:18:43 gehenna Exp $ */
/*
* Copyright (c) 1994 Christian E. Hopps
* 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.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by Christian E. Hopps.
* 4. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
* 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.
*/
#if ! defined (_ITEVAR_H)
#define _ITEVAR_H
enum ite_arraymaxs {
MAX_ARGSIZE = 256,
MAX_TABS = 256,
};
enum ite_attr {
ATTR_NOR = 0,
ATTR_INV = 1,
ATTR_UL = 2,
ATTR_BOLD = 4,
ATTR_BLINK = 8,
ATTR_ALL = 16-1,
ATTR_KEYPAD = 0x80 /* XXX */
};
struct ite_softc {
struct device device;
struct tty *tp;
char argbuf[MAX_ARGSIZE];
struct grf_softc *grf; /* XXX */
void *priv;
char *ap;
u_char *tabs;
int flags;
int open_count;
short cursorx;
short cursory;
short rows;
short cols;
u_char *font;
u_char *cursor;
u_char font_lo;
u_char font_hi;
short cpl; /* XXX? */
short ftheight;
short ftwidth;
short ftbaseline;
short ftboldsmear;
short planemask;
short pos;
char imode;
char fpd;
char hold;
u_char escape;
u_char cursor_opt;
u_char key_repeat;
char GL;
char GR;
char G0;
char G1;
char G2;
char G3;
char linefeed_newline;
char auto_wrap;
char cursor_appmode;
char keypad_appmode;
short top_margin;
short bottom_margin;
short inside_margins;
short eightbit_C1;
short emul_level;
enum ite_attr attribute;
enum ite_attr save_attribute;
int curx;
int save_curx;
int cury;
int save_cury;
};
enum ite_flags {
ITE_ALIVE = 0x1, /* grf layer is configed */
ITE_ISCONS = 0x2, /* ite is acting console. */
ITE_INITED = 0x4, /* ite has been inited. */
ITE_ISOPEN = 0x8, /* ite has been opened */
ITE_INGRF = 0x10, /* ite is in graphics mode */
ITE_ACTIVE = 0x20, /* ite is an active terminal */
};
enum ite_replrules {
RR_CLEAR = 0,
RR_COPY = 0x3,
RR_XOR = 0x6,
RR_COYINVERTED = 0xC
};
enum ite_scrolldir {
SCROLL_UP = 1,
SCROLL_DOWN,
SCROLL_LEFT,
SCROLL_RIGHT,
};
enum ite_cursact {
DRAW_CURSOR = 5,
ERASE_CURSOR,
MOVE_CURSOR,
START_CURSOROPT,
END_CURSOROPT
};
enum ite_special_keycodes {
KBD_LEFT_SHIFT = 0x60,
KBD_RIGHT_SHIFT,
KBD_CAPS_LOCK,
KBD_CTRL,
KBD_LEFT_ALT,
KBD_RIGHT_ALT,
KBD_LEFT_META,
KBD_RIGHT_META
};
enum ite_modifiers {
KBD_MOD_LSHIFT = (1 << (KBD_LEFT_SHIFT - KBD_LEFT_SHIFT)),
KBD_MOD_RSHIFT = (1 << (KBD_RIGHT_SHIFT- KBD_LEFT_SHIFT)),
KBD_MOD_CTRL = (1 << (KBD_CTRL - KBD_LEFT_SHIFT)),
KBD_MOD_LALT = (1 << (KBD_LEFT_ALT - KBD_LEFT_SHIFT)),
KBD_MOD_RALT = (1 << (KBD_RIGHT_ALT- KBD_LEFT_SHIFT)),
KBD_MOD_LMETA = (1 << (KBD_LEFT_META - KBD_LEFT_SHIFT)),
KBD_MOD_RMETA = (1 << (KBD_RIGHT_META- KBD_LEFT_SHIFT)),
KBD_MOD_CAPS = (1 << (KBD_CAPS_LOCK - KBD_LEFT_SHIFT)),
KBD_MOD_SHIFT = (KBD_MOD_LSHIFT | KBD_MOD_RSHIFT),
KBD_MOD_ALT = (KBD_MOD_LALT | KBD_MOD_RALT),
KBD_MOD_META = (KBD_MOD_LMETA | KBD_MOD_RMETA),
};
enum caller {
ITEFILT_TTY,
ITEFILT_CONSOLE,
ITEFILT_REPEATER
};
enum emul_level {
EMUL_VT100 = 1,
EMUL_VT300_8,
EMUL_VT300_7
};
enum ite_max_getsize { ITEBURST = 64 };
enum tab_size { TABSIZE = 8 };
#define TABEND(u) (ite_tty[u]->t_windsize.ws_col - TABSIZE) /* XXX */
#define set_attr(ip, attr) ((ip)->attribute |= (attr))
#define clr_attr(ip, attr) ((ip)->attribute &= ~(attr))
#define attrloc(ip, y, x) 0
#define attrclr(ip, sy, sx, h, w)
#define attrmov(ip, sy, sx, dy, dx, h, w)
#define attrtest(ip, attr) 0
#define attrset(ip, attr)
struct proc;
struct consdev;
struct termios;
/* console related function */
void itecnprobe(struct consdev *);
void itecninit(struct consdev *);
int itecngetc(dev_t);
void itecnputc(dev_t, int);
void ite_cnfinish(struct ite_softc *);
/* standard ite device entry points. */
void iteinit(dev_t);
void itestart(struct tty *);
/* ite functions */
int ite_on(dev_t, int);
void ite_off(dev_t, int);
void ite_reinit(dev_t);
int ite_param(struct tty *, struct termios *);
void ite_reset(struct ite_softc *);
int ite_cnfilter(u_char, enum caller);
void ite_filter(u_char ,enum caller);
int ite_grf_ioctl(struct ite_softc *, u_long, caddr_t, int, struct proc *);
#endif /* _ITEVAR_H */