/* * $Id: test.c,v 1.22 2004/01/25 17:20:50 phil Exp - revised by DAG $ * XY Display simulator test program (PDP-1 Munching Squares) * Phil Budne * September 2003 * * Updates from Douglas A. Gwyn, 12 Jan. 2004 * * With thanks to Daniel Smith for his web page: * http://world.std.com/~dpbsmith/munch.html */ /* * Copyright (c) 2003-2004, Philip L. Budne * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * Except as contained in this notice, the names of the authors shall * not be used in advertising or otherwise to promote the sale, use or * other dealings in this Software without prior written authorization * from the authors. */ #ifndef TEST_DIS #define TEST_DIS DIS_TYPE30 #endif #ifndef TEST_RES #define TEST_RES RES_HALF #endif #include #include #ifndef EXIT_FAILURE /* SunOS4 doesn't define this */ #define EXIT_FAILURE 1 #endif #include "display.h" static unsigned long test_switches = 0; /* called from display code: */ unsigned long cpu_get_switches(void) { return test_switches; } /* called from display code: */ void cpu_set_switches(bits) unsigned long bits; { printf("switches: %06lo\n", bits); test_switches = bits; } void munch(void) { static long us = 0; static long io = 0, v = 0; long ac; int x, y; ac = test_switches; ac += v; /* add v */ if (ac & ~0777777) { ac++; ac &= 0777777; } v = ac; /* dac v */ ac <<= 9; /* rcl 9s */ io <<= 9; io |= ac>>18; ac &= 0777777; ac |= io>>18; io &= 0777777; ac ^= v; /* xor v */ /* convert +/-512 one's complement to 0..1022, origin in lower left */ y = (io >> 8) & 01777; /* hi 10 */ if (y & 01000) y ^= 01000; else y += 511; x = (ac >> 8) & 01777; /* hi 10 */ if (x & 01000) /* negative */ x ^= 01000; else x += 511; if (display_point(x, y, DISPLAY_INT_MAX, 0)) printf("light pen hit at (%d,%d)\n", x, y); /*#define US 100000 /* 100ms (10/sec) */ /*#define US 50000 /* 50ms (20/sec) */ /*#define US 20000 /* 20ms (50/sec) */ /*#define US 10000 /* 10ms (100/sec) */ #define US 0 us += 50; /* 10 5us PDP-1 memory cycles */ if (us >= US) { display_age(us, 1); us = 0; } display_sync(); /* XXX push down */ } #ifdef T2 /* display all window system level intensities; * must be compiled with -DINTENSITIES= -DT2 */ void t2(void) { int x, y; display_init(TEST_DIS, TEST_RES, NULL); for (x = INTENSITIES-1; x >= 0; x--) { for (y = 0; y < 20; y++) { ws_display_point(x*4, y, x, 0); ws_display_point(x*4+1, y, x, 0); ws_display_point(x*4+2, y, x, 0); ws_display_point(x*4+3, y, x, 0); } display_sync(); } fflush(stdout); for (;;) /* wait */ ; } #endif #ifdef T3 /* display all "user" level intensities; * must be compiled with -DINTENSITIES= -DT3 * * skip every other virtual point on both axes * default scaling maps adjacent pixels and * causes re-intensification! */ void t3(void) { int x, y; display_init(TEST_DIS, TEST_RES, NULL); for (x = DISPLAY_INT_MAX; x >= 0; x--) { for (y = 0; y < 20; y++) { display_point(x*2, y*2, x, 0); } display_sync(); } fflush(stdout); for (;;) /* wait */ ; } #endif int main(void) { if (!display_init(TEST_DIS, TEST_RES, NULL)) exit(EXIT_FAILURE); cpu_set_switches(04000UL); /* classic starting value */ for (;;) { #ifdef T2 t2(); #endif #ifdef T3 t3(); #endif munch(); } /*NOTREACHED*/ }