1247N/A/*
1247N/A * Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved.
1247N/A *
1247N/A * Permission is hereby granted, free of charge, to any person obtaining a
1247N/A * copy of this software and associated documentation files (the "Software"),
1247N/A * to deal in the Software without restriction, including without limitation
1247N/A * the rights to use, copy, modify, merge, publish, distribute, sublicense,
1247N/A * and/or sell copies of the Software, and to permit persons to whom the
1247N/A * Software is furnished to do so, subject to the following conditions:
1247N/A *
1247N/A * The above copyright notice and this permission notice (including the next
1247N/A * paragraph) shall be included in all copies or substantial portions of the
1247N/A * Software.
1247N/A *
1247N/A * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1247N/A * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1247N/A * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
1247N/A * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
1247N/A * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
1247N/A * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
1247N/A * DEALINGS IN THE SOFTWARE.
1247N/A */
1247N/A
1247N/A#include "libvtsSUNWmga.h" /* VTS library definitions for mga device */
1247N/A
1247N/Amga_info_t mga_info;
1247N/A
1247N/Amga_xw_t mga_xw;
1247N/A
1247N/Astatic gfxtest_info *tests_info;
1247N/A
1247N/A/* Declarations needed for get_tests() */
1247N/A
1247N/Astatic unsigned int mga_mask_list[] = {
1247N/A GRAPHICS_TEST_OPEN,
1247N/A GRAPHICS_TEST_DMA,
1247N/A GRAPHICS_TEST_MEM,
1247N/A GRAPHICS_TEST_CHIP,
1247N/A};
1247N/A
1247N/Astatic unsigned int mga_mesg_list[] = {
1247N/A GRAPHICS_TEST_OPEN_MESG,
1247N/A GRAPHICS_TEST_DMA_MESG,
1247N/A GRAPHICS_TEST_MEM_MESG,
1247N/A GRAPHICS_TEST_CHIP_MESG,
1247N/A};
1247N/A
1247N/Astatic gfxtest_function mga_test_list[] = {
1247N/A mga_test_open,
1247N/A mga_test_dma,
1247N/A mga_test_memory,
1247N/A mga_test_chip
1247N/A};
1247N/A
1247N/A
1247N/A/* *** PUBLIC *** */
1247N/A
1247N/A/* These library functions are public and are expected to exist */
1247N/A
1247N/Aint
1247N/Aget_tests(
1247N/A register gfxtest_info *const tests)
1247N/A{
1247N/A /*
1247N/A * Set the gfx_vts_debug_mask bits according to environment variables
1247N/A */
1247N/A gfx_vts_set_debug_mask();
1247N/A
1247N/A /*
1247N/A * Construct the list of tests to be performed
1247N/A */
1247N/A tests->count = sizeof (mga_test_list) / sizeof (gfxtest_function);
1247N/A tests->this_test_mask = (int *)malloc(sizeof (mga_mask_list));
1247N/A tests->this_test_mesg = (int *)malloc(sizeof (mga_mesg_list));
1247N/A tests->this_test_function =
1247N/A (gfxtest_function *)malloc(sizeof (mga_test_list));
1247N/A
1247N/A if ((tests->this_test_mask == NULL) ||
1247N/A (tests->this_test_mesg == NULL) ||
1247N/A (tests->this_test_function == NULL)) {
1247N/A gfx_vts_free_tests(tests);
1247N/A return (GRAPHICS_ERR_MALLOC_FAIL);
1247N/A }
1247N/A
1247N/A tests->connection_test_function = mga_test_open;
1247N/A
1247N/A memcpy(tests->this_test_mask, mga_mask_list, sizeof (mga_mask_list));
1247N/A memcpy(tests->this_test_mesg, mga_mesg_list, sizeof (mga_mesg_list));
1247N/A memcpy(tests->this_test_function, mga_test_list,
1247N/A sizeof (mga_test_list));
1247N/A
1247N/A tests_info = tests;
1247N/A return (0);
1247N/A
1247N/A} /* get_tests() */
1247N/A
1247N/A
1247N/Aint
1247N/Acleanup_tests(
1247N/A register gfxtest_info *const tests)
1247N/A{
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "cleanup_tests",
1247N/A "call cleanup_tests\n");
1247N/A gfx_vts_free_tests(tests);
1247N/A
1247N/A return (0);
1247N/A} /* cleanup_tests() */
1247N/A
1247N/A
1247N/Avoid
1247N/Amga_block_signals(
1247N/A void)
1247N/A{
1247N/A sigset_t newprocmask;
1247N/A
1247N/A sigemptyset(&newprocmask);
1247N/A sigaddset(&newprocmask, SIGHUP);
1247N/A sigaddset(&newprocmask, SIGINT);
1247N/A sigaddset(&newprocmask, SIGTERM);
1247N/A sigaddset(&newprocmask, SIGALRM);
1247N/A
1247N/A sigprocmask(SIG_BLOCK, &newprocmask, &mga_xw.xw_procmask);
1247N/A}
1247N/A
1247N/A
1247N/Avoid
1247N/Amga_restore_signals(
1247N/A void)
1247N/A{
1247N/A sigprocmask(SIG_SETMASK, &mga_xw.xw_procmask, (sigset_t *) NULL);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_lock_display(
1247N/A void)
1247N/A{
1247N/A if (gfx_vts_debug_mask & GRAPHICS_VTS_SLOCK_OFF) {
1247N/A TraceMessage(VTS_DEBUG, "mga_lock_display",
1247N/A "mga_lock_display() DISABLED\n");
1247N/A return (0);
1247N/A }
1247N/A
1247N/A if (!mga_open_display()) {
1247N/A return (0);
1247N/A }
1247N/A
1247N/A mga_create_cursor();
1247N/A
1247N/A mga_create_window();
1247N/A
1247N/A /* Disable server from handling any requests */
1247N/A mga_grab_server();
1247N/A
1247N/A /* Gain control of keyboard */
1247N/A mga_grab_keyboard();
1247N/A
1247N/A /* Gain control of pointer */
1247N/A mga_grab_pointer();
1247N/A
1247N/A mga_disable_screensaver();
1247N/A
1247N/A mga_disable_dpms();
1247N/A
1247N/A XMapRaised(mga_xw.xw_display, mga_xw.xw_window);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_lock_display",
1247N/A "XMapRaised(display, 0x%lx)\n",
1247N/A (unsigned long) mga_xw.xw_window);
1247N/A
1247N/A return (1);
1247N/A
1247N/A} /* mga_lock_display() */
1247N/A
1247N/Aint
1247N/Amga_unlock_display(
1247N/A void)
1247N/A{
1247N/A if (mga_xw.xw_display == NULL)
1247N/A return (0);
1247N/A
1247N/A XUnmapWindow(mga_xw.xw_display, mga_xw.xw_window);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_unlock_display",
1247N/A "XUnmapWindow(display, 0x%lx)\n",
1247N/A (unsigned long) mga_xw.xw_window);
1247N/A
1247N/A mga_restore_dpms();
1247N/A
1247N/A mga_restore_screensaver();
1247N/A
1247N/A mga_ungrab_pointer();
1247N/A
1247N/A mga_ungrab_keyboard();
1247N/A
1247N/A mga_ungrab_server();
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_open_display(
1247N/A void)
1247N/A{
1247N/A if (mga_xw.xw_dispname == NULL)
1247N/A mga_xw.xw_dispname = ":0.0";
1247N/A
1247N/A if (mga_xw.xw_display == NULL) {
1247N/A mga_xw.xw_display = XOpenDisplay(mga_xw.xw_dispname);
1247N/A
1247N/A if (mga_xw.xw_display == NULL) {
1247N/A TraceMessage(VTS_DEBUG, "mga_open_display",
1247N/A "XOpenDisplay(\"%s\") = NULL\n"
1247N/A "Assuming no window system.\n",
1247N/A mga_xw.xw_dispname);
1247N/A
1247N/A return (0);
1247N/A }
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_open_display",
1247N/A "XOpenDisplay(\"%s\") = 0x%p\n"
1247N/A "Assuming a window system.\n",
1247N/A mga_xw.xw_dispname, mga_xw.xw_display);
1247N/A }
1247N/A
1247N/A /* Tell server to report events as they occur */
1247N/A XSynchronize(mga_xw.xw_display, True);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_open_display",
1247N/A "XSynchronize(display, True).\n");
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_create_cursor(
1247N/A void)
1247N/A{
1247N/A register Window const root = RootWindow(mga_xw.xw_display,
1247N/A mga_xw.xw_screen);
1247N/A register Pixmap emptypixmap;
1247N/A XColor dummy_color = {0, 0, 0, 0, 0, 0};
1247N/A
1247N/A if (mga_xw.xw_cursor != 0)
1247N/A return (0);
1247N/A
1247N/A emptypixmap = XCreateBitmapFromData(mga_xw.xw_display, root, "", 1, 1);
1247N/A
1247N/A mga_xw.xw_cursor = XCreatePixmapCursor(mga_xw.xw_display,
1247N/A emptypixmap, emptypixmap, &dummy_color, &dummy_color, 0, 0);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_create_cursor",
1247N/A "XCreatePixmapCursor(display, 0x%lx, 0x%lx, &dummy_color, "
1247N/A "&dummy_color, 0, 0) = 0x%lx\n",
1247N/A (unsigned long) emptypixmap, (unsigned long) emptypixmap,
1247N/A (unsigned long) mga_xw.xw_cursor);
1247N/A
1247N/A XFreePixmap(mga_xw.xw_display, emptypixmap);
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_create_window(
1247N/A void)
1247N/A{
1247N/A register Window const root = RootWindow(mga_xw.xw_display,
1247N/A mga_xw.xw_screen);
1247N/A register int const width = DisplayWidth(mga_xw.xw_display,
1247N/A mga_xw.xw_screen);
1247N/A register int const height = DisplayHeight(mga_xw.xw_display,
1247N/A mga_xw.xw_screen);
1247N/A XSetWindowAttributes xswa;
1247N/A
1247N/A if (mga_xw.xw_window != NULL)
1247N/A return (0);
1247N/A
1247N/A memset(&xswa, 0, sizeof (xswa));
1247N/A xswa.cursor = mga_xw.xw_cursor;
1247N/A xswa.background_pixmap = None;
1247N/A xswa.override_redirect = True;
1247N/A xswa.backing_store = NotUseful;
1247N/A xswa.save_under = False;
1247N/A xswa.event_mask = KeyPressMask | KeyReleaseMask | ExposureMask;
1247N/A
1247N/A mga_xw.xw_window = XCreateWindow(mga_xw.xw_display,
1247N/A root, 0, 0, width, height,
1247N/A 0, CopyFromParent, InputOutput, CopyFromParent,
1247N/A CWBackPixmap | CWOverrideRedirect | CWBackingStore |
1247N/A CWSaveUnder | CWEventMask | CWCursor, &xswa);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_create_window",
1247N/A "XCreateWindow(display, 0x%lx, %d, %d, %d, %d, "
1247N/A "%d, %d, %d, %d, 0x%lx, &xswa) = 0x%lx\n",
1247N/A (unsigned long) root, 0, 0, width, height,
1247N/A 0, CopyFromParent, InputOutput, CopyFromParent,
1247N/A (unsigned long) (CWBackPixmap | CWOverrideRedirect |
1247N/A CWBackingStore | CWSaveUnder | CWEventMask | CWCursor),
1247N/A (unsigned long) mga_xw.xw_window);
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_grab_server(
1247N/A void)
1247N/A{
1247N/A if (mga_xw.xw_grab_server == True)
1247N/A return (0);
1247N/A
1247N/A mga_xw.xw_grab_server = XGrabServer(mga_xw.xw_display);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_grab_server",
1247N/A "XGrabServer(display)\n");
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_ungrab_server(
1247N/A void)
1247N/A{
1247N/A if (mga_xw.xw_grab_server != True)
1247N/A return (0);
1247N/A
1247N/A mga_xw.xw_grab_server = !XUngrabServer(mga_xw.xw_display);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_ungrab_server",
1247N/A "XUngrabServer(display)\n");
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_grab_keyboard(
1247N/A void)
1247N/A{
1247N/A register int status;
1247N/A
1247N/A if (mga_xw.xw_grab_keyboard == True)
1247N/A return (0);
1247N/A
1247N/A status = XGrabKeyboard(mga_xw.xw_display, mga_xw.xw_window,
1247N/A False, GrabModeAsync, GrabModeAsync, CurrentTime);
1247N/A mga_xw.xw_grab_keyboard = status == GrabSuccess;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_grab_keyboard",
1247N/A "XGrabKeyboard(display, 0x%lx, %d, %d, %d, %ld) = %d\n",
1247N/A (unsigned long) mga_xw.xw_window,
1247N/A False, GrabModeAsync, GrabModeAsync, CurrentTime,
1247N/A status);
1247N/A
1247N/A if (status != GrabSuccess) {
1247N/A TraceMessage(VTS_DEBUG, "mga_grab_keyboard",
1247N/A "Cannot gain control of keyboard\n");
1247N/A return (-1);
1247N/A
1247N/A } else {
1247N/A return (1);
1247N/A }
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_ungrab_keyboard(
1247N/A void)
1247N/A{
1247N/A register int status;
1247N/A
1247N/A if (mga_xw.xw_grab_keyboard != True)
1247N/A return (0);
1247N/A
1247N/A status = XUngrabKeyboard(mga_xw.xw_display, CurrentTime);
1247N/A
1247N/A mga_xw.xw_grab_keyboard = False;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_ungrab_keyboard",
1247N/A "XGrabKeyboard(display, %ld) = %d\n",
1247N/A CurrentTime, status);
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_grab_pointer(
1247N/A void)
1247N/A{
1247N/A register int status;
1247N/A
1247N/A if (mga_xw.xw_grab_pointer == True)
1247N/A return (0);
1247N/A
1247N/A status = XGrabPointer(mga_xw.xw_display, mga_xw.xw_window,
1247N/A False, ResizeRedirectMask, GrabModeAsync, GrabModeAsync,
1247N/A None, mga_xw.xw_cursor, CurrentTime);
1247N/A
1247N/A mga_xw.xw_grab_pointer = status == GrabSuccess;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_grab_pointer",
1247N/A "XGrabPointer(display, 0x%lx, %d, 0x%lx, %d, %d, "
1247N/A "%d, %d, %ld) = %d\n",
1247N/A (unsigned long) mga_xw.xw_window,
1247N/A False, ResizeRedirectMask,
1247N/A GrabModeAsync, GrabModeAsync,
1247N/A None, None, CurrentTime,
1247N/A status);
1247N/A
1247N/A if (status != GrabSuccess) {
1247N/A TraceMessage(VTS_DEBUG, "mga_grab_pointer",
1247N/A "Cannot gain control of pointer\n");
1247N/A return (-1);
1247N/A
1247N/A } else {
1247N/A return (1);
1247N/A }
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_ungrab_pointer(
1247N/A void)
1247N/A{
1247N/A register int status;
1247N/A
1247N/A if (mga_xw.xw_grab_pointer != True)
1247N/A return (0);
1247N/A
1247N/A status = XUngrabPointer(mga_xw.xw_display, CurrentTime);
1247N/A
1247N/A mga_xw.xw_grab_pointer = False;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_ungrab_pointer",
1247N/A "XGrabPointer(display, %ld) = %d\n",
1247N/A CurrentTime, status);
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_disable_screensaver(
1247N/A void)
1247N/A{
1247N/A XGetScreenSaver(mga_xw.xw_display,
1247N/A &mga_xw.xw_ss_timeout,
1247N/A &mga_xw.xw_ss_interval,
1247N/A &mga_xw.xw_ss_prefer_blanking,
1247N/A &mga_xw.xw_ss_allow_exposures);
1247N/A
1247N/A mga_xw.xw_ss_saved = True;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_disable_screensaver",
1247N/A "XGetScreenSaver(display) = %d, %d, %d, %d\n",
1247N/A mga_xw.xw_ss_timeout,
1247N/A mga_xw.xw_ss_interval,
1247N/A mga_xw.xw_ss_prefer_blanking,
1247N/A mga_xw.xw_ss_allow_exposures);
1247N/A
1247N/A /* Reset the screen saver to reset its time. */
1247N/A
1247N/A XResetScreenSaver(mga_xw.xw_display);
1247N/A
1247N/A mga_xw.xw_ss_disabled = True;
1247N/A
1247N/A XSetScreenSaver(mga_xw.xw_display,
1247N/A DisableScreenSaver,
1247N/A mga_xw.xw_ss_interval,
1247N/A mga_xw.xw_ss_prefer_blanking,
1247N/A mga_xw.xw_ss_allow_exposures);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_disable_screensaver",
1247N/A "XSetScreenSaver(display, %d, %d, %d, %d)\n",
1247N/A DisableScreenSaver,
1247N/A mga_xw.xw_ss_interval,
1247N/A mga_xw.xw_ss_prefer_blanking,
1247N/A mga_xw.xw_ss_allow_exposures);
1247N/A
1247N/A return (1);
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_restore_screensaver(
1247N/A void)
1247N/A{
1247N/A if (mga_xw.xw_ss_saved != True ||
1247N/A mga_xw.xw_ss_disabled != True) {
1247N/A mga_xw.xw_ss_disabled = False;
1247N/A mga_xw.xw_ss_saved = False;
1247N/A return (0);
1247N/A
1247N/A } else {
1247N/A XSetScreenSaver(mga_xw.xw_display,
1247N/A mga_xw.xw_ss_timeout,
1247N/A mga_xw.xw_ss_interval,
1247N/A mga_xw.xw_ss_prefer_blanking,
1247N/A mga_xw.xw_ss_allow_exposures);
1247N/A
1247N/A mga_xw.xw_ss_disabled = False;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_restore_screensaver",
1247N/A "XSetScreenSaver(display, %d, %d, %d, %d)\n",
1247N/A mga_xw.xw_ss_timeout,
1247N/A mga_xw.xw_ss_interval,
1247N/A mga_xw.xw_ss_prefer_blanking,
1247N/A mga_xw.xw_ss_allow_exposures);
1247N/A
1247N/A mga_xw.xw_ss_saved = False;
1247N/A
1247N/A return (1);
1247N/A }
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_disable_dpms(
1247N/A void)
1247N/A{
1247N/A /* Disable the X Display Power Management Signaling. */
1247N/A
1247N/A int status;
1247N/A int dpms_error = 0;
1247N/A int dpms_event = 0;
1247N/A
1247N/A status = DPMSQueryExtension(mga_xw.xw_display,
1247N/A &dpms_event, &dpms_error);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_disable_dpms",
1247N/A "DPMSQueryExtension(display) = %d, %d, %d\n",
1247N/A status,
1247N/A dpms_event,
1247N/A dpms_error);
1247N/A
1247N/A if (status != True)
1247N/A return (-1);
1247N/A
1247N/A mga_xw.xw_dpms_saved = DPMSInfo(mga_xw.xw_display,
1247N/A &mga_xw.xw_dpms_power, &mga_xw.xw_dpms_state);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_disable_dpms",
1247N/A "DPMSInfo(display) = %d, %d, %d\n",
1247N/A mga_xw.xw_dpms_saved,
1247N/A mga_xw.xw_dpms_power,
1247N/A mga_xw.xw_dpms_state);
1247N/A
1247N/A if (mga_xw.xw_dpms_saved != True ||
1247N/A mga_xw.xw_dpms_state != True)
1247N/A return (0);
1247N/A
1247N/A else {
1247N/A mga_xw.xw_dpms_disabled = True;
1247N/A
1247N/A DPMSDisable(mga_xw.xw_display);
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_disable_dpms",
1247N/A "DPMSDisable(display)\n");
1247N/A
1247N/A return (1);
1247N/A }
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_restore_dpms(
1247N/A void)
1247N/A{
1247N/A /* Restore the X Display Power Management Signaling. */
1247N/A
1247N/A if (mga_xw.xw_dpms_saved != True ||
1247N/A mga_xw.xw_dpms_disabled != True) {
1247N/A mga_xw.xw_dpms_disabled = False;
1247N/A mga_xw.xw_dpms_saved = False;
1247N/A return (0);
1247N/A
1247N/A } else {
1247N/A DPMSEnable(mga_xw.xw_display);
1247N/A
1247N/A mga_xw.xw_dpms_disabled = False;
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "mga_restore_dpms",
1247N/A "DPMSEnable(display)\n");
1247N/A
1247N/A mga_xw.xw_dpms_saved = False;
1247N/A
1247N/A return (1);
1247N/A }
1247N/A}
1247N/A
1247N/A
1247N/Aint
1247N/Amga_sleep(
1247N/A unsigned int const seconds)
1247N/A{
1247N/A register int signo;
1247N/A struct sigaction oldhup;
1247N/A struct sigaction oldint;
1247N/A struct sigaction oldalrm;
1247N/A struct sigaction oldterm;
1247N/A struct sigaction newsigact;
1247N/A sigset_t oldprocmask;
1247N/A
1247N/A /*
1247N/A * Allow a SIGHUP, SIGINT, SIGALRM, or SIGTERM to interrupt our
1247N/A * sleep. These signals should already be masked from a
1247N/A * call to mga_block_signals.
1247N/A */
1247N/A
1247N/A /* Save the current signals. */
1247N/A
1247N/A sigaction(SIGHUP, NULL, &oldhup);
1247N/A sigaction(SIGINT, NULL, &oldint);
1247N/A sigaction(SIGALRM, NULL, &oldalrm);
1247N/A sigaction(SIGTERM, NULL, &oldterm);
1247N/A
1247N/A /* Setup up new signal action. */
1247N/A
1247N/A newsigact.sa_handler = mga_signal_routine;
1247N/A sigemptyset(&newsigact.sa_mask);
1247N/A newsigact.sa_flags = 0;
1247N/A
1247N/A signo = sigsetjmp(mga_xw.xw_sigjmpbuf, 1);
1247N/A if (!signo) {
1247N/A /* First time goes here. */
1247N/A
1247N/A /* Set signal routines. */
1247N/A
1247N/A if (oldhup.sa_handler != SIG_IGN)
1247N/A sigaction(SIGHUP, &newsigact, NULL);
1247N/A if (oldint.sa_handler != SIG_IGN)
1247N/A sigaction(SIGINT, &newsigact, NULL);
1247N/A if (oldalrm.sa_handler != SIG_IGN)
1247N/A sigaction(SIGALRM, &newsigact, NULL);
1247N/A if (oldterm.sa_handler != SIG_IGN)
1247N/A sigaction(SIGTERM, &newsigact, NULL);
1247N/A
1247N/A /* Unmask SIGHUP, SIGINT, SIGALRM, SIGTERM. */
1247N/A
1247N/A sigprocmask(SIG_SETMASK, &mga_xw.xw_procmask, &oldprocmask);
1247N/A
1247N/A sleep(seconds);
1247N/A
1247N/A /* Mask SIGHUP, SIGINT, SIGALRM, SIGTERM. */
1247N/A
1247N/A sigprocmask(SIG_SETMASK, &oldprocmask, NULL);
1247N/A
1247N/A /* Restore the signals. */
1247N/A
1247N/A if (oldhup.sa_handler != SIG_IGN)
1247N/A sigaction(SIGHUP, &oldhup, NULL);
1247N/A if (oldint.sa_handler != SIG_IGN)
1247N/A sigaction(SIGINT, &oldint, NULL);
1247N/A if (oldalrm.sa_handler != SIG_IGN)
1247N/A sigaction(SIGALRM, &oldalrm, NULL);
1247N/A if (oldterm.sa_handler != SIG_IGN)
1247N/A sigaction(SIGTERM, &oldterm, NULL);
1247N/A }
1247N/A
1247N/A else {
1247N/A /* We come here from the siglongjmp in mga_signal_routine. */
1247N/A
1247N/A /* Mask SIGHUP, SIGINT, SIGALRM, SIGTERM. */
1247N/A
1247N/A sigprocmask(SIG_SETMASK, &oldprocmask, NULL);
1247N/A
1247N/A /* Restore the signals. */
1247N/A
1247N/A if (oldhup.sa_handler != SIG_IGN)
1247N/A sigaction(SIGHUP, &oldhup, NULL);
1247N/A if (oldint.sa_handler != SIG_IGN)
1247N/A sigaction(SIGINT, &oldint, NULL);
1247N/A if (oldalrm.sa_handler != SIG_IGN)
1247N/A sigaction(SIGALRM, &oldalrm, NULL);
1247N/A if (oldterm.sa_handler != SIG_IGN)
1247N/A sigaction(SIGTERM, &oldterm, NULL);
1247N/A
1247N/A /* Cause us to get the signal, when we unmask the signals. */
1247N/A
1247N/A kill(getpid(), signo);
1247N/A }
1247N/A return (signo);
1247N/A}
1247N/A
1247N/A
1247N/Avoid
1247N/Amga_signal_routine(
1247N/A register int const signo)
1247N/A{
1247N/A siglongjmp(mga_xw.xw_sigjmpbuf, signo);
1247N/A}
1247N/A
1247N/A
1247N/Avoid
1247N/Agraphicstest_finish(
1247N/A register int const flag)
1247N/A{
1247N/A
1247N/A TraceMessage(VTS_DEBUG, "graphicstest_finish",
1247N/A "call graphicstest_finish\n");
1247N/A
1247N/A cleanup_tests(tests_info);
1247N/A
1247N/A exit(0);
1247N/A
1247N/A}