1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
/* Copyright (C) 1992 Aladdin Enterprises. All rights reserved.
This file is part of GNU Ghostscript.
GNU Ghostscript is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY. No author or distributor accepts responsibility to
anyone for the consequences of using it or for whether it serves any
particular purpose or works at all, unless he says so in writing. Refer
to the GNU Ghostscript General Public License for full details.
*/
/* zdosio.c */
/* MS-DOS direct I/O operators. */
/* These should NEVER be included in a released configuration! */
#include "dos_.h"
#include "ghost.h"
#include "errors.h"
#include "oper.h"
#include "store.h"
/* <port> .inport <word> */
private int
zinport(register os_ptr op)
{ check_type(*op, t_integer);
make_int(op, inport((int)op->value.intval));
return 0;
}
/* <port> .inportb <byte> */
private int
zinportb(register os_ptr op)
{ check_type(*op, t_integer);
make_int(op, inportb((int)op->value.intval));
return 0;
}
/* <port> <word> .outport - */
private int
zoutport(register os_ptr op)
{ check_type(*op, t_integer);
check_type(op[-1], t_integer);
outport((int)op[-1].value.intval, (int)op->value.intval);
pop(1);
return 0;
}
/* <port> <byte> .outportb - */
private int
zoutportb(register os_ptr op)
{ check_type(*op, t_integer);
check_int_leu(op[-1], 0xff);
outportb((int)op[-1].value.intval, (byte)op->value.intval);
pop(1);
return 0;
}
/* <loc> .peek <byte> */
private int
zpeek(register os_ptr op)
{ check_type(*op, t_integer);
make_int(op, *(byte *)(op->value.intval));
return 0;
}
/* <loc> <byte> .poke - */
private int
zpoke(register os_ptr op)
{ check_type(*op, t_integer);
check_int_leu(op[-1], 0xff);
*(byte *)(op[-1].value.intval) = (byte)op->value.intval;
pop(1);
return 0;
}
/* ------ Operator initialization ------ */
BEGIN_OP_DEFS(zdosio_op_defs) {
{"1.inport", zinport},
{"1.inportb", zinportb},
{"2.outport", zoutport},
{"2.outportb", zoutportb},
{"1.peek", zpeek},
{"2.poke", zpoke},
END_OP_DEFS(0) }
|