home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / mitsch75.zip / scheme-7_5_17-src.zip / scheme-7.5.17 / src / microcode / os2top.c < prev    next >
C/C++ Source or Header  |  2000-12-05  |  116KB  |  2,524 lines

  1. /* -*-C-*-
  2.  
  3. $Id: os2top.c,v 1.21 2000/12/05 21:23:46 cph Exp $
  4.  
  5. Copyright (c) 1994-2000 Massachusetts Institute of Technology
  6.  
  7. This program is free software; you can redistribute it and/or modify
  8. it under the terms of the GNU General Public License as published by
  9. the Free Software Foundation; either version 2 of the License, or (at
  10. your option) any later version.
  11.  
  12. This program is distributed in the hope that it will be useful, but
  13. WITHOUT ANY WARRANTY; without even the implied warranty of
  14. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  15. General Public License for more details.
  16.  
  17. You should have received a copy of the GNU General Public License
  18. along with this program; if not, write to the Free Software
  19. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20. */
  21.  
  22. #define SCM_OS2TOP_C
  23. #define INCL_WIN
  24.  
  25. #include "scheme.h"
  26. #include "os2.h"
  27. #include "ostop.h"
  28. #include "option.h"
  29.  
  30. #ifndef DISABLE_SOCKET_SUPPORT
  31. #  include <nerrno.h>
  32. #endif
  33.  
  34. extern void execute_reload_cleanups (void);
  35.  
  36. extern void OS2_initialize_channels (void);
  37. extern void OS2_initialize_channel_thread_messages (void);
  38. extern void OS2_initialize_console (void);
  39. extern void OS2_initialize_directory_reader (void);
  40. extern void OS2_initialize_environment (void);
  41. extern void OS2_initialize_exception_handling (void);
  42. extern void OS2_initialize_keyboard_interrupts (void);
  43. extern void OS2_initialize_malloc (void);
  44. extern void OS2_initialize_message_queues (void);
  45. extern void OS2_initialize_pm_thread (void);
  46. extern void OS2_initialize_processes (void);
  47. extern void OS2_initialize_scheme_thread (void);
  48. extern void OS2_initialize_tty (void);
  49. extern void OS2_initialize_window_primitives (void);
  50.  
  51. extern void OS2_check_message_length_initializations (void);
  52. extern void * OS2_malloc_noerror (unsigned int);
  53. extern void * OS2_realloc_noerror (void *, unsigned int);
  54.  
  55. extern void OS2_create_msg_queue (void); /* forward reference */
  56.  
  57. extern const char * OS_Name;
  58. extern const char * OS_Variant;
  59. extern HMTX OS2_create_queue_lock;
  60.  
  61. static const char * OS2_version_string (void);
  62. static void initialize_locks (void);
  63.  
  64. static int initialization_completed = 0;
  65.  
  66. int
  67. OS_under_emacs_p (void)
  68. {
  69.   return (option_emacs_subprocess);
  70. }
  71.  
  72. void
  73. OS2_initialize_early (void)
  74. {
  75.   initialization_completed = 0;
  76.   OS2_initialize_malloc ();
  77.   initialize_locks ();
  78.   OS2_create_msg_queue ();
  79. }
  80.  
  81. void
  82. OS_initialize (void)
  83. {
  84.   (void) DosError (FERR_DISABLEEXCEPTION | FERR_DISABLEHARDERR);
  85.   OS2_initialize_exception_handling ();
  86.   OS2_initialize_message_queues ();
  87.   OS2_initialize_scheme_thread ();
  88.   OS2_initialize_pm_thread ();
  89.   OS2_initialize_channels ();
  90.   OS2_initialize_channel_thread_messages ();
  91.   OS2_initialize_keyboard_interrupts ();
  92.   OS2_initialize_console ();
  93.   OS2_initialize_environment ();
  94.   OS2_initialize_directory_reader ();
  95.   OS2_initialize_tty ();
  96.   OS2_initialize_window_primitives ();
  97.   OS2_initialize_processes ();
  98.   initialization_completed = 1;
  99.   /* This must be after all of the initializations that can set
  100.      message lengths.  */
  101.   OS2_check_message_length_initializations ();
  102.   OS_Name = "OS/2";
  103.   {
  104.     const char * version = (OS2_version_string ());
  105.     OS_Variant = (OS_malloc ((strlen (OS_Name)) + (strlen (version)) + 2));
  106.     sprintf (((char *) OS_Variant), "%s %s", OS_Name, version);
  107.   }
  108. }
  109.  
  110. void
  111. OS_announcement (void)
  112. {
  113. }
  114.  
  115. static const char *
  116. OS2_version_string (void)
  117. {
  118.   ULONG major = (OS2_system_variable (QSV_VERSION_MAJOR));
  119.   ULONG minor = (OS2_system_variable (QSV_VERSION_MINOR));
  120.   char revision = (OS2_system_variable (QSV_VERSION_REVISION));
  121.   static char result [64];
  122.   char sminor [16];
  123.   char srev [2];
  124.   if ((major == 20) && (minor >= 30))
  125.     {
  126.       major = (minor - (minor % 10));
  127.       minor = ((minor % 10) * 10);
  128.     }
  129.   if ((minor < 10) && (minor != 0))
  130.     sprintf (sminor, "0%d", minor);
  131.   else
  132.     sprintf (sminor, "%d",
  133.          (((minor < 100) && ((minor % 10) == 0)) ? (minor / 10) : minor));
  134.   if (revision == '\0')
  135.     sprintf (srev, "");
  136.   else
  137.     sprintf (srev, "%c", revision);
  138.   sprintf (result, "%d.%s%s", (major / 10), sminor, srev);
  139.   return (result);
  140. }
  141.  
  142. #define PAGESIZE 4096
  143. #define PAGE_PERMS (PAG_READ | PAG_WRITE | PAG_EXECUTE)
  144. #define N_STACK_GUARD_PAGES 2
  145.  
  146. #define ROUND_UP_TO_PAGE(size)                        \
  147.   (((((size) + (PAGESIZE - 1)) / PAGESIZE) + N_STACK_GUARD_PAGES + 1)    \
  148.    * PAGESIZE)
  149.  
  150. typedef struct
  151. {
  152.   char * low;
  153.   unsigned int enabled_p : 1;
  154. } guard_page_state_t;
  155.  
  156. static guard_page_state_t guard_page_states [N_STACK_GUARD_PAGES];
  157.  
  158. static void *
  159. commit_heap_helper (void * base, unsigned long size)
  160. {
  161.   /* Complicated arrangement to detect stack overflow with reasonable
  162.      reliability.  We allocate three extra pages past the end of the
  163.      stack; the first two (adjacent to the stack) are committed as
  164.      guard pages so that OS/2 will deliver an exception when we access
  165.      them.  If we overrun the first guard page, the trap handler
  166.      should recognize this and terminate Scheme gracefully, using the
  167.      second guard page as its stack.  The third page, on the other
  168.      side of the guard pages, is uncommitted -- if for some reason we
  169.      overrun the second guard page, this uncommitted page will cause a
  170.      hard fault that will kill Scheme right away.
  171.  
  172.      This is slightly kludgey, because we take advantage of the fact
  173.      that the Scheme stack occupies the low-order addresses in the
  174.      allocated block, and particularly that the stack grows towards
  175.      lower addresses.  Thus we can put the guard pages just below the
  176.      allocated block.  If the memory layout is altered, this will have
  177.      to change.  The reason for this fragile implementation is that it
  178.      requires the least change to the existing memory allocation
  179.      mechanism.  */
  180.   char * p = base;
  181.   /* Skip uncommitted page, then commit rest of memory block.  */
  182.   p += PAGESIZE;
  183.   if ((dos_set_mem (p, (size - PAGESIZE), (PAG_COMMIT | PAG_DEFAULT)))
  184.       != NO_ERROR)
  185.     return (0);
  186.   /* Initialize the stack guard pages and get pointer to first page
  187.      past the guard pages.  */
  188.   {
  189.     guard_page_state_t * scan = guard_page_states;
  190.     guard_page_state_t * end = (scan + N_STACK_GUARD_PAGES);
  191.     while (scan < end)
  192.       {
  193.     (scan -> low) = p;
  194.     (scan -> enabled_p) = 0;
  195.     scan += 1;
  196.     p += PAGESIZE;
  197.       }
  198.     OS2_stack_reset ();
  199.   }
  200.   return (p);
  201. }
  202.  
  203. static void
  204. enable_stack_guard (guard_page_state_t * page, int enable_p)
  205. {
  206.   (void) dos_set_mem ((page -> low),
  207.               PAGESIZE,
  208.               (enable_p ? (PAGE_PERMS | PAG_GUARD) : PAGE_PERMS));
  209.   (page -> enabled_p) = enable_p;
  210. }
  211.  
  212. int
  213. OS2_disable_stack_guard (void * p)
  214. {
  215.   char * cp = p;
  216.   guard_page_state_t * scan = guard_page_states;
  217.   guard_page_state_t * end = (scan + N_STACK_GUARD_PAGES);
  218.   while (1)
  219.     {
  220.       if (scan == end)
  221.     return (0);
  222.       if (((scan -> low) <= cp) && (cp < ((scan -> low) + PAGESIZE)))
  223.     {
  224.       enable_stack_guard (scan, 0);
  225.       return (1);
  226.     }
  227.       scan += 1;
  228.     }
  229. }
  230.  
  231. void
  232. OS2_stack_reset (void)
  233. {
  234.   {
  235.     guard_page_state_t * scan = guard_page_states;
  236.     guard_page_state_t * end = (scan + N_STACK_GUARD_PAGES);
  237.     while (1)
  238.       {
  239.     if (scan == end)
  240.       return;
  241.     if (! (scan -> enabled_p))
  242.       break;
  243.     scan += 1;
  244.       }
  245.   }
  246.   enable_stack_guard ((&guard_page_states[1]), 0);
  247.   {
  248.     SCHEME_OBJECT * p = ((SCHEME_OBJECT *) ((guard_page_states[1]) . low));
  249.     (*p) = (MAKE_POINTER_OBJECT (TC_BROKEN_HEART, p));
  250.   }
  251.   {
  252.     guard_page_state_t * scan = guard_page_states;
  253.     guard_page_state_t * end = (scan + N_STACK_GUARD_PAGES);
  254.     while (scan < end)
  255.       enable_stack_guard ((scan++), 1);
  256.   }
  257. }
  258.  
  259. int
  260. OS2_stack_overflowed_p (void)
  261. {
  262.   SCHEME_OBJECT * p = ((SCHEME_OBJECT *) ((guard_page_states[1]) . low));
  263.   return
  264.     ((! ((guard_page_states[1]) . enabled_p))
  265.      && ((*p) != (MAKE_POINTER_OBJECT (TC_BROKEN_HEART, p))));
  266. }
  267.  
  268. #if 0
  269.  
  270. /* This is an attempt to allocate Scheme's memory as early as
  271.    possible, in order to obtain the lowest possible addresses before
  272.    `malloc' grabs them for some uninteresting purpose.  However, there
  273.    are two reasons not to do this: first, it doesn't seem to gain any
  274.    advantage at present (in OS/2 Warp 3.0 with C Set++/2 2.1), because
  275.    the returned addresses are about the same in both cases.  Second,
  276.    this sometimes causes a fatal error in the debugger, apparently
  277.    because it cares about how much memory the debugged process has
  278.    allocated, even if it's not committed.  */
  279.  
  280. static void * OS2_heap_base;
  281.  
  282. void
  283. OS2_alloc_heap (void)
  284. {
  285.   APIRET rc
  286.     = (dos_alloc_mem ((& OS2_heap_base),
  287.               0x04000000,
  288.               (PAG_EXECUTE | PAG_READ | PAG_WRITE)));
  289.   if (rc != NO_ERROR)
  290.     {
  291.       fprintf (stderr, "Can't allocate heap memory.");
  292.       fflush (stderr);
  293.       exit (EXIT_FAILURE);
  294.     }
  295. }
  296.  
  297. void *
  298. OS2_commit_heap (unsigned long size)
  299. {
  300.   return (commit_heap_helper (OS2_heap_base, (ROUND_UP_TO_PAGE (size))));
  301. }
  302.  
  303. #else
  304.  
  305. void
  306. OS2_alloc_heap (void)
  307. {
  308. }
  309.  
  310. void *
  311. OS2_commit_heap (unsigned long size)
  312. {
  313.   unsigned long actual = (ROUND_UP_TO_PAGE (size));
  314.   void * heap_base;
  315.   APIRET rc
  316.     = (dos_alloc_mem ((& heap_base),
  317.               actual,
  318.               (PAG_EXECUTE | PAG_READ | PAG_WRITE)));
  319.   return ((rc == NO_ERROR) ? (commit_heap_helper (heap_base, actual)) : 0);
  320. }
  321.  
  322. #endif
  323.  
  324. void
  325. OS2_create_msg_queue (void)
  326. {
  327.   /* Create a PM message queue.  This allows us to use message boxes
  328.      to report fatal errors.  */
  329.   HAB hab = (WinInitialize (0));
  330.   HMQ hmq;
  331.   if (hab == NULLHANDLE)
  332.     OS2_logic_error ("Unable to initialize anchor block.");
  333.   hmq = (WinCreateMsgQueue (hab, 0));
  334.   if (hmq == NULLHANDLE)
  335.     OS2_logic_error ("Unable to create PM message queue.");
  336.   /* This tells the system that this message queue should not receive
  337.      WM_QUIT messages.  */
  338.   WinCancelShutdown (hmq, TRUE);
  339. }
  340.  
  341. void
  342. OS2_message_box (const char * title, const char * message, int errorp)
  343. {
  344.   (void) WinMessageBox (HWND_DESKTOP,
  345.             NULLHANDLE,
  346.             ((PSZ) message),
  347.             ((PSZ) title),
  348.             0,
  349.             (MB_OK | (errorp ? MB_ERROR : MB_WARNING)));
  350. }
  351.  
  352. void
  353. OS2_exit_scheme (int value)
  354. {
  355.   if (initialization_completed)
  356.     {
  357. #if 0
  358.       OS2_channel_close_all_noerror ();
  359. #endif
  360.     }
  361.   exit (value);
  362. }
  363.  
  364. void
  365. OS_reset (void)
  366. {
  367.   execute_reload_cleanups ();
  368. }
  369.  
  370. void
  371. OS_quit (int code, int abnormal_p)
  372. {
  373.   outf_flush_console ();
  374.   OS_restore_external_state ();
  375. }
  376.  
  377. void
  378. OS_save_external_state (void)
  379. {
  380. }
  381.  
  382. void
  383. OS_save_internal_state (void)
  384. {
  385. }
  386.  
  387. void
  388. OS_restore_internal_state (void)
  389. {
  390. }
  391.  
  392. void
  393. OS_restore_external_state (void)
  394. {
  395. }
  396.  
  397. void
  398. preserve_signal_mask (void)
  399. {
  400. }
  401.  
  402. void
  403. block_signals (void)
  404. {
  405. }
  406.  
  407. void
  408. unblock_signals (void)
  409. {
  410. }
  411.  
  412. void
  413. OS_restartable_exit (void)
  414. {
  415. }
  416.  
  417. #if defined(__IBMC__) || defined(__WATCOMC__)
  418. void
  419. bcopy (const char * from, char * to, unsigned int n)
  420. {
  421.   FASTCOPY (from, to, n);
  422. }
  423. #endif
  424.  
  425. static HMTX interrupt_registers_lock;
  426.  
  427. static void
  428. initialize_locks (void)
  429. {
  430.   interrupt_registers_lock = (OS2_create_mutex_semaphore (0, 0));
  431.   OS2_create_queue_lock = (OS2_create_mutex_semaphore (0, 0));
  432. }
  433.  
  434. void
  435. OS_grab_interrupt_registers (void)
  436. {
  437.   OS2_request_mutex_semaphore (interrupt_registers_lock);
  438. }
  439.  
  440. void
  441. OS_release_interrupt_registers (void)
  442. {
  443.   OS2_release_mutex_semaphore (interrupt_registers_lock);
  444. }
  445.  
  446. /* Machine-generated procedure, do not edit: */
  447. enum syserr_names
  448. OS_error_code_to_syserr (int code)
  449. {
  450.   switch (code)
  451.     {
  452.     case ERROR_INVALID_FUNCTION:    return (syserr_invalid_function);
  453.     case ERROR_FILE_NOT_FOUND:    return (syserr_file_not_found);
  454.     case ERROR_PATH_NOT_FOUND:    return (syserr_path_not_found);
  455.     case ERROR_TOO_MANY_OPEN_FILES:    return (syserr_too_many_open_files);
  456.     case ERROR_ACCESS_DENIED:    return (syserr_access_denied);
  457.     case ERROR_INVALID_HANDLE:    return (syserr_invalid_handle);
  458.     case ERROR_ARENA_TRASHED:    return (syserr_arena_trashed);
  459.     case ERROR_NOT_ENOUGH_MEMORY:    return (syserr_not_enough_memory);
  460.     case ERROR_INVALID_BLOCK:    return (syserr_invalid_block);
  461.     case ERROR_BAD_ENVIRONMENT:    return (syserr_bad_environment);
  462.     case ERROR_BAD_FORMAT:    return (syserr_bad_format);
  463.     case ERROR_INVALID_ACCESS:    return (syserr_invalid_access);
  464.     case ERROR_INVALID_DATA:    return (syserr_invalid_data);
  465.     case ERROR_INVALID_DRIVE:    return (syserr_invalid_drive);
  466.     case ERROR_CURRENT_DIRECTORY:    return (syserr_current_directory);
  467.     case ERROR_NOT_SAME_DEVICE:    return (syserr_not_same_device);
  468.     case ERROR_NO_MORE_FILES:    return (syserr_no_more_files);
  469.     case ERROR_WRITE_PROTECT:    return (syserr_write_protect);
  470.     case ERROR_BAD_UNIT:    return (syserr_bad_unit);
  471.     case ERROR_NOT_READY:    return (syserr_not_ready);
  472.     case ERROR_BAD_COMMAND:    return (syserr_bad_command);
  473.     case ERROR_CRC:    return (syserr_crc);
  474.     case ERROR_BAD_LENGTH:    return (syserr_bad_length);
  475.     case ERROR_SEEK:    return (syserr_seek);
  476.     case ERROR_NOT_DOS_DISK:    return (syserr_not_dos_disk);
  477.     case ERROR_SECTOR_NOT_FOUND:    return (syserr_sector_not_found);
  478.     case ERROR_OUT_OF_PAPER:    return (syserr_out_of_paper);
  479.     case ERROR_WRITE_FAULT:    return (syserr_write_fault);
  480.     case ERROR_READ_FAULT:    return (syserr_read_fault);
  481.     case ERROR_GEN_FAILURE:    return (syserr_gen_failure);
  482.     case ERROR_SHARING_VIOLATION:    return (syserr_sharing_violation);
  483.     case ERROR_LOCK_VIOLATION:    return (syserr_lock_violation);
  484.     case ERROR_WRONG_DISK:    return (syserr_wrong_disk);
  485.     case ERROR_FCB_UNAVAILABLE:    return (syserr_fcb_unavailable);
  486.     case ERROR_SHARING_BUFFER_EXCEEDED:    return (syserr_sharing_buffer_exceeded);
  487.     case ERROR_CODE_PAGE_MISMATCHED:    return (syserr_code_page_mismatched);
  488.     case ERROR_HANDLE_EOF:    return (syserr_handle_eof);
  489.     case ERROR_HANDLE_DISK_FULL:    return (syserr_handle_disk_full);
  490.     case ERROR_NOT_SUPPORTED:    return (syserr_not_supported);
  491.     case ERROR_REM_NOT_LIST:    return (syserr_rem_not_list);
  492.     case ERROR_DUP_NAME:    return (syserr_dup_name);
  493.     case ERROR_BAD_NETPATH:    return (syserr_bad_netpath);
  494.     case ERROR_NETWORK_BUSY:    return (syserr_network_busy);
  495.     case ERROR_DEV_NOT_EXIST:    return (syserr_dev_not_exist);
  496.     case ERROR_TOO_MANY_CMDS:    return (syserr_too_many_cmds);
  497.     case ERROR_ADAP_HDW_ERR:    return (syserr_adap_hdw_err);
  498.     case ERROR_BAD_NET_RESP:    return (syserr_bad_net_resp);
  499.     case ERROR_UNEXP_NET_ERR:    return (syserr_unexp_net_err);
  500.     case ERROR_BAD_REM_ADAP:    return (syserr_bad_rem_adap);
  501.     case ERROR_PRINTQ_FULL:    return (syserr_printq_full);
  502.     case ERROR_NO_SPOOL_SPACE:    return (syserr_no_spool_space);
  503.     case ERROR_PRINT_CANCELLED:    return (syserr_print_cancelled);
  504.     case ERROR_NETNAME_DELETED:    return (syserr_netname_deleted);
  505.     case ERROR_NETWORK_ACCESS_DENIED:    return (syserr_network_access_denied);
  506.     case ERROR_BAD_DEV_TYPE:    return (syserr_bad_dev_type);
  507.     case ERROR_BAD_NET_NAME:    return (syserr_bad_net_name);
  508.     case ERROR_TOO_MANY_NAMES:    return (syserr_too_many_names);
  509.     case ERROR_TOO_MANY_SESS:    return (syserr_too_many_sess);
  510.     case ERROR_SHARING_PAUSED:    return (syserr_sharing_paused);
  511.     case ERROR_REQ_NOT_ACCEP:    return (syserr_req_not_accep);
  512.     case ERROR_REDIR_PAUSED:    return (syserr_redir_paused);
  513.     case ERROR_SBCS_ATT_WRITE_PROT:    return (syserr_sbcs_att_write_prot);
  514.     case ERROR_SBCS_GENERAL_FAILURE:    return (syserr_sbcs_general_failure);
  515.     case ERROR_XGA_OUT_MEMORY:    return (syserr_xga_out_memory);
  516.     case ERROR_FILE_EXISTS:    return (syserr_file_exists);
  517.     case ERROR_DUP_FCB:    return (syserr_dup_fcb);
  518.     case ERROR_CANNOT_MAKE:    return (syserr_cannot_make);
  519.     case ERROR_FAIL_I24:    return (syserr_fail_i24);
  520.     case ERROR_OUT_OF_STRUCTURES:    return (syserr_out_of_structures);
  521.     case ERROR_ALREADY_ASSIGNED:    return (syserr_already_assigned);
  522.     case ERROR_INVALID_PASSWORD:    return (syserr_invalid_password);
  523.     case ERROR_INVALID_PARAMETER:    return (syserr_invalid_parameter);
  524.     case ERROR_NET_WRITE_FAULT:    return (syserr_net_write_fault);
  525.     case ERROR_NO_PROC_SLOTS:    return (syserr_no_proc_slots);
  526.     case ERROR_NOT_FROZEN:    return (syserr_not_frozen);
  527.     case ERR_TSTOVFL:    return (syserr_tstovfl);
  528.     case ERR_TSTDUP:    return (syserr_tstdup);
  529.     case ERROR_NO_ITEMS:    return (syserr_no_items);
  530.     case ERROR_INTERRUPT:    return (syserr_interrupt);
  531.     case ERROR_DEVICE_IN_USE:    return (syserr_device_in_use);
  532.     case ERROR_TOO_MANY_SEMAPHORES:    return (syserr_too_many_semaphores);
  533.     case ERROR_EXCL_SEM_ALREADY_OWNED:    return (syserr_excl_sem_already_owned);
  534.     case ERROR_SEM_IS_SET:    return (syserr_sem_is_set);
  535.     case ERROR_TOO_MANY_SEM_REQUESTS:    return (syserr_too_many_sem_requests);
  536.     case ERROR_INVALID_AT_INTERRUPT_TIME:    return (syserr_invalid_at_interrupt_time);
  537.     case ERROR_SEM_OWNER_DIED:    return (syserr_sem_owner_died);
  538.     case ERROR_SEM_USER_LIMIT:    return (syserr_sem_user_limit);
  539.     case ERROR_DISK_CHANGE:    return (syserr_disk_change);
  540.     case ERROR_DRIVE_LOCKED:    return (syserr_drive_locked);
  541.     case ERROR_BROKEN_PIPE:    return (syserr_broken_pipe);
  542.     case ERROR_OPEN_FAILED:    return (syserr_open_failed);
  543.     case ERROR_BUFFER_OVERFLOW:    return (syserr_buffer_overflow);
  544.     case ERROR_DISK_FULL:    return (syserr_disk_full);
  545.     case ERROR_NO_MORE_SEARCH_HANDLES:    return (syserr_no_more_search_handles);
  546.     case ERROR_INVALID_TARGET_HANDLE:    return (syserr_invalid_target_handle);
  547.     case ERROR_PROTECTION_VIOLATION:    return (syserr_protection_violation);
  548.     case ERROR_VIOKBD_REQUEST:    return (syserr_viokbd_request);
  549.     case ERROR_INVALID_CATEGORY:    return (syserr_invalid_category);
  550.     case ERROR_INVALID_VERIFY_SWITCH:    return (syserr_invalid_verify_switch);
  551.     case ERROR_BAD_DRIVER_LEVEL:    return (syserr_bad_driver_level);
  552.     case ERROR_CALL_NOT_IMPLEMENTED:    return (syserr_call_not_implemented);
  553.     case ERROR_SEM_TIMEOUT:    return (syserr_sem_timeout);
  554.     case ERROR_INSUFFICIENT_BUFFER:    return (syserr_insufficient_buffer);
  555.     case ERROR_INVALID_NAME:    return (syserr_invalid_name);
  556.     case ERROR_INVALID_LEVEL:    return (syserr_invalid_level);
  557.     case ERROR_NO_VOLUME_LABEL:    return (syserr_no_volume_label);
  558.     case ERROR_MOD_NOT_FOUND:    return (syserr_mod_not_found);
  559.     case ERROR_PROC_NOT_FOUND:    return (syserr_proc_not_found);
  560.     case ERROR_WAIT_NO_CHILDREN:    return (syserr_wait_no_children);
  561.     case ERROR_CHILD_NOT_COMPLETE:    return (syserr_child_not_complete);
  562.     case ERROR_DIRECT_ACCESS_HANDLE:    return (syserr_direct_access_handle);
  563.     case ERROR_NEGATIVE_SEEK:    return (syserr_negative_seek);
  564.     case ERROR_SEEK_ON_DEVICE:    return (syserr_seek_on_device);
  565.     case ERROR_IS_JOIN_TARGET:    return (syserr_is_join_target);
  566.     case ERROR_IS_JOINED:    return (syserr_is_joined);
  567.     case ERROR_IS_SUBSTED:    return (syserr_is_substed);
  568.     case ERROR_NOT_JOINED:    return (syserr_not_joined);
  569.     case ERROR_NOT_SUBSTED:    return (syserr_not_substed);
  570.     case ERROR_JOIN_TO_JOIN:    return (syserr_join_to_join);
  571.     case ERROR_SUBST_TO_SUBST:    return (syserr_subst_to_subst);
  572.     case ERROR_JOIN_TO_SUBST:    return (syserr_join_to_subst);
  573.     case ERROR_SUBST_TO_JOIN:    return (syserr_subst_to_join);
  574.     case ERROR_BUSY_DRIVE:    return (syserr_busy_drive);
  575.     case ERROR_SAME_DRIVE:    return (syserr_same_drive);
  576.     case ERROR_DIR_NOT_ROOT:    return (syserr_dir_not_root);
  577.     case ERROR_DIR_NOT_EMPTY:    return (syserr_dir_not_empty);
  578.     case ERROR_IS_SUBST_PATH:    return (syserr_is_subst_path);
  579.     case ERROR_IS_JOIN_PATH:    return (syserr_is_join_path);
  580.     case ERROR_PATH_BUSY:    return (syserr_path_busy);
  581.     case ERROR_IS_SUBST_TARGET:    return (syserr_is_subst_target);
  582.     case ERROR_SYSTEM_TRACE:    return (syserr_system_trace);
  583.     case ERROR_INVALID_EVENT_COUNT:    return (syserr_invalid_event_count);
  584.     case ERROR_TOO_MANY_MUXWAITERS:    return (syserr_too_many_muxwaiters);
  585.     case ERROR_INVALID_LIST_FORMAT:    return (syserr_invalid_list_format);
  586.     case ERROR_LABEL_TOO_LONG:    return (syserr_label_too_long);
  587.     case ERROR_TOO_MANY_TCBS:    return (syserr_too_many_tcbs);
  588.     case ERROR_SIGNAL_REFUSED:    return (syserr_signal_refused);
  589.     case ERROR_DISCARDED:    return (syserr_discarded);
  590.     case ERROR_NOT_LOCKED:    return (syserr_not_locked);
  591.     case ERROR_BAD_THREADID_ADDR:    return (syserr_bad_threadid_addr);
  592.     case ERROR_BAD_ARGUMENTS:    return (syserr_bad_arguments);
  593.     case ERROR_BAD_PATHNAME:    return (syserr_bad_pathname);
  594.     case ERROR_SIGNAL_PENDING:    return (syserr_signal_pending);
  595.     case ERROR_UNCERTAIN_MEDIA:    return (syserr_uncertain_media);
  596.     case ERROR_MAX_THRDS_REACHED:    return (syserr_max_thrds_reached);
  597.     case ERROR_MONITORS_NOT_SUPPORTED:    return (syserr_monitors_not_supported);
  598.     case ERROR_UNC_DRIVER_NOT_INSTALLED:    return (syserr_unc_driver_not_installed);
  599.     case ERROR_LOCK_FAILED:    return (syserr_lock_failed);
  600.     case ERROR_SWAPIO_FAILED:    return (syserr_swapio_failed);
  601.     case ERROR_SWAPIN_FAILED:    return (syserr_swapin_failed);
  602.     case ERROR_BUSY:    return (syserr_busy);
  603.     case ERROR_CANCEL_VIOLATION:    return (syserr_cancel_violation);
  604.     case ERROR_ATOMIC_LOCK_NOT_SUPPORTED:    return (syserr_atomic_lock_not_supported);
  605.     case ERROR_READ_LOCKS_NOT_SUPPORTED:    return (syserr_read_locks_not_supported);
  606.     case ERROR_INVALID_SEGMENT_NUMBER:    return (syserr_invalid_segment_number);
  607.     case ERROR_INVALID_CALLGATE:    return (syserr_invalid_callgate);
  608.     case ERROR_INVALID_ORDINAL:    return (syserr_invalid_ordinal);
  609.     case ERROR_ALREADY_EXISTS:    return (syserr_already_exists);
  610.     case ERROR_NO_CHILD_PROCESS:    return (syserr_no_child_process);
  611.     case ERROR_CHILD_ALIVE_NOWAIT:    return (syserr_child_alive_nowait);
  612.     case ERROR_INVALID_FLAG_NUMBER:    return (syserr_invalid_flag_number);
  613.     case ERROR_SEM_NOT_FOUND:    return (syserr_sem_not_found);
  614.     case ERROR_INVALID_STARTING_CODESEG:    return (syserr_invalid_starting_codeseg);
  615.     case ERROR_INVALID_STACKSEG:    return (syserr_invalid_stackseg);
  616.     case ERROR_INVALID_MODULETYPE:    return (syserr_invalid_moduletype);
  617.     case ERROR_INVALID_EXE_SIGNATURE:    return (syserr_invalid_exe_signature);
  618.     case ERROR_EXE_MARKED_INVALID:    return (syserr_exe_marked_invalid);
  619.     case ERROR_BAD_EXE_FORMAT:    return (syserr_bad_exe_format);
  620. #ifdef ERROR_ITERATED_DATA_EXCEEDS_64k
  621.     case ERROR_ITERATED_DATA_EXCEEDS_64k:    return (syserr_iterated_data_exceeds_64k);
  622. #endif
  623.     case ERROR_INVALID_MINALLOCSIZE:    return (syserr_invalid_minallocsize);
  624.     case ERROR_DYNLINK_FROM_INVALID_RING:    return (syserr_dynlink_from_invalid_ring);
  625.     case ERROR_IOPL_NOT_ENABLED:    return (syserr_iopl_not_enabled);
  626.     case ERROR_INVALID_SEGDPL:    return (syserr_invalid_segdpl);
  627. #ifdef ERROR_AUTODATASEG_EXCEEDS_64k
  628.     case ERROR_AUTODATASEG_EXCEEDS_64k:    return (syserr_autodataseg_exceeds_64k);
  629. #endif
  630.     case ERROR_RING2SEG_MUST_BE_MOVABLE:    return (syserr_ring2seg_must_be_movable);
  631. #ifdef ERROR_RELOC_CHAIN_XEEDS_SEGLIM
  632.     case ERROR_RELOC_CHAIN_XEEDS_SEGLIM:    return (syserr_reloc_chain_xeeds_seglim);
  633. #endif
  634.     case ERROR_INFLOOP_IN_RELOC_CHAIN:    return (syserr_infloop_in_reloc_chain);
  635.     case ERROR_ENVVAR_NOT_FOUND:    return (syserr_envvar_not_found);
  636.     case ERROR_NOT_CURRENT_CTRY:    return (syserr_not_current_ctry);
  637.     case ERROR_NO_SIGNAL_SENT:    return (syserr_no_signal_sent);
  638.     case ERROR_FILENAME_EXCED_RANGE:    return (syserr_filename_exced_range);
  639.     case ERROR_RING2_STACK_IN_USE:    return (syserr_ring2_stack_in_use);
  640.     case ERROR_META_EXPANSION_TOO_LONG:    return (syserr_meta_expansion_too_long);
  641.     case ERROR_INVALID_SIGNAL_NUMBER:    return (syserr_invalid_signal_number);
  642.     case ERROR_THREAD_1_INACTIVE:    return (syserr_thread_1_inactive);
  643.     case ERROR_INFO_NOT_AVAIL:    return (syserr_info_not_avail);
  644.     case ERROR_LOCKED:    return (syserr_locked);
  645.     case ERROR_BAD_DYNALINK:    return (syserr_bad_dynalink);
  646.     case ERROR_TOO_MANY_MODULES:    return (syserr_too_many_modules);
  647.     case ERROR_NESTING_NOT_ALLOWED:    return (syserr_nesting_not_allowed);
  648.     case ERROR_CANNOT_SHRINK:    return (syserr_cannot_shrink);
  649.     case ERROR_ZOMBIE_PROCESS:    return (syserr_zombie_process);
  650.     case ERROR_STACK_IN_HIGH_MEMORY:    return (syserr_stack_in_high_memory);
  651.     case ERROR_INVALID_EXITROUTINE_RING:    return (syserr_invalid_exitroutine_ring);
  652.     case ERROR_GETBUF_FAILED:    return (syserr_getbuf_failed);
  653.     case ERROR_FLUSHBUF_FAILED:    return (syserr_flushbuf_failed);
  654.     case ERROR_TRANSFER_TOO_LONG:    return (syserr_transfer_too_long);
  655.     case ERROR_FORCENOSWAP_FAILED:    return (syserr_forcenoswap_failed);
  656.     case ERROR_SMG_NO_TARGET_WINDOW:    return (syserr_smg_no_target_window);
  657.     case ERROR_NO_CHILDREN:    return (syserr_no_children);
  658.     case ERROR_INVALID_SCREEN_GROUP:    return (syserr_invalid_screen_group);
  659.     case ERROR_BAD_PIPE:    return (syserr_bad_pipe);
  660.     case ERROR_PIPE_BUSY:    return (syserr_pipe_busy);
  661.     case ERROR_NO_DATA:    return (syserr_no_data);
  662.     case ERROR_PIPE_NOT_CONNECTED:    return (syserr_pipe_not_connected);
  663.     case ERROR_MORE_DATA:    return (syserr_more_data);
  664.     case ERROR_VC_DISCONNECTED:    return (syserr_vc_disconnected);
  665.     case ERROR_CIRCULARITY_REQUESTED:    return (syserr_circularity_requested);
  666.     case ERROR_DIRECTORY_IN_CDS:    return (syserr_directory_in_cds);
  667.     case ERROR_INVALID_FSD_NAME:    return (syserr_invalid_fsd_name);
  668.     case ERROR_INVALID_PATH:    return (syserr_invalid_path);
  669.     case ERROR_INVALID_EA_NAME:    return (syserr_invalid_ea_name);
  670.     case ERROR_EA_LIST_INCONSISTENT:    return (syserr_ea_list_inconsistent);
  671.     case ERROR_EA_LIST_TOO_LONG:    return (syserr_ea_list_too_long);
  672.     case ERROR_NO_META_MATCH:    return (syserr_no_meta_match);
  673.     case ERROR_FINDNOTIFY_TIMEOUT:    return (syserr_findnotify_timeout);
  674.     case ERROR_NO_MORE_ITEMS:    return (syserr_no_more_items);
  675.     case ERROR_SEARCH_STRUC_REUSED:    return (syserr_search_struc_reused);
  676.     case ERROR_CHAR_NOT_FOUND:    return (syserr_char_not_found);
  677.     case ERROR_TOO_MUCH_STACK:    return (syserr_too_much_stack);
  678.     case ERROR_INVALID_ATTR:    return (syserr_invalid_attr);
  679.     case ERROR_INVALID_STARTING_RING:    return (syserr_invalid_starting_ring);
  680.     case ERROR_INVALID_DLL_INIT_RING:    return (syserr_invalid_dll_init_ring);
  681.     case ERROR_CANNOT_COPY:    return (syserr_cannot_copy);
  682.     case ERROR_DIRECTORY:    return (syserr_directory);
  683.     case ERROR_OPLOCKED_FILE:    return (syserr_oplocked_file);
  684.     case ERROR_OPLOCK_THREAD_EXISTS:    return (syserr_oplock_thread_exists);
  685.     case ERROR_VOLUME_CHANGED:    return (syserr_volume_changed);
  686.     case ERROR_FINDNOTIFY_HANDLE_IN_USE:    return (syserr_findnotify_handle_in_use);
  687.     case ERROR_FINDNOTIFY_HANDLE_CLOSED:    return (syserr_findnotify_handle_closed);
  688.     case ERROR_NOTIFY_OBJECT_REMOVED:    return (syserr_notify_object_removed);
  689.     case ERROR_ALREADY_SHUTDOWN:    return (syserr_already_shutdown);
  690.     case ERROR_EAS_DIDNT_FIT:    return (syserr_eas_didnt_fit);
  691.     case ERROR_EA_FILE_CORRUPT:    return (syserr_ea_file_corrupt);
  692.     case ERROR_EA_TABLE_FULL:    return (syserr_ea_table_full);
  693.     case ERROR_INVALID_EA_HANDLE:    return (syserr_invalid_ea_handle);
  694.     case ERROR_NO_CLUSTER:    return (syserr_no_cluster);
  695.     case ERROR_CREATE_EA_FILE:    return (syserr_create_ea_file);
  696.     case ERROR_CANNOT_OPEN_EA_FILE:    return (syserr_cannot_open_ea_file);
  697.     case ERROR_EAS_NOT_SUPPORTED:    return (syserr_eas_not_supported);
  698.     case ERROR_NEED_EAS_FOUND:    return (syserr_need_eas_found);
  699.     case ERROR_DUPLICATE_HANDLE:    return (syserr_duplicate_handle);
  700.     case ERROR_DUPLICATE_NAME:    return (syserr_duplicate_name);
  701.     case ERROR_EMPTY_MUXWAIT:    return (syserr_empty_muxwait);
  702.     case ERROR_MUTEX_OWNED:    return (syserr_mutex_owned);
  703.     case ERROR_NOT_OWNER:    return (syserr_not_owner);
  704.     case ERROR_PARAM_TOO_SMALL:    return (syserr_param_too_small);
  705.     case ERROR_TOO_MANY_HANDLES:    return (syserr_too_many_handles);
  706.     case ERROR_TOO_MANY_OPENS:    return (syserr_too_many_opens);
  707.     case ERROR_WRONG_TYPE:    return (syserr_wrong_type);
  708.     case ERROR_UNUSED_CODE:    return (syserr_unused_code);
  709.     case ERROR_THREAD_NOT_TERMINATED:    return (syserr_thread_not_terminated);
  710.     case ERROR_INIT_ROUTINE_FAILED:    return (syserr_init_routine_failed);
  711.     case ERROR_MODULE_IN_USE:    return (syserr_module_in_use);
  712.     case ERROR_NOT_ENOUGH_WATCHPOINTS:    return (syserr_not_enough_watchpoints);
  713.     case ERROR_TOO_MANY_POSTS:    return (syserr_too_many_posts);
  714.     case ERROR_ALREADY_POSTED:    return (syserr_already_posted);
  715.     case ERROR_ALREADY_RESET:    return (syserr_already_reset);
  716.     case ERROR_SEM_BUSY:    return (syserr_sem_busy);
  717.     case ERROR_INVALID_PROCID:    return (syserr_invalid_procid);
  718.     case ERROR_INVALID_PDELTA:    return (syserr_invalid_pdelta);
  719.     case ERROR_NOT_DESCENDANT:    return (syserr_not_descendant);
  720.     case ERROR_NOT_SESSION_MANAGER:    return (syserr_not_session_manager);
  721.     case ERROR_INVALID_PCLASS:    return (syserr_invalid_pclass);
  722.     case ERROR_INVALID_SCOPE:    return (syserr_invalid_scope);
  723.     case ERROR_INVALID_THREADID:    return (syserr_invalid_threadid);
  724.     case ERROR_DOSSUB_SHRINK:    return (syserr_dossub_shrink);
  725.     case ERROR_DOSSUB_NOMEM:    return (syserr_dossub_nomem);
  726.     case ERROR_DOSSUB_OVERLAP:    return (syserr_dossub_overlap);
  727.     case ERROR_DOSSUB_BADSIZE:    return (syserr_dossub_badsize);
  728.     case ERROR_DOSSUB_BADFLAG:    return (syserr_dossub_badflag);
  729.     case ERROR_DOSSUB_BADSELECTOR:    return (syserr_dossub_badselector);
  730.     case ERROR_MR_MSG_TOO_LONG:    return (syserr_mr_msg_too_long);
  731.     case ERROR_MR_MID_NOT_FOUND:    return (syserr_mr_mid_not_found);
  732.     case ERROR_MR_UN_ACC_MSGF:    return (syserr_mr_un_acc_msgf);
  733.     case ERROR_MR_INV_MSGF_FORMAT:    return (syserr_mr_inv_msgf_format);
  734.     case ERROR_MR_INV_IVCOUNT:    return (syserr_mr_inv_ivcount);
  735.     case ERROR_MR_UN_PERFORM:    return (syserr_mr_un_perform);
  736.     case ERROR_TS_WAKEUP:    return (syserr_ts_wakeup);
  737.     case ERROR_TS_SEMHANDLE:    return (syserr_ts_semhandle);
  738.     case ERROR_TS_NOTIMER:    return (syserr_ts_notimer);
  739.     case ERROR_TS_HANDLE:    return (syserr_ts_handle);
  740.     case ERROR_TS_DATETIME:    return (syserr_ts_datetime);
  741.     case ERROR_SYS_INTERNAL:    return (syserr_sys_internal);
  742.     case ERROR_QUE_CURRENT_NAME:    return (syserr_que_current_name);
  743.     case ERROR_QUE_PROC_NOT_OWNED:    return (syserr_que_proc_not_owned);
  744.     case ERROR_QUE_PROC_OWNED:    return (syserr_que_proc_owned);
  745.     case ERROR_QUE_DUPLICATE:    return (syserr_que_duplicate);
  746.     case ERROR_QUE_ELEMENT_NOT_EXIST:    return (syserr_que_element_not_exist);
  747.     case ERROR_QUE_NO_MEMORY:    return (syserr_que_no_memory);
  748.     case ERROR_QUE_INVALID_NAME:    return (syserr_que_invalid_name);
  749.     case ERROR_QUE_INVALID_PRIORITY:    return (syserr_que_invalid_priority);
  750.     case ERROR_QUE_INVALID_HANDLE:    return (syserr_que_invalid_handle);
  751.     case ERROR_QUE_LINK_NOT_FOUND:    return (syserr_que_link_not_found);
  752.     case ERROR_QUE_MEMORY_ERROR:    return (syserr_que_memory_error);
  753.     case ERROR_QUE_PREV_AT_END:    return (syserr_que_prev_at_end);
  754.     case ERROR_QUE_PROC_NO_ACCESS:    return (syserr_que_proc_no_access);
  755.     case ERROR_QUE_EMPTY:    return (syserr_que_empty);
  756.     case ERROR_QUE_NAME_NOT_EXIST:    return (syserr_que_name_not_exist);
  757.     case ERROR_QUE_NOT_INITIALIZED:    return (syserr_que_not_initialized);
  758.     case ERROR_QUE_UNABLE_TO_ACCESS:    return (syserr_que_unable_to_access);
  759.     case ERROR_QUE_UNABLE_TO_ADD:    return (syserr_que_unable_to_add);
  760.     case ERROR_QUE_UNABLE_TO_INIT:    return (syserr_que_unable_to_init);
  761.     case ERROR_VIO_INVALID_MASK:    return (syserr_vio_invalid_mask);
  762.     case ERROR_VIO_PTR:    return (syserr_vio_ptr);
  763.     case ERROR_VIO_APTR:    return (syserr_vio_aptr);
  764.     case ERROR_VIO_RPTR:    return (syserr_vio_rptr);
  765.     case ERROR_VIO_CPTR:    return (syserr_vio_cptr);
  766.     case ERROR_VIO_LPTR:    return (syserr_vio_lptr);
  767.     case ERROR_VIO_MODE:    return (syserr_vio_mode);
  768.     case ERROR_VIO_WIDTH:    return (syserr_vio_width);
  769.     case ERROR_VIO_ATTR:    return (syserr_vio_attr);
  770.     case ERROR_VIO_ROW:    return (syserr_vio_row);
  771.     case ERROR_VIO_COL:    return (syserr_vio_col);
  772.     case ERROR_VIO_TOPROW:    return (syserr_vio_toprow);
  773.     case ERROR_VIO_BOTROW:    return (syserr_vio_botrow);
  774.     case ERROR_VIO_RIGHTCOL:    return (syserr_vio_rightcol);
  775.     case ERROR_VIO_LEFTCOL:    return (syserr_vio_leftcol);
  776.     case ERROR_SCS_CALL:    return (syserr_scs_call);
  777.     case ERROR_SCS_VALUE:    return (syserr_scs_value);
  778.     case ERROR_VIO_WAIT_FLAG:    return (syserr_vio_wait_flag);
  779.     case ERROR_VIO_UNLOCK:    return (syserr_vio_unlock);
  780.     case ERROR_SGS_NOT_SESSION_MGR:    return (syserr_sgs_not_session_mgr);
  781.     case ERROR_SMG_INVALID_SESSION_ID:    return (syserr_smg_invalid_session_id);
  782.     case ERROR_SMG_NO_SESSIONS:    return (syserr_smg_no_sessions);
  783.     case ERROR_SMG_SESSION_NOT_FOUND:    return (syserr_smg_session_not_found);
  784.     case ERROR_SMG_SET_TITLE:    return (syserr_smg_set_title);
  785.     case ERROR_KBD_PARAMETER:    return (syserr_kbd_parameter);
  786.     case ERROR_KBD_NO_DEVICE:    return (syserr_kbd_no_device);
  787.     case ERROR_KBD_INVALID_IOWAIT:    return (syserr_kbd_invalid_iowait);
  788.     case ERROR_KBD_INVALID_LENGTH:    return (syserr_kbd_invalid_length);
  789.     case ERROR_KBD_INVALID_ECHO_MASK:    return (syserr_kbd_invalid_echo_mask);
  790.     case ERROR_KBD_INVALID_INPUT_MASK:    return (syserr_kbd_invalid_input_mask);
  791.     case ERROR_MON_INVALID_PARMS:    return (syserr_mon_invalid_parms);
  792.     case ERROR_MON_INVALID_DEVNAME:    return (syserr_mon_invalid_devname);
  793.     case ERROR_MON_INVALID_HANDLE:    return (syserr_mon_invalid_handle);
  794.     case ERROR_MON_BUFFER_TOO_SMALL:    return (syserr_mon_buffer_too_small);
  795.     case ERROR_MON_BUFFER_EMPTY:    return (syserr_mon_buffer_empty);
  796.     case ERROR_MON_DATA_TOO_LARGE:    return (syserr_mon_data_too_large);
  797.     case ERROR_MOUSE_NO_DEVICE:    return (syserr_mouse_no_device);
  798.     case ERROR_MOUSE_INV_HANDLE:    return (syserr_mouse_inv_handle);
  799.     case ERROR_MOUSE_INV_PARMS:    return (syserr_mouse_inv_parms);
  800.     case ERROR_MOUSE_CANT_RESET:    return (syserr_mouse_cant_reset);
  801.     case ERROR_MOUSE_DISPLAY_PARMS:    return (syserr_mouse_display_parms);
  802.     case ERROR_MOUSE_INV_MODULE:    return (syserr_mouse_inv_module);
  803.     case ERROR_MOUSE_INV_ENTRY_PT:    return (syserr_mouse_inv_entry_pt);
  804.     case ERROR_MOUSE_INV_MASK:    return (syserr_mouse_inv_mask);
  805.     case NO_ERROR_MOUSE_NO_DATA:    return (syserr_mouse_no_data);
  806.     case NO_ERROR_MOUSE_PTR_DRAWN:    return (syserr_mouse_ptr_drawn);
  807.     case ERROR_INVALID_FREQUENCY:    return (syserr_invalid_frequency);
  808.     case ERROR_NLS_NO_COUNTRY_FILE:    return (syserr_nls_no_country_file);
  809.     case ERROR_NLS_OPEN_FAILED:    return (syserr_nls_open_failed);
  810. #ifdef ERROR_NO_COUNTRY_OR_CODEPAGE
  811.     case ERROR_NO_COUNTRY_OR_CODEPAGE:    return (syserr_no_country_or_codepage);
  812. #endif
  813.     case ERROR_NLS_TABLE_TRUNCATED:    return (syserr_nls_table_truncated);
  814.     case ERROR_NLS_BAD_TYPE:    return (syserr_nls_bad_type);
  815.     case ERROR_NLS_TYPE_NOT_FOUND:    return (syserr_nls_type_not_found);
  816.     case ERROR_VIO_SMG_ONLY:    return (syserr_vio_smg_only);
  817.     case ERROR_VIO_INVALID_ASCIIZ:    return (syserr_vio_invalid_asciiz);
  818.     case ERROR_VIO_DEREGISTER:    return (syserr_vio_deregister);
  819.     case ERROR_VIO_NO_POPUP:    return (syserr_vio_no_popup);
  820.     case ERROR_VIO_EXISTING_POPUP:    return (syserr_vio_existing_popup);
  821.     case ERROR_KBD_SMG_ONLY:    return (syserr_kbd_smg_only);
  822.     case ERROR_KBD_INVALID_ASCIIZ:    return (syserr_kbd_invalid_asciiz);
  823.     case ERROR_KBD_INVALID_MASK:    return (syserr_kbd_invalid_mask);
  824.     case ERROR_KBD_REGISTER:    return (syserr_kbd_register);
  825.     case ERROR_KBD_DEREGISTER:    return (syserr_kbd_deregister);
  826.     case ERROR_MOUSE_SMG_ONLY:    return (syserr_mouse_smg_only);
  827.     case ERROR_MOUSE_INVALID_ASCIIZ:    return (syserr_mouse_invalid_asciiz);
  828.     case ERROR_MOUSE_INVALID_MASK:    return (syserr_mouse_invalid_mask);
  829.     case ERROR_MOUSE_REGISTER:    return (syserr_mouse_register);
  830.     case ERROR_MOUSE_DEREGISTER:    return (syserr_mouse_deregister);
  831.     case ERROR_SMG_BAD_ACTION:    return (syserr_smg_bad_action);
  832.     case ERROR_SMG_INVALID_CALL:    return (syserr_smg_invalid_call);
  833.     case ERROR_SCS_SG_NOTFOUND:    return (syserr_scs_sg_notfound);
  834.     case ERROR_SCS_NOT_SHELL:    return (syserr_scs_not_shell);
  835.     case ERROR_VIO_INVALID_PARMS:    return (syserr_vio_invalid_parms);
  836.     case ERROR_VIO_FUNCTION_OWNED:    return (syserr_vio_function_owned);
  837.     case ERROR_VIO_RETURN:    return (syserr_vio_return);
  838.     case ERROR_SCS_INVALID_FUNCTION:    return (syserr_scs_invalid_function);
  839.     case ERROR_SCS_NOT_SESSION_MGR:    return (syserr_scs_not_session_mgr);
  840.     case ERROR_VIO_REGISTER:    return (syserr_vio_register);
  841.     case ERROR_VIO_NO_MODE_THREAD:    return (syserr_vio_no_mode_thread);
  842.     case ERROR_VIO_NO_SAVE_RESTORE_THD:    return (syserr_vio_no_save_restore_thd);
  843.     case ERROR_VIO_IN_BG:    return (syserr_vio_in_bg);
  844.     case ERROR_VIO_ILLEGAL_DURING_POPUP:    return (syserr_vio_illegal_during_popup);
  845.     case ERROR_SMG_NOT_BASESHELL:    return (syserr_smg_not_baseshell);
  846.     case ERROR_SMG_BAD_STATUSREQ:    return (syserr_smg_bad_statusreq);
  847.     case ERROR_QUE_INVALID_WAIT:    return (syserr_que_invalid_wait);
  848.     case ERROR_VIO_LOCK:    return (syserr_vio_lock);
  849.     case ERROR_MOUSE_INVALID_IOWAIT:    return (syserr_mouse_invalid_iowait);
  850.     case ERROR_VIO_INVALID_HANDLE:    return (syserr_vio_invalid_handle);
  851.     case ERROR_VIO_ILLEGAL_DURING_LOCK:    return (syserr_vio_illegal_during_lock);
  852.     case ERROR_VIO_INVALID_LENGTH:    return (syserr_vio_invalid_length);
  853.     case ERROR_KBD_INVALID_HANDLE:    return (syserr_kbd_invalid_handle);
  854.     case ERROR_KBD_NO_MORE_HANDLE:    return (syserr_kbd_no_more_handle);
  855.     case ERROR_KBD_CANNOT_CREATE_KCB:    return (syserr_kbd_cannot_create_kcb);
  856.     case ERROR_KBD_CODEPAGE_LOAD_INCOMPL:    return (syserr_kbd_codepage_load_incompl);
  857.     case ERROR_KBD_INVALID_CODEPAGE_ID:    return (syserr_kbd_invalid_codepage_id);
  858.     case ERROR_KBD_NO_CODEPAGE_SUPPORT:    return (syserr_kbd_no_codepage_support);
  859.     case ERROR_KBD_FOCUS_REQUIRED:    return (syserr_kbd_focus_required);
  860.     case ERROR_KBD_FOCUS_ALREADY_ACTIVE:    return (syserr_kbd_focus_already_active);
  861.     case ERROR_KBD_KEYBOARD_BUSY:    return (syserr_kbd_keyboard_busy);
  862.     case ERROR_KBD_INVALID_CODEPAGE:    return (syserr_kbd_invalid_codepage);
  863.     case ERROR_KBD_UNABLE_TO_FOCUS:    return (syserr_kbd_unable_to_focus);
  864.     case ERROR_SMG_SESSION_NON_SELECT:    return (syserr_smg_session_non_select);
  865.     case ERROR_SMG_SESSION_NOT_FOREGRND:    return (syserr_smg_session_not_foregrnd);
  866.     case ERROR_SMG_SESSION_NOT_PARENT:    return (syserr_smg_session_not_parent);
  867.     case ERROR_SMG_INVALID_START_MODE:    return (syserr_smg_invalid_start_mode);
  868.     case ERROR_SMG_INVALID_RELATED_OPT:    return (syserr_smg_invalid_related_opt);
  869.     case ERROR_SMG_INVALID_BOND_OPTION:    return (syserr_smg_invalid_bond_option);
  870.     case ERROR_SMG_INVALID_SELECT_OPT:    return (syserr_smg_invalid_select_opt);
  871.     case ERROR_SMG_START_IN_BACKGROUND:    return (syserr_smg_start_in_background);
  872.     case ERROR_SMG_INVALID_STOP_OPTION:    return (syserr_smg_invalid_stop_option);
  873.     case ERROR_SMG_BAD_RESERVE:    return (syserr_smg_bad_reserve);
  874.     case ERROR_SMG_PROCESS_NOT_PARENT:    return (syserr_smg_process_not_parent);
  875.     case ERROR_SMG_INVALID_DATA_LENGTH:    return (syserr_smg_invalid_data_length);
  876.     case ERROR_SMG_NOT_BOUND:    return (syserr_smg_not_bound);
  877.     case ERROR_SMG_RETRY_SUB_ALLOC:    return (syserr_smg_retry_sub_alloc);
  878.     case ERROR_KBD_DETACHED:    return (syserr_kbd_detached);
  879.     case ERROR_VIO_DETACHED:    return (syserr_vio_detached);
  880.     case ERROR_MOU_DETACHED:    return (syserr_mou_detached);
  881.     case ERROR_VIO_FONT:    return (syserr_vio_font);
  882.     case ERROR_VIO_USER_FONT:    return (syserr_vio_user_font);
  883.     case ERROR_VIO_BAD_CP:    return (syserr_vio_bad_cp);
  884.     case ERROR_VIO_NO_CP:    return (syserr_vio_no_cp);
  885.     case ERROR_VIO_NA_CP:    return (syserr_vio_na_cp);
  886.     case ERROR_INVALID_CODE_PAGE:    return (syserr_invalid_code_page);
  887.     case ERROR_CPLIST_TOO_SMALL:    return (syserr_cplist_too_small);
  888.     case ERROR_CP_NOT_MOVED:    return (syserr_cp_not_moved);
  889.     case ERROR_MODE_SWITCH_INIT:    return (syserr_mode_switch_init);
  890.     case ERROR_CODE_PAGE_NOT_FOUND:    return (syserr_code_page_not_found);
  891.     case ERROR_UNEXPECTED_SLOT_RETURNED:    return (syserr_unexpected_slot_returned);
  892.     case ERROR_SMG_INVALID_TRACE_OPTION:    return (syserr_smg_invalid_trace_option);
  893.     case ERROR_VIO_INTERNAL_RESOURCE:    return (syserr_vio_internal_resource);
  894.     case ERROR_VIO_SHELL_INIT:    return (syserr_vio_shell_init);
  895.     case ERROR_SMG_NO_HARD_ERRORS:    return (syserr_smg_no_hard_errors);
  896.     case ERROR_CP_SWITCH_INCOMPLETE:    return (syserr_cp_switch_incomplete);
  897.     case ERROR_VIO_TRANSPARENT_POPUP:    return (syserr_vio_transparent_popup);
  898.     case ERROR_CRITSEC_OVERFLOW:    return (syserr_critsec_overflow);
  899.     case ERROR_CRITSEC_UNDERFLOW:    return (syserr_critsec_underflow);
  900.     case ERROR_VIO_BAD_RESERVE:    return (syserr_vio_bad_reserve);
  901.     case ERROR_INVALID_ADDRESS:    return (syserr_invalid_address);
  902.     case ERROR_ZERO_SELECTORS_REQUESTED:    return (syserr_zero_selectors_requested);
  903.     case ERROR_NOT_ENOUGH_SELECTORS_AVA:    return (syserr_not_enough_selectors_ava);
  904.     case ERROR_INVALID_SELECTOR:    return (syserr_invalid_selector);
  905.     case ERROR_SMG_INVALID_PROGRAM_TYPE:    return (syserr_smg_invalid_program_type);
  906.     case ERROR_SMG_INVALID_PGM_CONTROL:    return (syserr_smg_invalid_pgm_control);
  907.     case ERROR_SMG_INVALID_INHERIT_OPT:    return (syserr_smg_invalid_inherit_opt);
  908.     case ERROR_VIO_EXTENDED_SG:    return (syserr_vio_extended_sg);
  909.     case ERROR_VIO_NOT_PRES_MGR_SG:    return (syserr_vio_not_pres_mgr_sg);
  910.     case ERROR_VIO_SHIELD_OWNED:    return (syserr_vio_shield_owned);
  911.     case ERROR_VIO_NO_MORE_HANDLES:    return (syserr_vio_no_more_handles);
  912.     case ERROR_VIO_SEE_ERROR_LOG:    return (syserr_vio_see_error_log);
  913.     case ERROR_VIO_ASSOCIATED_DC:    return (syserr_vio_associated_dc);
  914.     case ERROR_KBD_NO_CONSOLE:    return (syserr_kbd_no_console);
  915.     case ERROR_MOUSE_NO_CONSOLE:    return (syserr_mouse_no_console);
  916.     case ERROR_MOUSE_INVALID_HANDLE:    return (syserr_mouse_invalid_handle);
  917.     case ERROR_SMG_INVALID_DEBUG_PARMS:    return (syserr_smg_invalid_debug_parms);
  918.     case ERROR_KBD_EXTENDED_SG:    return (syserr_kbd_extended_sg);
  919.     case ERROR_MOU_EXTENDED_SG:    return (syserr_mou_extended_sg);
  920.     case ERROR_SMG_INVALID_ICON_FILE:    return (syserr_smg_invalid_icon_file);
  921.     case ERROR_TRC_PID_NON_EXISTENT:    return (syserr_trc_pid_non_existent);
  922.     case ERROR_TRC_COUNT_ACTIVE:    return (syserr_trc_count_active);
  923.     case ERROR_TRC_SUSPENDED_BY_COUNT:    return (syserr_trc_suspended_by_count);
  924.     case ERROR_TRC_COUNT_INACTIVE:    return (syserr_trc_count_inactive);
  925.     case ERROR_TRC_COUNT_REACHED:    return (syserr_trc_count_reached);
  926.     case ERROR_NO_MC_TRACE:    return (syserr_no_mc_trace);
  927.     case ERROR_MC_TRACE:    return (syserr_mc_trace);
  928.     case ERROR_TRC_COUNT_ZERO:    return (syserr_trc_count_zero);
  929.     case ERROR_SMG_TOO_MANY_DDS:    return (syserr_smg_too_many_dds);
  930.     case ERROR_SMG_INVALID_NOTIFICATION:    return (syserr_smg_invalid_notification);
  931.     case ERROR_LF_INVALID_FUNCTION:    return (syserr_lf_invalid_function);
  932.     case ERROR_LF_NOT_AVAIL:    return (syserr_lf_not_avail);
  933.     case ERROR_LF_SUSPENDED:    return (syserr_lf_suspended);
  934.     case ERROR_LF_BUF_TOO_SMALL:    return (syserr_lf_buf_too_small);
  935.     case ERROR_LF_BUFFER_FULL:    return (syserr_lf_buffer_full);
  936.     case ERROR_LF_INVALID_RECORD:    return (syserr_lf_invalid_record);
  937.     case ERROR_LF_INVALID_SERVICE:    return (syserr_lf_invalid_service);
  938.     case ERROR_LF_GENERAL_FAILURE:    return (syserr_lf_general_failure);
  939.     case ERROR_LF_INVALID_ID:    return (syserr_lf_invalid_id);
  940.     case ERROR_LF_INVALID_HANDLE:    return (syserr_lf_invalid_handle);
  941.     case ERROR_LF_NO_ID_AVAIL:    return (syserr_lf_no_id_avail);
  942.     case ERROR_LF_TEMPLATE_AREA_FULL:    return (syserr_lf_template_area_full);
  943.     case ERROR_LF_ID_IN_USE:    return (syserr_lf_id_in_use);
  944.     case ERROR_MOU_NOT_INITIALIZED:    return (syserr_mou_not_initialized);
  945.     case ERROR_MOUINITREAL_DONE:    return (syserr_mouinitreal_done);
  946.     case ERROR_DOSSUB_CORRUPTED:    return (syserr_dossub_corrupted);
  947.     case ERROR_MOUSE_CALLER_NOT_SUBSYS:    return (syserr_mouse_caller_not_subsys);
  948.     case ERROR_ARITHMETIC_OVERFLOW:    return (syserr_arithmetic_overflow);
  949.     case ERROR_TMR_NO_DEVICE:    return (syserr_tmr_no_device);
  950.     case ERROR_TMR_INVALID_TIME:    return (syserr_tmr_invalid_time);
  951.     case ERROR_PVW_INVALID_ENTITY:    return (syserr_pvw_invalid_entity);
  952.     case ERROR_PVW_INVALID_ENTITY_TYPE:    return (syserr_pvw_invalid_entity_type);
  953.     case ERROR_PVW_INVALID_SPEC:    return (syserr_pvw_invalid_spec);
  954.     case ERROR_PVW_INVALID_RANGE_TYPE:    return (syserr_pvw_invalid_range_type);
  955.     case ERROR_PVW_INVALID_COUNTER_BLK:    return (syserr_pvw_invalid_counter_blk);
  956.     case ERROR_PVW_INVALID_TEXT_BLK:    return (syserr_pvw_invalid_text_blk);
  957.     case ERROR_PRF_NOT_INITIALIZED:    return (syserr_prf_not_initialized);
  958.     case ERROR_PRF_ALREADY_INITIALIZED:    return (syserr_prf_already_initialized);
  959.     case ERROR_PRF_NOT_STARTED:    return (syserr_prf_not_started);
  960.     case ERROR_PRF_ALREADY_STARTED:    return (syserr_prf_already_started);
  961.     case ERROR_PRF_TIMER_OUT_OF_RANGE:    return (syserr_prf_timer_out_of_range);
  962.     case ERROR_PRF_TIMER_RESET:    return (syserr_prf_timer_reset);
  963.     case ERROR_VDD_LOCK_USEAGE_DENIED:    return (syserr_vdd_lock_useage_denied);
  964.     case ERROR_TIMEOUT:    return (syserr_timeout);
  965.     case ERROR_VDM_DOWN:    return (syserr_vdm_down);
  966.     case ERROR_VDM_LIMIT:    return (syserr_vdm_limit);
  967.     case ERROR_VDD_NOT_FOUND:    return (syserr_vdd_not_found);
  968.     case ERROR_INVALID_CALLER:    return (syserr_invalid_caller);
  969.     case ERROR_PID_MISMATCH:    return (syserr_pid_mismatch);
  970.     case ERROR_INVALID_VDD_HANDLE:    return (syserr_invalid_vdd_handle);
  971.     case ERROR_VLPT_NO_SPOOLER:    return (syserr_vlpt_no_spooler);
  972.     case ERROR_VCOM_DEVICE_BUSY:    return (syserr_vcom_device_busy);
  973.     case ERROR_VLPT_DEVICE_BUSY:    return (syserr_vlpt_device_busy);
  974.     case ERROR_NESTING_TOO_DEEP:    return (syserr_nesting_too_deep);
  975.     case ERROR_VDD_MISSING:    return (syserr_vdd_missing);
  976.     case ERROR_BIDI_INVALID_LENGTH:    return (syserr_bidi_invalid_length);
  977.     case ERROR_BIDI_INVALID_INCREMENT:    return (syserr_bidi_invalid_increment);
  978.     case ERROR_BIDI_INVALID_COMBINATION:    return (syserr_bidi_invalid_combination);
  979.     case ERROR_BIDI_INVALID_RESERVED:    return (syserr_bidi_invalid_reserved);
  980.     case ERROR_BIDI_INVALID_EFFECT:    return (syserr_bidi_invalid_effect);
  981.     case ERROR_BIDI_INVALID_CSDREC:    return (syserr_bidi_invalid_csdrec);
  982.     case ERROR_BIDI_INVALID_CSDSTATE:    return (syserr_bidi_invalid_csdstate);
  983.     case ERROR_BIDI_INVALID_LEVEL:    return (syserr_bidi_invalid_level);
  984.     case ERROR_BIDI_INVALID_TYPE_SUPPORT:    return (syserr_bidi_invalid_type_support);
  985.     case ERROR_BIDI_INVALID_ORIENTATION:    return (syserr_bidi_invalid_orientation);
  986.     case ERROR_BIDI_INVALID_NUM_SHAPE:    return (syserr_bidi_invalid_num_shape);
  987.     case ERROR_BIDI_INVALID_CSD:    return (syserr_bidi_invalid_csd);
  988.     case ERROR_BIDI_NO_SUPPORT:    return (syserr_bidi_no_support);
  989.     case NO_ERROR_BIDI_RW_INCOMPLETE:    return (syserr_bidi_rw_incomplete);
  990.     case ERROR_IMP_INVALID_PARM:    return (syserr_imp_invalid_parm);
  991.     case ERROR_IMP_INVALID_LENGTH:    return (syserr_imp_invalid_length);
  992. #ifdef MSG_HPFS_DISK_ERROR_WARN
  993.     case MSG_HPFS_DISK_ERROR_WARN:    return (syserr_hpfs_disk_error_warn);
  994. #endif
  995.     case ERROR_MON_BAD_BUFFER:    return (syserr_mon_bad_buffer);
  996.     case ERROR_MODULE_CORRUPTED:    return (syserr_module_corrupted);
  997.     case ERROR_SM_OUTOF_SWAPFILE:    return (syserr_sm_outof_swapfile);
  998.     case ERROR_LF_TIMEOUT:    return (syserr_lf_timeout);
  999.     case ERROR_LF_SUSPEND_SUCCESS:    return (syserr_lf_suspend_success);
  1000.     case ERROR_LF_RESUME_SUCCESS:    return (syserr_lf_resume_success);
  1001.     case ERROR_LF_REDIRECT_SUCCESS:    return (syserr_lf_redirect_success);
  1002.     case ERROR_LF_REDIRECT_FAILURE:    return (syserr_lf_redirect_failure);
  1003.     case ERROR_SWAPPER_NOT_ACTIVE:    return (syserr_swapper_not_active);
  1004.     case ERROR_INVALID_SWAPID:    return (syserr_invalid_swapid);
  1005.     case ERROR_IOERR_SWAP_FILE:    return (syserr_ioerr_swap_file);
  1006.     case ERROR_SWAP_TABLE_FULL:    return (syserr_swap_table_full);
  1007.     case ERROR_SWAP_FILE_FULL:    return (syserr_swap_file_full);
  1008.     case ERROR_CANT_INIT_SWAPPER:    return (syserr_cant_init_swapper);
  1009.     case ERROR_SWAPPER_ALREADY_INIT:    return (syserr_swapper_already_init);
  1010.     case ERROR_PMM_INSUFFICIENT_MEMORY:    return (syserr_pmm_insufficient_memory);
  1011.     case ERROR_PMM_INVALID_FLAGS:    return (syserr_pmm_invalid_flags);
  1012.     case ERROR_PMM_INVALID_ADDRESS:    return (syserr_pmm_invalid_address);
  1013.     case ERROR_PMM_LOCK_FAILED:    return (syserr_pmm_lock_failed);
  1014.     case ERROR_PMM_UNLOCK_FAILED:    return (syserr_pmm_unlock_failed);
  1015.     case ERROR_PMM_MOVE_INCOMPLETE:    return (syserr_pmm_move_incomplete);
  1016.     case ERROR_UCOM_DRIVE_RENAMED:    return (syserr_ucom_drive_renamed);
  1017.     case ERROR_UCOM_FILENAME_TRUNCATED:    return (syserr_ucom_filename_truncated);
  1018.     case ERROR_UCOM_BUFFER_LENGTH:    return (syserr_ucom_buffer_length);
  1019.     case ERROR_MON_CHAIN_HANDLE:    return (syserr_mon_chain_handle);
  1020.     case ERROR_MON_NOT_REGISTERED:    return (syserr_mon_not_registered);
  1021.     case ERROR_SMG_ALREADY_TOP:    return (syserr_smg_already_top);
  1022.     case ERROR_PMM_ARENA_MODIFIED:    return (syserr_pmm_arena_modified);
  1023.     case ERROR_SMG_PRINTER_OPEN:    return (syserr_smg_printer_open);
  1024.     case ERROR_PMM_SET_FLAGS_FAILED:    return (syserr_pmm_set_flags_failed);
  1025.     case ERROR_INVALID_DOS_DD:    return (syserr_invalid_dos_dd);
  1026.     case ERROR_BLOCKED:    return (syserr_blocked);
  1027.     case ERROR_NOBLOCK:    return (syserr_noblock);
  1028.     case ERROR_INSTANCE_SHARED:    return (syserr_instance_shared);
  1029.     case ERROR_NO_OBJECT:    return (syserr_no_object);
  1030.     case ERROR_PARTIAL_ATTACH:    return (syserr_partial_attach);
  1031.     case ERROR_INCACHE:    return (syserr_incache);
  1032.     case ERROR_SWAP_IO_PROBLEMS:    return (syserr_swap_io_problems);
  1033.     case ERROR_CROSSES_OBJECT_BOUNDARY:    return (syserr_crosses_object_boundary);
  1034.     case ERROR_LONGLOCK:    return (syserr_longlock);
  1035.     case ERROR_SHORTLOCK:    return (syserr_shortlock);
  1036.     case ERROR_UVIRTLOCK:    return (syserr_uvirtlock);
  1037.     case ERROR_ALIASLOCK:    return (syserr_aliaslock);
  1038.     case ERROR_ALIAS:    return (syserr_alias);
  1039.     case ERROR_NO_MORE_HANDLES:    return (syserr_no_more_handles);
  1040.     case ERROR_SCAN_TERMINATED:    return (syserr_scan_terminated);
  1041.     case ERROR_TERMINATOR_NOT_FOUND:    return (syserr_terminator_not_found);
  1042.     case ERROR_NOT_DIRECT_CHILD:    return (syserr_not_direct_child);
  1043.     case ERROR_DELAY_FREE:    return (syserr_delay_free);
  1044.     case ERROR_GUARDPAGE:    return (syserr_guardpage);
  1045.     case ERROR_SWAPERROR:    return (syserr_swaperror);
  1046.     case ERROR_LDRERROR:    return (syserr_ldrerror);
  1047.     case ERROR_NOMEMORY:    return (syserr_nomemory);
  1048.     case ERROR_NOACCESS:    return (syserr_noaccess);
  1049.     case ERROR_NO_DLL_TERM:    return (syserr_no_dll_term);
  1050.     case ERROR_CPSIO_CODE_PAGE_INVALID:    return (syserr_cpsio_code_page_invalid);
  1051.     case ERROR_CPSIO_NO_SPOOLER:    return (syserr_cpsio_no_spooler);
  1052.     case ERROR_CPSIO_FONT_ID_INVALID:    return (syserr_cpsio_font_id_invalid);
  1053.     case ERROR_CPSIO_INTERNAL_ERROR:    return (syserr_cpsio_internal_error);
  1054.     case ERROR_CPSIO_INVALID_PTR_NAME:    return (syserr_cpsio_invalid_ptr_name);
  1055.     case ERROR_CPSIO_NOT_ACTIVE:    return (syserr_cpsio_not_active);
  1056.     case ERROR_CPSIO_PID_FULL:    return (syserr_cpsio_pid_full);
  1057.     case ERROR_CPSIO_PID_NOT_FOUND:    return (syserr_cpsio_pid_not_found);
  1058.     case ERROR_CPSIO_READ_CTL_SEQ:    return (syserr_cpsio_read_ctl_seq);
  1059.     case ERROR_CPSIO_READ_FNT_DEF:    return (syserr_cpsio_read_fnt_def);
  1060.     case ERROR_CPSIO_WRITE_ERROR:    return (syserr_cpsio_write_error);
  1061.     case ERROR_CPSIO_WRITE_FULL_ERROR:    return (syserr_cpsio_write_full_error);
  1062.     case ERROR_CPSIO_WRITE_HANDLE_BAD:    return (syserr_cpsio_write_handle_bad);
  1063.     case ERROR_CPSIO_SWIT_LOAD:    return (syserr_cpsio_swit_load);
  1064.     case ERROR_CPSIO_INV_COMMAND:    return (syserr_cpsio_inv_command);
  1065.     case ERROR_CPSIO_NO_FONT_SWIT:    return (syserr_cpsio_no_font_swit);
  1066.     case ERROR_ENTRY_IS_CALLGATE:    return (syserr_entry_is_callgate);
  1067.  
  1068. #ifndef DISABLE_SOCKET_SUPPORT
  1069.     case SOCEPERM:        return (syserr_socket_perm);
  1070.     case SOCESRCH:        return (syserr_socket_srch);
  1071.     case SOCEINTR:        return (syserr_socket_intr);
  1072.     case SOCENXIO:        return (syserr_socket_nxio);
  1073.     case SOCEBADF:        return (syserr_socket_badf);
  1074.     case SOCEACCES:        return (syserr_socket_acces);
  1075.     case SOCEFAULT:        return (syserr_socket_fault);
  1076.     case SOCEINVAL:        return (syserr_socket_inval);
  1077.     case SOCEMFILE:        return (syserr_socket_mfile);
  1078.     case SOCEPIPE:        return (syserr_socket_pipe);
  1079.     case SOCEOS2ERR:        return (syserr_socket_os2err);
  1080.     case SOCEWOULDBLOCK:    return (syserr_socket_wouldblock);
  1081.     case SOCEINPROGRESS:    return (syserr_socket_inprogress);
  1082.     case SOCEALREADY:        return (syserr_socket_already);
  1083.     case SOCENOTSOCK:        return (syserr_socket_notsock);
  1084.     case SOCEDESTADDRREQ:    return (syserr_socket_destaddrreq);
  1085.     case SOCEMSGSIZE:        return (syserr_socket_msgsize);
  1086.     case SOCEPROTOTYPE:        return (syserr_socket_prototype);
  1087.     case SOCENOPROTOOPT:    return (syserr_socket_noprotoopt);
  1088.     case SOCEPROTONOSUPPORT:    return (syserr_socket_protonosupport);
  1089.     case SOCESOCKTNOSUPPORT:    return (syserr_socket_socktnosupport);
  1090.     case SOCEOPNOTSUPP:        return (syserr_socket_opnotsupp);
  1091.     case SOCEPFNOSUPPORT:    return (syserr_socket_pfnosupport);
  1092.     case SOCEAFNOSUPPORT:    return (syserr_socket_afnosupport);
  1093.     case SOCEADDRINUSE:        return (syserr_socket_addrinuse);
  1094.     case SOCEADDRNOTAVAIL:    return (syserr_socket_addrnotavail);
  1095.     case SOCENETDOWN:        return (syserr_socket_netdown);
  1096.     case SOCENETUNREACH:    return (syserr_socket_netunreach);
  1097.     case SOCENETRESET:        return (syserr_socket_netreset);
  1098.     case SOCECONNABORTED:    return (syserr_socket_connaborted);
  1099.     case SOCECONNRESET:        return (syserr_socket_connreset);
  1100.     case SOCENOBUFS:        return (syserr_socket_nobufs);
  1101.     case SOCEISCONN:        return (syserr_socket_isconn);
  1102.     case SOCENOTCONN:        return (syserr_socket_notconn);
  1103.     case SOCESHUTDOWN:        return (syserr_socket_shutdown);
  1104.     case SOCETOOMANYREFS:    return (syserr_socket_toomanyrefs);
  1105.     case SOCETIMEDOUT:        return (syserr_socket_timedout);
  1106.     case SOCECONNREFUSED:    return (syserr_socket_connrefused);
  1107.     case SOCELOOP:        return (syserr_socket_loop);
  1108.     case SOCENAMETOOLONG:    return (syserr_socket_nametoolong);
  1109.     case SOCEHOSTDOWN:        return (syserr_socket_hostdown);
  1110.     case SOCEHOSTUNREACH:    return (syserr_socket_hostunreach);
  1111.     case SOCENOTEMPTY:        return (syserr_socket_notempty);
  1112. #endif /* not DISABLE_SOCKET_SUPPORT */
  1113.  
  1114.     default:    return (syserr_unknown);
  1115.     }
  1116. }
  1117.  
  1118. /* Machine-generated procedure, do not edit: */
  1119. static APIRET
  1120. syserr_to_error_code (enum syserr_names syserr)
  1121. {
  1122.   switch (syserr)
  1123.     {
  1124.     case syserr_invalid_function:    return (ERROR_INVALID_FUNCTION);
  1125.     case syserr_file_not_found:    return (ERROR_FILE_NOT_FOUND);
  1126.     case syserr_path_not_found:    return (ERROR_PATH_NOT_FOUND);
  1127.     case syserr_too_many_open_files:    return (ERROR_TOO_MANY_OPEN_FILES);
  1128.     case syserr_access_denied:    return (ERROR_ACCESS_DENIED);
  1129.     case syserr_invalid_handle:    return (ERROR_INVALID_HANDLE);
  1130.     case syserr_arena_trashed:    return (ERROR_ARENA_TRASHED);
  1131.     case syserr_not_enough_memory:    return (ERROR_NOT_ENOUGH_MEMORY);
  1132.     case syserr_invalid_block:    return (ERROR_INVALID_BLOCK);
  1133.     case syserr_bad_environment:    return (ERROR_BAD_ENVIRONMENT);
  1134.     case syserr_bad_format:    return (ERROR_BAD_FORMAT);
  1135.     case syserr_invalid_access:    return (ERROR_INVALID_ACCESS);
  1136.     case syserr_invalid_data:    return (ERROR_INVALID_DATA);
  1137.     case syserr_invalid_drive:    return (ERROR_INVALID_DRIVE);
  1138.     case syserr_current_directory:    return (ERROR_CURRENT_DIRECTORY);
  1139.     case syserr_not_same_device:    return (ERROR_NOT_SAME_DEVICE);
  1140.     case syserr_no_more_files:    return (ERROR_NO_MORE_FILES);
  1141.     case syserr_write_protect:    return (ERROR_WRITE_PROTECT);
  1142.     case syserr_bad_unit:    return (ERROR_BAD_UNIT);
  1143.     case syserr_not_ready:    return (ERROR_NOT_READY);
  1144.     case syserr_bad_command:    return (ERROR_BAD_COMMAND);
  1145.     case syserr_crc:    return (ERROR_CRC);
  1146.     case syserr_bad_length:    return (ERROR_BAD_LENGTH);
  1147.     case syserr_seek:    return (ERROR_SEEK);
  1148.     case syserr_not_dos_disk:    return (ERROR_NOT_DOS_DISK);
  1149.     case syserr_sector_not_found:    return (ERROR_SECTOR_NOT_FOUND);
  1150.     case syserr_out_of_paper:    return (ERROR_OUT_OF_PAPER);
  1151.     case syserr_write_fault:    return (ERROR_WRITE_FAULT);
  1152.     case syserr_read_fault:    return (ERROR_READ_FAULT);
  1153.     case syserr_gen_failure:    return (ERROR_GEN_FAILURE);
  1154.     case syserr_sharing_violation:    return (ERROR_SHARING_VIOLATION);
  1155.     case syserr_lock_violation:    return (ERROR_LOCK_VIOLATION);
  1156.     case syserr_wrong_disk:    return (ERROR_WRONG_DISK);
  1157.     case syserr_fcb_unavailable:    return (ERROR_FCB_UNAVAILABLE);
  1158.     case syserr_sharing_buffer_exceeded:    return (ERROR_SHARING_BUFFER_EXCEEDED);
  1159.     case syserr_code_page_mismatched:    return (ERROR_CODE_PAGE_MISMATCHED);
  1160.     case syserr_handle_eof:    return (ERROR_HANDLE_EOF);
  1161.     case syserr_handle_disk_full:    return (ERROR_HANDLE_DISK_FULL);
  1162.     case syserr_not_supported:    return (ERROR_NOT_SUPPORTED);
  1163.     case syserr_rem_not_list:    return (ERROR_REM_NOT_LIST);
  1164.     case syserr_dup_name:    return (ERROR_DUP_NAME);
  1165.     case syserr_bad_netpath:    return (ERROR_BAD_NETPATH);
  1166.     case syserr_network_busy:    return (ERROR_NETWORK_BUSY);
  1167.     case syserr_dev_not_exist:    return (ERROR_DEV_NOT_EXIST);
  1168.     case syserr_too_many_cmds:    return (ERROR_TOO_MANY_CMDS);
  1169.     case syserr_adap_hdw_err:    return (ERROR_ADAP_HDW_ERR);
  1170.     case syserr_bad_net_resp:    return (ERROR_BAD_NET_RESP);
  1171.     case syserr_unexp_net_err:    return (ERROR_UNEXP_NET_ERR);
  1172.     case syserr_bad_rem_adap:    return (ERROR_BAD_REM_ADAP);
  1173.     case syserr_printq_full:    return (ERROR_PRINTQ_FULL);
  1174.     case syserr_no_spool_space:    return (ERROR_NO_SPOOL_SPACE);
  1175.     case syserr_print_cancelled:    return (ERROR_PRINT_CANCELLED);
  1176.     case syserr_netname_deleted:    return (ERROR_NETNAME_DELETED);
  1177.     case syserr_network_access_denied:    return (ERROR_NETWORK_ACCESS_DENIED);
  1178.     case syserr_bad_dev_type:    return (ERROR_BAD_DEV_TYPE);
  1179.     case syserr_bad_net_name:    return (ERROR_BAD_NET_NAME);
  1180.     case syserr_too_many_names:    return (ERROR_TOO_MANY_NAMES);
  1181.     case syserr_too_many_sess:    return (ERROR_TOO_MANY_SESS);
  1182.     case syserr_sharing_paused:    return (ERROR_SHARING_PAUSED);
  1183.     case syserr_req_not_accep:    return (ERROR_REQ_NOT_ACCEP);
  1184.     case syserr_redir_paused:    return (ERROR_REDIR_PAUSED);
  1185.     case syserr_sbcs_att_write_prot:    return (ERROR_SBCS_ATT_WRITE_PROT);
  1186.     case syserr_sbcs_general_failure:    return (ERROR_SBCS_GENERAL_FAILURE);
  1187.     case syserr_xga_out_memory:    return (ERROR_XGA_OUT_MEMORY);
  1188.     case syserr_file_exists:    return (ERROR_FILE_EXISTS);
  1189.     case syserr_dup_fcb:    return (ERROR_DUP_FCB);
  1190.     case syserr_cannot_make:    return (ERROR_CANNOT_MAKE);
  1191.     case syserr_fail_i24:    return (ERROR_FAIL_I24);
  1192.     case syserr_out_of_structures:    return (ERROR_OUT_OF_STRUCTURES);
  1193.     case syserr_already_assigned:    return (ERROR_ALREADY_ASSIGNED);
  1194.     case syserr_invalid_password:    return (ERROR_INVALID_PASSWORD);
  1195.     case syserr_invalid_parameter:    return (ERROR_INVALID_PARAMETER);
  1196.     case syserr_net_write_fault:    return (ERROR_NET_WRITE_FAULT);
  1197.     case syserr_no_proc_slots:    return (ERROR_NO_PROC_SLOTS);
  1198.     case syserr_not_frozen:    return (ERROR_NOT_FROZEN);
  1199.     case syserr_tstovfl:    return (ERR_TSTOVFL);
  1200.     case syserr_tstdup:    return (ERR_TSTDUP);
  1201.     case syserr_no_items:    return (ERROR_NO_ITEMS);
  1202.     case syserr_interrupt:    return (ERROR_INTERRUPT);
  1203.     case syserr_device_in_use:    return (ERROR_DEVICE_IN_USE);
  1204.     case syserr_too_many_semaphores:    return (ERROR_TOO_MANY_SEMAPHORES);
  1205.     case syserr_excl_sem_already_owned:    return (ERROR_EXCL_SEM_ALREADY_OWNED);
  1206.     case syserr_sem_is_set:    return (ERROR_SEM_IS_SET);
  1207.     case syserr_too_many_sem_requests:    return (ERROR_TOO_MANY_SEM_REQUESTS);
  1208.     case syserr_invalid_at_interrupt_time:    return (ERROR_INVALID_AT_INTERRUPT_TIME);
  1209.     case syserr_sem_owner_died:    return (ERROR_SEM_OWNER_DIED);
  1210.     case syserr_sem_user_limit:    return (ERROR_SEM_USER_LIMIT);
  1211.     case syserr_disk_change:    return (ERROR_DISK_CHANGE);
  1212.     case syserr_drive_locked:    return (ERROR_DRIVE_LOCKED);
  1213.     case syserr_broken_pipe:    return (ERROR_BROKEN_PIPE);
  1214.     case syserr_open_failed:    return (ERROR_OPEN_FAILED);
  1215.     case syserr_buffer_overflow:    return (ERROR_BUFFER_OVERFLOW);
  1216.     case syserr_disk_full:    return (ERROR_DISK_FULL);
  1217.     case syserr_no_more_search_handles:    return (ERROR_NO_MORE_SEARCH_HANDLES);
  1218.     case syserr_invalid_target_handle:    return (ERROR_INVALID_TARGET_HANDLE);
  1219.     case syserr_protection_violation:    return (ERROR_PROTECTION_VIOLATION);
  1220.     case syserr_viokbd_request:    return (ERROR_VIOKBD_REQUEST);
  1221.     case syserr_invalid_category:    return (ERROR_INVALID_CATEGORY);
  1222.     case syserr_invalid_verify_switch:    return (ERROR_INVALID_VERIFY_SWITCH);
  1223.     case syserr_bad_driver_level:    return (ERROR_BAD_DRIVER_LEVEL);
  1224.     case syserr_call_not_implemented:    return (ERROR_CALL_NOT_IMPLEMENTED);
  1225.     case syserr_sem_timeout:    return (ERROR_SEM_TIMEOUT);
  1226.     case syserr_insufficient_buffer:    return (ERROR_INSUFFICIENT_BUFFER);
  1227.     case syserr_invalid_name:    return (ERROR_INVALID_NAME);
  1228.     case syserr_invalid_level:    return (ERROR_INVALID_LEVEL);
  1229.     case syserr_no_volume_label:    return (ERROR_NO_VOLUME_LABEL);
  1230.     case syserr_mod_not_found:    return (ERROR_MOD_NOT_FOUND);
  1231.     case syserr_proc_not_found:    return (ERROR_PROC_NOT_FOUND);
  1232.     case syserr_wait_no_children:    return (ERROR_WAIT_NO_CHILDREN);
  1233.     case syserr_child_not_complete:    return (ERROR_CHILD_NOT_COMPLETE);
  1234.     case syserr_direct_access_handle:    return (ERROR_DIRECT_ACCESS_HANDLE);
  1235.     case syserr_negative_seek:    return (ERROR_NEGATIVE_SEEK);
  1236.     case syserr_seek_on_device:    return (ERROR_SEEK_ON_DEVICE);
  1237.     case syserr_is_join_target:    return (ERROR_IS_JOIN_TARGET);
  1238.     case syserr_is_joined:    return (ERROR_IS_JOINED);
  1239.     case syserr_is_substed:    return (ERROR_IS_SUBSTED);
  1240.     case syserr_not_joined:    return (ERROR_NOT_JOINED);
  1241.     case syserr_not_substed:    return (ERROR_NOT_SUBSTED);
  1242.     case syserr_join_to_join:    return (ERROR_JOIN_TO_JOIN);
  1243.     case syserr_subst_to_subst:    return (ERROR_SUBST_TO_SUBST);
  1244.     case syserr_join_to_subst:    return (ERROR_JOIN_TO_SUBST);
  1245.     case syserr_subst_to_join:    return (ERROR_SUBST_TO_JOIN);
  1246.     case syserr_busy_drive:    return (ERROR_BUSY_DRIVE);
  1247.     case syserr_same_drive:    return (ERROR_SAME_DRIVE);
  1248.     case syserr_dir_not_root:    return (ERROR_DIR_NOT_ROOT);
  1249.     case syserr_dir_not_empty:    return (ERROR_DIR_NOT_EMPTY);
  1250.     case syserr_is_subst_path:    return (ERROR_IS_SUBST_PATH);
  1251.     case syserr_is_join_path:    return (ERROR_IS_JOIN_PATH);
  1252.     case syserr_path_busy:    return (ERROR_PATH_BUSY);
  1253.     case syserr_is_subst_target:    return (ERROR_IS_SUBST_TARGET);
  1254.     case syserr_system_trace:    return (ERROR_SYSTEM_TRACE);
  1255.     case syserr_invalid_event_count:    return (ERROR_INVALID_EVENT_COUNT);
  1256.     case syserr_too_many_muxwaiters:    return (ERROR_TOO_MANY_MUXWAITERS);
  1257.     case syserr_invalid_list_format:    return (ERROR_INVALID_LIST_FORMAT);
  1258.     case syserr_label_too_long:    return (ERROR_LABEL_TOO_LONG);
  1259.     case syserr_too_many_tcbs:    return (ERROR_TOO_MANY_TCBS);
  1260.     case syserr_signal_refused:    return (ERROR_SIGNAL_REFUSED);
  1261.     case syserr_discarded:    return (ERROR_DISCARDED);
  1262.     case syserr_not_locked:    return (ERROR_NOT_LOCKED);
  1263.     case syserr_bad_threadid_addr:    return (ERROR_BAD_THREADID_ADDR);
  1264.     case syserr_bad_arguments:    return (ERROR_BAD_ARGUMENTS);
  1265.     case syserr_bad_pathname:    return (ERROR_BAD_PATHNAME);
  1266.     case syserr_signal_pending:    return (ERROR_SIGNAL_PENDING);
  1267.     case syserr_uncertain_media:    return (ERROR_UNCERTAIN_MEDIA);
  1268.     case syserr_max_thrds_reached:    return (ERROR_MAX_THRDS_REACHED);
  1269.     case syserr_monitors_not_supported:    return (ERROR_MONITORS_NOT_SUPPORTED);
  1270.     case syserr_unc_driver_not_installed:    return (ERROR_UNC_DRIVER_NOT_INSTALLED);
  1271.     case syserr_lock_failed:    return (ERROR_LOCK_FAILED);
  1272.     case syserr_swapio_failed:    return (ERROR_SWAPIO_FAILED);
  1273.     case syserr_swapin_failed:    return (ERROR_SWAPIN_FAILED);
  1274.     case syserr_busy:    return (ERROR_BUSY);
  1275.     case syserr_cancel_violation:    return (ERROR_CANCEL_VIOLATION);
  1276.     case syserr_atomic_lock_not_supported:    return (ERROR_ATOMIC_LOCK_NOT_SUPPORTED);
  1277.     case syserr_read_locks_not_supported:    return (ERROR_READ_LOCKS_NOT_SUPPORTED);
  1278.     case syserr_invalid_segment_number:    return (ERROR_INVALID_SEGMENT_NUMBER);
  1279.     case syserr_invalid_callgate:    return (ERROR_INVALID_CALLGATE);
  1280.     case syserr_invalid_ordinal:    return (ERROR_INVALID_ORDINAL);
  1281.     case syserr_already_exists:    return (ERROR_ALREADY_EXISTS);
  1282.     case syserr_no_child_process:    return (ERROR_NO_CHILD_PROCESS);
  1283.     case syserr_child_alive_nowait:    return (ERROR_CHILD_ALIVE_NOWAIT);
  1284.     case syserr_invalid_flag_number:    return (ERROR_INVALID_FLAG_NUMBER);
  1285.     case syserr_sem_not_found:    return (ERROR_SEM_NOT_FOUND);
  1286.     case syserr_invalid_starting_codeseg:    return (ERROR_INVALID_STARTING_CODESEG);
  1287.     case syserr_invalid_stackseg:    return (ERROR_INVALID_STACKSEG);
  1288.     case syserr_invalid_moduletype:    return (ERROR_INVALID_MODULETYPE);
  1289.     case syserr_invalid_exe_signature:    return (ERROR_INVALID_EXE_SIGNATURE);
  1290.     case syserr_exe_marked_invalid:    return (ERROR_EXE_MARKED_INVALID);
  1291.     case syserr_bad_exe_format:    return (ERROR_BAD_EXE_FORMAT);
  1292. #ifdef ERROR_ITERATED_DATA_EXCEEDS_64k
  1293.     case syserr_iterated_data_exceeds_64k:    return (ERROR_ITERATED_DATA_EXCEEDS_64k);
  1294. #endif
  1295.     case syserr_invalid_minallocsize:    return (ERROR_INVALID_MINALLOCSIZE);
  1296.     case syserr_dynlink_from_invalid_ring:    return (ERROR_DYNLINK_FROM_INVALID_RING);
  1297.     case syserr_iopl_not_enabled:    return (ERROR_IOPL_NOT_ENABLED);
  1298.     case syserr_invalid_segdpl:    return (ERROR_INVALID_SEGDPL);
  1299. #ifdef ERROR_AUTODATASEG_EXCEEDS_64k
  1300.     case syserr_autodataseg_exceeds_64k:    return (ERROR_AUTODATASEG_EXCEEDS_64k);
  1301. #endif
  1302.     case syserr_ring2seg_must_be_movable:    return (ERROR_RING2SEG_MUST_BE_MOVABLE);
  1303. #ifdef ERROR_RELOC_CHAIN_XEEDS_SEGLIM
  1304.     case syserr_reloc_chain_xeeds_seglim:    return (ERROR_RELOC_CHAIN_XEEDS_SEGLIM);
  1305. #endif
  1306.     case syserr_infloop_in_reloc_chain:    return (ERROR_INFLOOP_IN_RELOC_CHAIN);
  1307.     case syserr_envvar_not_found:    return (ERROR_ENVVAR_NOT_FOUND);
  1308.     case syserr_not_current_ctry:    return (ERROR_NOT_CURRENT_CTRY);
  1309.     case syserr_no_signal_sent:    return (ERROR_NO_SIGNAL_SENT);
  1310.     case syserr_filename_exced_range:    return (ERROR_FILENAME_EXCED_RANGE);
  1311.     case syserr_ring2_stack_in_use:    return (ERROR_RING2_STACK_IN_USE);
  1312.     case syserr_meta_expansion_too_long:    return (ERROR_META_EXPANSION_TOO_LONG);
  1313.     case syserr_invalid_signal_number:    return (ERROR_INVALID_SIGNAL_NUMBER);
  1314.     case syserr_thread_1_inactive:    return (ERROR_THREAD_1_INACTIVE);
  1315.     case syserr_info_not_avail:    return (ERROR_INFO_NOT_AVAIL);
  1316.     case syserr_locked:    return (ERROR_LOCKED);
  1317.     case syserr_bad_dynalink:    return (ERROR_BAD_DYNALINK);
  1318.     case syserr_too_many_modules:    return (ERROR_TOO_MANY_MODULES);
  1319.     case syserr_nesting_not_allowed:    return (ERROR_NESTING_NOT_ALLOWED);
  1320.     case syserr_cannot_shrink:    return (ERROR_CANNOT_SHRINK);
  1321.     case syserr_zombie_process:    return (ERROR_ZOMBIE_PROCESS);
  1322.     case syserr_stack_in_high_memory:    return (ERROR_STACK_IN_HIGH_MEMORY);
  1323.     case syserr_invalid_exitroutine_ring:    return (ERROR_INVALID_EXITROUTINE_RING);
  1324.     case syserr_getbuf_failed:    return (ERROR_GETBUF_FAILED);
  1325.     case syserr_flushbuf_failed:    return (ERROR_FLUSHBUF_FAILED);
  1326.     case syserr_transfer_too_long:    return (ERROR_TRANSFER_TOO_LONG);
  1327.     case syserr_forcenoswap_failed:    return (ERROR_FORCENOSWAP_FAILED);
  1328.     case syserr_smg_no_target_window:    return (ERROR_SMG_NO_TARGET_WINDOW);
  1329.     case syserr_no_children:    return (ERROR_NO_CHILDREN);
  1330.     case syserr_invalid_screen_group:    return (ERROR_INVALID_SCREEN_GROUP);
  1331.     case syserr_bad_pipe:    return (ERROR_BAD_PIPE);
  1332.     case syserr_pipe_busy:    return (ERROR_PIPE_BUSY);
  1333.     case syserr_no_data:    return (ERROR_NO_DATA);
  1334.     case syserr_pipe_not_connected:    return (ERROR_PIPE_NOT_CONNECTED);
  1335.     case syserr_more_data:    return (ERROR_MORE_DATA);
  1336.     case syserr_vc_disconnected:    return (ERROR_VC_DISCONNECTED);
  1337.     case syserr_circularity_requested:    return (ERROR_CIRCULARITY_REQUESTED);
  1338.     case syserr_directory_in_cds:    return (ERROR_DIRECTORY_IN_CDS);
  1339.     case syserr_invalid_fsd_name:    return (ERROR_INVALID_FSD_NAME);
  1340.     case syserr_invalid_path:    return (ERROR_INVALID_PATH);
  1341.     case syserr_invalid_ea_name:    return (ERROR_INVALID_EA_NAME);
  1342.     case syserr_ea_list_inconsistent:    return (ERROR_EA_LIST_INCONSISTENT);
  1343.     case syserr_ea_list_too_long:    return (ERROR_EA_LIST_TOO_LONG);
  1344.     case syserr_no_meta_match:    return (ERROR_NO_META_MATCH);
  1345.     case syserr_findnotify_timeout:    return (ERROR_FINDNOTIFY_TIMEOUT);
  1346.     case syserr_no_more_items:    return (ERROR_NO_MORE_ITEMS);
  1347.     case syserr_search_struc_reused:    return (ERROR_SEARCH_STRUC_REUSED);
  1348.     case syserr_char_not_found:    return (ERROR_CHAR_NOT_FOUND);
  1349.     case syserr_too_much_stack:    return (ERROR_TOO_MUCH_STACK);
  1350.     case syserr_invalid_attr:    return (ERROR_INVALID_ATTR);
  1351.     case syserr_invalid_starting_ring:    return (ERROR_INVALID_STARTING_RING);
  1352.     case syserr_invalid_dll_init_ring:    return (ERROR_INVALID_DLL_INIT_RING);
  1353.     case syserr_cannot_copy:    return (ERROR_CANNOT_COPY);
  1354.     case syserr_directory:    return (ERROR_DIRECTORY);
  1355.     case syserr_oplocked_file:    return (ERROR_OPLOCKED_FILE);
  1356.     case syserr_oplock_thread_exists:    return (ERROR_OPLOCK_THREAD_EXISTS);
  1357.     case syserr_volume_changed:    return (ERROR_VOLUME_CHANGED);
  1358.     case syserr_findnotify_handle_in_use:    return (ERROR_FINDNOTIFY_HANDLE_IN_USE);
  1359.     case syserr_findnotify_handle_closed:    return (ERROR_FINDNOTIFY_HANDLE_CLOSED);
  1360.     case syserr_notify_object_removed:    return (ERROR_NOTIFY_OBJECT_REMOVED);
  1361.     case syserr_already_shutdown:    return (ERROR_ALREADY_SHUTDOWN);
  1362.     case syserr_eas_didnt_fit:    return (ERROR_EAS_DIDNT_FIT);
  1363.     case syserr_ea_file_corrupt:    return (ERROR_EA_FILE_CORRUPT);
  1364.     case syserr_ea_table_full:    return (ERROR_EA_TABLE_FULL);
  1365.     case syserr_invalid_ea_handle:    return (ERROR_INVALID_EA_HANDLE);
  1366.     case syserr_no_cluster:    return (ERROR_NO_CLUSTER);
  1367.     case syserr_create_ea_file:    return (ERROR_CREATE_EA_FILE);
  1368.     case syserr_cannot_open_ea_file:    return (ERROR_CANNOT_OPEN_EA_FILE);
  1369.     case syserr_eas_not_supported:    return (ERROR_EAS_NOT_SUPPORTED);
  1370.     case syserr_need_eas_found:    return (ERROR_NEED_EAS_FOUND);
  1371.     case syserr_duplicate_handle:    return (ERROR_DUPLICATE_HANDLE);
  1372.     case syserr_duplicate_name:    return (ERROR_DUPLICATE_NAME);
  1373.     case syserr_empty_muxwait:    return (ERROR_EMPTY_MUXWAIT);
  1374.     case syserr_mutex_owned:    return (ERROR_MUTEX_OWNED);
  1375.     case syserr_not_owner:    return (ERROR_NOT_OWNER);
  1376.     case syserr_param_too_small:    return (ERROR_PARAM_TOO_SMALL);
  1377.     case syserr_too_many_handles:    return (ERROR_TOO_MANY_HANDLES);
  1378.     case syserr_too_many_opens:    return (ERROR_TOO_MANY_OPENS);
  1379.     case syserr_wrong_type:    return (ERROR_WRONG_TYPE);
  1380.     case syserr_unused_code:    return (ERROR_UNUSED_CODE);
  1381.     case syserr_thread_not_terminated:    return (ERROR_THREAD_NOT_TERMINATED);
  1382.     case syserr_init_routine_failed:    return (ERROR_INIT_ROUTINE_FAILED);
  1383.     case syserr_module_in_use:    return (ERROR_MODULE_IN_USE);
  1384.     case syserr_not_enough_watchpoints:    return (ERROR_NOT_ENOUGH_WATCHPOINTS);
  1385.     case syserr_too_many_posts:    return (ERROR_TOO_MANY_POSTS);
  1386.     case syserr_already_posted:    return (ERROR_ALREADY_POSTED);
  1387.     case syserr_already_reset:    return (ERROR_ALREADY_RESET);
  1388.     case syserr_sem_busy:    return (ERROR_SEM_BUSY);
  1389.     case syserr_invalid_procid:    return (ERROR_INVALID_PROCID);
  1390.     case syserr_invalid_pdelta:    return (ERROR_INVALID_PDELTA);
  1391.     case syserr_not_descendant:    return (ERROR_NOT_DESCENDANT);
  1392.     case syserr_not_session_manager:    return (ERROR_NOT_SESSION_MANAGER);
  1393.     case syserr_invalid_pclass:    return (ERROR_INVALID_PCLASS);
  1394.     case syserr_invalid_scope:    return (ERROR_INVALID_SCOPE);
  1395.     case syserr_invalid_threadid:    return (ERROR_INVALID_THREADID);
  1396.     case syserr_dossub_shrink:    return (ERROR_DOSSUB_SHRINK);
  1397.     case syserr_dossub_nomem:    return (ERROR_DOSSUB_NOMEM);
  1398.     case syserr_dossub_overlap:    return (ERROR_DOSSUB_OVERLAP);
  1399.     case syserr_dossub_badsize:    return (ERROR_DOSSUB_BADSIZE);
  1400.     case syserr_dossub_badflag:    return (ERROR_DOSSUB_BADFLAG);
  1401.     case syserr_dossub_badselector:    return (ERROR_DOSSUB_BADSELECTOR);
  1402.     case syserr_mr_msg_too_long:    return (ERROR_MR_MSG_TOO_LONG);
  1403.     case syserr_mr_mid_not_found:    return (ERROR_MR_MID_NOT_FOUND);
  1404.     case syserr_mr_un_acc_msgf:    return (ERROR_MR_UN_ACC_MSGF);
  1405.     case syserr_mr_inv_msgf_format:    return (ERROR_MR_INV_MSGF_FORMAT);
  1406.     case syserr_mr_inv_ivcount:    return (ERROR_MR_INV_IVCOUNT);
  1407.     case syserr_mr_un_perform:    return (ERROR_MR_UN_PERFORM);
  1408.     case syserr_ts_wakeup:    return (ERROR_TS_WAKEUP);
  1409.     case syserr_ts_semhandle:    return (ERROR_TS_SEMHANDLE);
  1410.     case syserr_ts_notimer:    return (ERROR_TS_NOTIMER);
  1411.     case syserr_ts_handle:    return (ERROR_TS_HANDLE);
  1412.     case syserr_ts_datetime:    return (ERROR_TS_DATETIME);
  1413.     case syserr_sys_internal:    return (ERROR_SYS_INTERNAL);
  1414.     case syserr_que_current_name:    return (ERROR_QUE_CURRENT_NAME);
  1415.     case syserr_que_proc_not_owned:    return (ERROR_QUE_PROC_NOT_OWNED);
  1416.     case syserr_que_proc_owned:    return (ERROR_QUE_PROC_OWNED);
  1417.     case syserr_que_duplicate:    return (ERROR_QUE_DUPLICATE);
  1418.     case syserr_que_element_not_exist:    return (ERROR_QUE_ELEMENT_NOT_EXIST);
  1419.     case syserr_que_no_memory:    return (ERROR_QUE_NO_MEMORY);
  1420.     case syserr_que_invalid_name:    return (ERROR_QUE_INVALID_NAME);
  1421.     case syserr_que_invalid_priority:    return (ERROR_QUE_INVALID_PRIORITY);
  1422.     case syserr_que_invalid_handle:    return (ERROR_QUE_INVALID_HANDLE);
  1423.     case syserr_que_link_not_found:    return (ERROR_QUE_LINK_NOT_FOUND);
  1424.     case syserr_que_memory_error:    return (ERROR_QUE_MEMORY_ERROR);
  1425.     case syserr_que_prev_at_end:    return (ERROR_QUE_PREV_AT_END);
  1426.     case syserr_que_proc_no_access:    return (ERROR_QUE_PROC_NO_ACCESS);
  1427.     case syserr_que_empty:    return (ERROR_QUE_EMPTY);
  1428.     case syserr_que_name_not_exist:    return (ERROR_QUE_NAME_NOT_EXIST);
  1429.     case syserr_que_not_initialized:    return (ERROR_QUE_NOT_INITIALIZED);
  1430.     case syserr_que_unable_to_access:    return (ERROR_QUE_UNABLE_TO_ACCESS);
  1431.     case syserr_que_unable_to_add:    return (ERROR_QUE_UNABLE_TO_ADD);
  1432.     case syserr_que_unable_to_init:    return (ERROR_QUE_UNABLE_TO_INIT);
  1433.     case syserr_vio_invalid_mask:    return (ERROR_VIO_INVALID_MASK);
  1434.     case syserr_vio_ptr:    return (ERROR_VIO_PTR);
  1435.     case syserr_vio_aptr:    return (ERROR_VIO_APTR);
  1436.     case syserr_vio_rptr:    return (ERROR_VIO_RPTR);
  1437.     case syserr_vio_cptr:    return (ERROR_VIO_CPTR);
  1438.     case syserr_vio_lptr:    return (ERROR_VIO_LPTR);
  1439.     case syserr_vio_mode:    return (ERROR_VIO_MODE);
  1440.     case syserr_vio_width:    return (ERROR_VIO_WIDTH);
  1441.     case syserr_vio_attr:    return (ERROR_VIO_ATTR);
  1442.     case syserr_vio_row:    return (ERROR_VIO_ROW);
  1443.     case syserr_vio_col:    return (ERROR_VIO_COL);
  1444.     case syserr_vio_toprow:    return (ERROR_VIO_TOPROW);
  1445.     case syserr_vio_botrow:    return (ERROR_VIO_BOTROW);
  1446.     case syserr_vio_rightcol:    return (ERROR_VIO_RIGHTCOL);
  1447.     case syserr_vio_leftcol:    return (ERROR_VIO_LEFTCOL);
  1448.     case syserr_scs_call:    return (ERROR_SCS_CALL);
  1449.     case syserr_scs_value:    return (ERROR_SCS_VALUE);
  1450.     case syserr_vio_wait_flag:    return (ERROR_VIO_WAIT_FLAG);
  1451.     case syserr_vio_unlock:    return (ERROR_VIO_UNLOCK);
  1452.     case syserr_sgs_not_session_mgr:    return (ERROR_SGS_NOT_SESSION_MGR);
  1453.     case syserr_smg_invalid_session_id:    return (ERROR_SMG_INVALID_SESSION_ID);
  1454.     case syserr_smg_no_sessions:    return (ERROR_SMG_NO_SESSIONS);
  1455.     case syserr_smg_session_not_found:    return (ERROR_SMG_SESSION_NOT_FOUND);
  1456.     case syserr_smg_set_title:    return (ERROR_SMG_SET_TITLE);
  1457.     case syserr_kbd_parameter:    return (ERROR_KBD_PARAMETER);
  1458.     case syserr_kbd_no_device:    return (ERROR_KBD_NO_DEVICE);
  1459.     case syserr_kbd_invalid_iowait:    return (ERROR_KBD_INVALID_IOWAIT);
  1460.     case syserr_kbd_invalid_length:    return (ERROR_KBD_INVALID_LENGTH);
  1461.     case syserr_kbd_invalid_echo_mask:    return (ERROR_KBD_INVALID_ECHO_MASK);
  1462.     case syserr_kbd_invalid_input_mask:    return (ERROR_KBD_INVALID_INPUT_MASK);
  1463.     case syserr_mon_invalid_parms:    return (ERROR_MON_INVALID_PARMS);
  1464.     case syserr_mon_invalid_devname:    return (ERROR_MON_INVALID_DEVNAME);
  1465.     case syserr_mon_invalid_handle:    return (ERROR_MON_INVALID_HANDLE);
  1466.     case syserr_mon_buffer_too_small:    return (ERROR_MON_BUFFER_TOO_SMALL);
  1467.     case syserr_mon_buffer_empty:    return (ERROR_MON_BUFFER_EMPTY);
  1468.     case syserr_mon_data_too_large:    return (ERROR_MON_DATA_TOO_LARGE);
  1469.     case syserr_mouse_no_device:    return (ERROR_MOUSE_NO_DEVICE);
  1470.     case syserr_mouse_inv_handle:    return (ERROR_MOUSE_INV_HANDLE);
  1471.     case syserr_mouse_inv_parms:    return (ERROR_MOUSE_INV_PARMS);
  1472.     case syserr_mouse_cant_reset:    return (ERROR_MOUSE_CANT_RESET);
  1473.     case syserr_mouse_display_parms:    return (ERROR_MOUSE_DISPLAY_PARMS);
  1474.     case syserr_mouse_inv_module:    return (ERROR_MOUSE_INV_MODULE);
  1475.     case syserr_mouse_inv_entry_pt:    return (ERROR_MOUSE_INV_ENTRY_PT);
  1476.     case syserr_mouse_inv_mask:    return (ERROR_MOUSE_INV_MASK);
  1477.     case syserr_mouse_no_data:    return (NO_ERROR_MOUSE_NO_DATA);
  1478.     case syserr_mouse_ptr_drawn:    return (NO_ERROR_MOUSE_PTR_DRAWN);
  1479.     case syserr_invalid_frequency:    return (ERROR_INVALID_FREQUENCY);
  1480.     case syserr_nls_no_country_file:    return (ERROR_NLS_NO_COUNTRY_FILE);
  1481.     case syserr_nls_open_failed:    return (ERROR_NLS_OPEN_FAILED);
  1482. #ifdef ERROR_NO_COUNTRY_OR_CODEPAGE
  1483.     case syserr_no_country_or_codepage:    return (ERROR_NO_COUNTRY_OR_CODEPAGE);
  1484. #endif
  1485.     case syserr_nls_table_truncated:    return (ERROR_NLS_TABLE_TRUNCATED);
  1486.     case syserr_nls_bad_type:    return (ERROR_NLS_BAD_TYPE);
  1487.     case syserr_nls_type_not_found:    return (ERROR_NLS_TYPE_NOT_FOUND);
  1488.     case syserr_vio_smg_only:    return (ERROR_VIO_SMG_ONLY);
  1489.     case syserr_vio_invalid_asciiz:    return (ERROR_VIO_INVALID_ASCIIZ);
  1490.     case syserr_vio_deregister:    return (ERROR_VIO_DEREGISTER);
  1491.     case syserr_vio_no_popup:    return (ERROR_VIO_NO_POPUP);
  1492.     case syserr_vio_existing_popup:    return (ERROR_VIO_EXISTING_POPUP);
  1493.     case syserr_kbd_smg_only:    return (ERROR_KBD_SMG_ONLY);
  1494.     case syserr_kbd_invalid_asciiz:    return (ERROR_KBD_INVALID_ASCIIZ);
  1495.     case syserr_kbd_invalid_mask:    return (ERROR_KBD_INVALID_MASK);
  1496.     case syserr_kbd_register:    return (ERROR_KBD_REGISTER);
  1497.     case syserr_kbd_deregister:    return (ERROR_KBD_DEREGISTER);
  1498.     case syserr_mouse_smg_only:    return (ERROR_MOUSE_SMG_ONLY);
  1499.     case syserr_mouse_invalid_asciiz:    return (ERROR_MOUSE_INVALID_ASCIIZ);
  1500.     case syserr_mouse_invalid_mask:    return (ERROR_MOUSE_INVALID_MASK);
  1501.     case syserr_mouse_register:    return (ERROR_MOUSE_REGISTER);
  1502.     case syserr_mouse_deregister:    return (ERROR_MOUSE_DEREGISTER);
  1503.     case syserr_smg_bad_action:    return (ERROR_SMG_BAD_ACTION);
  1504.     case syserr_smg_invalid_call:    return (ERROR_SMG_INVALID_CALL);
  1505.     case syserr_scs_sg_notfound:    return (ERROR_SCS_SG_NOTFOUND);
  1506.     case syserr_scs_not_shell:    return (ERROR_SCS_NOT_SHELL);
  1507.     case syserr_vio_invalid_parms:    return (ERROR_VIO_INVALID_PARMS);
  1508.     case syserr_vio_function_owned:    return (ERROR_VIO_FUNCTION_OWNED);
  1509.     case syserr_vio_return:    return (ERROR_VIO_RETURN);
  1510.     case syserr_scs_invalid_function:    return (ERROR_SCS_INVALID_FUNCTION);
  1511.     case syserr_scs_not_session_mgr:    return (ERROR_SCS_NOT_SESSION_MGR);
  1512.     case syserr_vio_register:    return (ERROR_VIO_REGISTER);
  1513.     case syserr_vio_no_mode_thread:    return (ERROR_VIO_NO_MODE_THREAD);
  1514.     case syserr_vio_no_save_restore_thd:    return (ERROR_VIO_NO_SAVE_RESTORE_THD);
  1515.     case syserr_vio_in_bg:    return (ERROR_VIO_IN_BG);
  1516.     case syserr_vio_illegal_during_popup:    return (ERROR_VIO_ILLEGAL_DURING_POPUP);
  1517.     case syserr_smg_not_baseshell:    return (ERROR_SMG_NOT_BASESHELL);
  1518.     case syserr_smg_bad_statusreq:    return (ERROR_SMG_BAD_STATUSREQ);
  1519.     case syserr_que_invalid_wait:    return (ERROR_QUE_INVALID_WAIT);
  1520.     case syserr_vio_lock:    return (ERROR_VIO_LOCK);
  1521.     case syserr_mouse_invalid_iowait:    return (ERROR_MOUSE_INVALID_IOWAIT);
  1522.     case syserr_vio_invalid_handle:    return (ERROR_VIO_INVALID_HANDLE);
  1523.     case syserr_vio_illegal_during_lock:    return (ERROR_VIO_ILLEGAL_DURING_LOCK);
  1524.     case syserr_vio_invalid_length:    return (ERROR_VIO_INVALID_LENGTH);
  1525.     case syserr_kbd_invalid_handle:    return (ERROR_KBD_INVALID_HANDLE);
  1526.     case syserr_kbd_no_more_handle:    return (ERROR_KBD_NO_MORE_HANDLE);
  1527.     case syserr_kbd_cannot_create_kcb:    return (ERROR_KBD_CANNOT_CREATE_KCB);
  1528.     case syserr_kbd_codepage_load_incompl:    return (ERROR_KBD_CODEPAGE_LOAD_INCOMPL);
  1529.     case syserr_kbd_invalid_codepage_id:    return (ERROR_KBD_INVALID_CODEPAGE_ID);
  1530.     case syserr_kbd_no_codepage_support:    return (ERROR_KBD_NO_CODEPAGE_SUPPORT);
  1531.     case syserr_kbd_focus_required:    return (ERROR_KBD_FOCUS_REQUIRED);
  1532.     case syserr_kbd_focus_already_active:    return (ERROR_KBD_FOCUS_ALREADY_ACTIVE);
  1533.     case syserr_kbd_keyboard_busy:    return (ERROR_KBD_KEYBOARD_BUSY);
  1534.     case syserr_kbd_invalid_codepage:    return (ERROR_KBD_INVALID_CODEPAGE);
  1535.     case syserr_kbd_unable_to_focus:    return (ERROR_KBD_UNABLE_TO_FOCUS);
  1536.     case syserr_smg_session_non_select:    return (ERROR_SMG_SESSION_NON_SELECT);
  1537.     case syserr_smg_session_not_foregrnd:    return (ERROR_SMG_SESSION_NOT_FOREGRND);
  1538.     case syserr_smg_session_not_parent:    return (ERROR_SMG_SESSION_NOT_PARENT);
  1539.     case syserr_smg_invalid_start_mode:    return (ERROR_SMG_INVALID_START_MODE);
  1540.     case syserr_smg_invalid_related_opt:    return (ERROR_SMG_INVALID_RELATED_OPT);
  1541.     case syserr_smg_invalid_bond_option:    return (ERROR_SMG_INVALID_BOND_OPTION);
  1542.     case syserr_smg_invalid_select_opt:    return (ERROR_SMG_INVALID_SELECT_OPT);
  1543.     case syserr_smg_start_in_background:    return (ERROR_SMG_START_IN_BACKGROUND);
  1544.     case syserr_smg_invalid_stop_option:    return (ERROR_SMG_INVALID_STOP_OPTION);
  1545.     case syserr_smg_bad_reserve:    return (ERROR_SMG_BAD_RESERVE);
  1546.     case syserr_smg_process_not_parent:    return (ERROR_SMG_PROCESS_NOT_PARENT);
  1547.     case syserr_smg_invalid_data_length:    return (ERROR_SMG_INVALID_DATA_LENGTH);
  1548.     case syserr_smg_not_bound:    return (ERROR_SMG_NOT_BOUND);
  1549.     case syserr_smg_retry_sub_alloc:    return (ERROR_SMG_RETRY_SUB_ALLOC);
  1550.     case syserr_kbd_detached:    return (ERROR_KBD_DETACHED);
  1551.     case syserr_vio_detached:    return (ERROR_VIO_DETACHED);
  1552.     case syserr_mou_detached:    return (ERROR_MOU_DETACHED);
  1553.     case syserr_vio_font:    return (ERROR_VIO_FONT);
  1554.     case syserr_vio_user_font:    return (ERROR_VIO_USER_FONT);
  1555.     case syserr_vio_bad_cp:    return (ERROR_VIO_BAD_CP);
  1556.     case syserr_vio_no_cp:    return (ERROR_VIO_NO_CP);
  1557.     case syserr_vio_na_cp:    return (ERROR_VIO_NA_CP);
  1558.     case syserr_invalid_code_page:    return (ERROR_INVALID_CODE_PAGE);
  1559.     case syserr_cplist_too_small:    return (ERROR_CPLIST_TOO_SMALL);
  1560.     case syserr_cp_not_moved:    return (ERROR_CP_NOT_MOVED);
  1561.     case syserr_mode_switch_init:    return (ERROR_MODE_SWITCH_INIT);
  1562.     case syserr_code_page_not_found:    return (ERROR_CODE_PAGE_NOT_FOUND);
  1563.     case syserr_unexpected_slot_returned:    return (ERROR_UNEXPECTED_SLOT_RETURNED);
  1564.     case syserr_smg_invalid_trace_option:    return (ERROR_SMG_INVALID_TRACE_OPTION);
  1565.     case syserr_vio_internal_resource:    return (ERROR_VIO_INTERNAL_RESOURCE);
  1566.     case syserr_vio_shell_init:    return (ERROR_VIO_SHELL_INIT);
  1567.     case syserr_smg_no_hard_errors:    return (ERROR_SMG_NO_HARD_ERRORS);
  1568.     case syserr_cp_switch_incomplete:    return (ERROR_CP_SWITCH_INCOMPLETE);
  1569.     case syserr_vio_transparent_popup:    return (ERROR_VIO_TRANSPARENT_POPUP);
  1570.     case syserr_critsec_overflow:    return (ERROR_CRITSEC_OVERFLOW);
  1571.     case syserr_critsec_underflow:    return (ERROR_CRITSEC_UNDERFLOW);
  1572.     case syserr_vio_bad_reserve:    return (ERROR_VIO_BAD_RESERVE);
  1573.     case syserr_invalid_address:    return (ERROR_INVALID_ADDRESS);
  1574.     case syserr_zero_selectors_requested:    return (ERROR_ZERO_SELECTORS_REQUESTED);
  1575.     case syserr_not_enough_selectors_ava:    return (ERROR_NOT_ENOUGH_SELECTORS_AVA);
  1576.     case syserr_invalid_selector:    return (ERROR_INVALID_SELECTOR);
  1577.     case syserr_smg_invalid_program_type:    return (ERROR_SMG_INVALID_PROGRAM_TYPE);
  1578.     case syserr_smg_invalid_pgm_control:    return (ERROR_SMG_INVALID_PGM_CONTROL);
  1579.     case syserr_smg_invalid_inherit_opt:    return (ERROR_SMG_INVALID_INHERIT_OPT);
  1580.     case syserr_vio_extended_sg:    return (ERROR_VIO_EXTENDED_SG);
  1581.     case syserr_vio_not_pres_mgr_sg:    return (ERROR_VIO_NOT_PRES_MGR_SG);
  1582.     case syserr_vio_shield_owned:    return (ERROR_VIO_SHIELD_OWNED);
  1583.     case syserr_vio_no_more_handles:    return (ERROR_VIO_NO_MORE_HANDLES);
  1584.     case syserr_vio_see_error_log:    return (ERROR_VIO_SEE_ERROR_LOG);
  1585.     case syserr_vio_associated_dc:    return (ERROR_VIO_ASSOCIATED_DC);
  1586.     case syserr_kbd_no_console:    return (ERROR_KBD_NO_CONSOLE);
  1587.     case syserr_mouse_no_console:    return (ERROR_MOUSE_NO_CONSOLE);
  1588.     case syserr_mouse_invalid_handle:    return (ERROR_MOUSE_INVALID_HANDLE);
  1589.     case syserr_smg_invalid_debug_parms:    return (ERROR_SMG_INVALID_DEBUG_PARMS);
  1590.     case syserr_kbd_extended_sg:    return (ERROR_KBD_EXTENDED_SG);
  1591.     case syserr_mou_extended_sg:    return (ERROR_MOU_EXTENDED_SG);
  1592.     case syserr_smg_invalid_icon_file:    return (ERROR_SMG_INVALID_ICON_FILE);
  1593.     case syserr_trc_pid_non_existent:    return (ERROR_TRC_PID_NON_EXISTENT);
  1594.     case syserr_trc_count_active:    return (ERROR_TRC_COUNT_ACTIVE);
  1595.     case syserr_trc_suspended_by_count:    return (ERROR_TRC_SUSPENDED_BY_COUNT);
  1596.     case syserr_trc_count_inactive:    return (ERROR_TRC_COUNT_INACTIVE);
  1597.     case syserr_trc_count_reached:    return (ERROR_TRC_COUNT_REACHED);
  1598.     case syserr_no_mc_trace:    return (ERROR_NO_MC_TRACE);
  1599.     case syserr_mc_trace:    return (ERROR_MC_TRACE);
  1600.     case syserr_trc_count_zero:    return (ERROR_TRC_COUNT_ZERO);
  1601.     case syserr_smg_too_many_dds:    return (ERROR_SMG_TOO_MANY_DDS);
  1602.     case syserr_smg_invalid_notification:    return (ERROR_SMG_INVALID_NOTIFICATION);
  1603.     case syserr_lf_invalid_function:    return (ERROR_LF_INVALID_FUNCTION);
  1604.     case syserr_lf_not_avail:    return (ERROR_LF_NOT_AVAIL);
  1605.     case syserr_lf_suspended:    return (ERROR_LF_SUSPENDED);
  1606.     case syserr_lf_buf_too_small:    return (ERROR_LF_BUF_TOO_SMALL);
  1607.     case syserr_lf_buffer_full:    return (ERROR_LF_BUFFER_FULL);
  1608.     case syserr_lf_invalid_record:    return (ERROR_LF_INVALID_RECORD);
  1609.     case syserr_lf_invalid_service:    return (ERROR_LF_INVALID_SERVICE);
  1610.     case syserr_lf_general_failure:    return (ERROR_LF_GENERAL_FAILURE);
  1611.     case syserr_lf_invalid_id:    return (ERROR_LF_INVALID_ID);
  1612.     case syserr_lf_invalid_handle:    return (ERROR_LF_INVALID_HANDLE);
  1613.     case syserr_lf_no_id_avail:    return (ERROR_LF_NO_ID_AVAIL);
  1614.     case syserr_lf_template_area_full:    return (ERROR_LF_TEMPLATE_AREA_FULL);
  1615.     case syserr_lf_id_in_use:    return (ERROR_LF_ID_IN_USE);
  1616.     case syserr_mou_not_initialized:    return (ERROR_MOU_NOT_INITIALIZED);
  1617.     case syserr_mouinitreal_done:    return (ERROR_MOUINITREAL_DONE);
  1618.     case syserr_dossub_corrupted:    return (ERROR_DOSSUB_CORRUPTED);
  1619.     case syserr_mouse_caller_not_subsys:    return (ERROR_MOUSE_CALLER_NOT_SUBSYS);
  1620.     case syserr_arithmetic_overflow:    return (ERROR_ARITHMETIC_OVERFLOW);
  1621.     case syserr_tmr_no_device:    return (ERROR_TMR_NO_DEVICE);
  1622.     case syserr_tmr_invalid_time:    return (ERROR_TMR_INVALID_TIME);
  1623.     case syserr_pvw_invalid_entity:    return (ERROR_PVW_INVALID_ENTITY);
  1624.     case syserr_pvw_invalid_entity_type:    return (ERROR_PVW_INVALID_ENTITY_TYPE);
  1625.     case syserr_pvw_invalid_spec:    return (ERROR_PVW_INVALID_SPEC);
  1626.     case syserr_pvw_invalid_range_type:    return (ERROR_PVW_INVALID_RANGE_TYPE);
  1627.     case syserr_pvw_invalid_counter_blk:    return (ERROR_PVW_INVALID_COUNTER_BLK);
  1628.     case syserr_pvw_invalid_text_blk:    return (ERROR_PVW_INVALID_TEXT_BLK);
  1629.     case syserr_prf_not_initialized:    return (ERROR_PRF_NOT_INITIALIZED);
  1630.     case syserr_prf_already_initialized:    return (ERROR_PRF_ALREADY_INITIALIZED);
  1631.     case syserr_prf_not_started:    return (ERROR_PRF_NOT_STARTED);
  1632.     case syserr_prf_already_started:    return (ERROR_PRF_ALREADY_STARTED);
  1633.     case syserr_prf_timer_out_of_range:    return (ERROR_PRF_TIMER_OUT_OF_RANGE);
  1634.     case syserr_prf_timer_reset:    return (ERROR_PRF_TIMER_RESET);
  1635.     case syserr_vdd_lock_useage_denied:    return (ERROR_VDD_LOCK_USEAGE_DENIED);
  1636.     case syserr_timeout:    return (ERROR_TIMEOUT);
  1637.     case syserr_vdm_down:    return (ERROR_VDM_DOWN);
  1638.     case syserr_vdm_limit:    return (ERROR_VDM_LIMIT);
  1639.     case syserr_vdd_not_found:    return (ERROR_VDD_NOT_FOUND);
  1640.     case syserr_invalid_caller:    return (ERROR_INVALID_CALLER);
  1641.     case syserr_pid_mismatch:    return (ERROR_PID_MISMATCH);
  1642.     case syserr_invalid_vdd_handle:    return (ERROR_INVALID_VDD_HANDLE);
  1643.     case syserr_vlpt_no_spooler:    return (ERROR_VLPT_NO_SPOOLER);
  1644.     case syserr_vcom_device_busy:    return (ERROR_VCOM_DEVICE_BUSY);
  1645.     case syserr_vlpt_device_busy:    return (ERROR_VLPT_DEVICE_BUSY);
  1646.     case syserr_nesting_too_deep:    return (ERROR_NESTING_TOO_DEEP);
  1647.     case syserr_vdd_missing:    return (ERROR_VDD_MISSING);
  1648.     case syserr_bidi_invalid_length:    return (ERROR_BIDI_INVALID_LENGTH);
  1649.     case syserr_bidi_invalid_increment:    return (ERROR_BIDI_INVALID_INCREMENT);
  1650.     case syserr_bidi_invalid_combination:    return (ERROR_BIDI_INVALID_COMBINATION);
  1651.     case syserr_bidi_invalid_reserved:    return (ERROR_BIDI_INVALID_RESERVED);
  1652.     case syserr_bidi_invalid_effect:    return (ERROR_BIDI_INVALID_EFFECT);
  1653.     case syserr_bidi_invalid_csdrec:    return (ERROR_BIDI_INVALID_CSDREC);
  1654.     case syserr_bidi_invalid_csdstate:    return (ERROR_BIDI_INVALID_CSDSTATE);
  1655.     case syserr_bidi_invalid_level:    return (ERROR_BIDI_INVALID_LEVEL);
  1656.     case syserr_bidi_invalid_type_support:    return (ERROR_BIDI_INVALID_TYPE_SUPPORT);
  1657.     case syserr_bidi_invalid_orientation:    return (ERROR_BIDI_INVALID_ORIENTATION);
  1658.     case syserr_bidi_invalid_num_shape:    return (ERROR_BIDI_INVALID_NUM_SHAPE);
  1659.     case syserr_bidi_invalid_csd:    return (ERROR_BIDI_INVALID_CSD);
  1660.     case syserr_bidi_no_support:    return (ERROR_BIDI_NO_SUPPORT);
  1661.     case syserr_bidi_rw_incomplete:    return (NO_ERROR_BIDI_RW_INCOMPLETE);
  1662.     case syserr_imp_invalid_parm:    return (ERROR_IMP_INVALID_PARM);
  1663.     case syserr_imp_invalid_length:    return (ERROR_IMP_INVALID_LENGTH);
  1664. #ifdef MSG_HPFS_DISK_ERROR_WARN
  1665.     case syserr_hpfs_disk_error_warn:    return (MSG_HPFS_DISK_ERROR_WARN);
  1666. #endif
  1667.     case syserr_mon_bad_buffer:    return (ERROR_MON_BAD_BUFFER);
  1668.     case syserr_module_corrupted:    return (ERROR_MODULE_CORRUPTED);
  1669.     case syserr_sm_outof_swapfile:    return (ERROR_SM_OUTOF_SWAPFILE);
  1670.     case syserr_lf_timeout:    return (ERROR_LF_TIMEOUT);
  1671.     case syserr_lf_suspend_success:    return (ERROR_LF_SUSPEND_SUCCESS);
  1672.     case syserr_lf_resume_success:    return (ERROR_LF_RESUME_SUCCESS);
  1673.     case syserr_lf_redirect_success:    return (ERROR_LF_REDIRECT_SUCCESS);
  1674.     case syserr_lf_redirect_failure:    return (ERROR_LF_REDIRECT_FAILURE);
  1675.     case syserr_swapper_not_active:    return (ERROR_SWAPPER_NOT_ACTIVE);
  1676.     case syserr_invalid_swapid:    return (ERROR_INVALID_SWAPID);
  1677.     case syserr_ioerr_swap_file:    return (ERROR_IOERR_SWAP_FILE);
  1678.     case syserr_swap_table_full:    return (ERROR_SWAP_TABLE_FULL);
  1679.     case syserr_swap_file_full:    return (ERROR_SWAP_FILE_FULL);
  1680.     case syserr_cant_init_swapper:    return (ERROR_CANT_INIT_SWAPPER);
  1681.     case syserr_swapper_already_init:    return (ERROR_SWAPPER_ALREADY_INIT);
  1682.     case syserr_pmm_insufficient_memory:    return (ERROR_PMM_INSUFFICIENT_MEMORY);
  1683.     case syserr_pmm_invalid_flags:    return (ERROR_PMM_INVALID_FLAGS);
  1684.     case syserr_pmm_invalid_address:    return (ERROR_PMM_INVALID_ADDRESS);
  1685.     case syserr_pmm_lock_failed:    return (ERROR_PMM_LOCK_FAILED);
  1686.     case syserr_pmm_unlock_failed:    return (ERROR_PMM_UNLOCK_FAILED);
  1687.     case syserr_pmm_move_incomplete:    return (ERROR_PMM_MOVE_INCOMPLETE);
  1688.     case syserr_ucom_drive_renamed:    return (ERROR_UCOM_DRIVE_RENAMED);
  1689.     case syserr_ucom_filename_truncated:    return (ERROR_UCOM_FILENAME_TRUNCATED);
  1690.     case syserr_ucom_buffer_length:    return (ERROR_UCOM_BUFFER_LENGTH);
  1691.     case syserr_mon_chain_handle:    return (ERROR_MON_CHAIN_HANDLE);
  1692.     case syserr_mon_not_registered:    return (ERROR_MON_NOT_REGISTERED);
  1693.     case syserr_smg_already_top:    return (ERROR_SMG_ALREADY_TOP);
  1694.     case syserr_pmm_arena_modified:    return (ERROR_PMM_ARENA_MODIFIED);
  1695.     case syserr_smg_printer_open:    return (ERROR_SMG_PRINTER_OPEN);
  1696.     case syserr_pmm_set_flags_failed:    return (ERROR_PMM_SET_FLAGS_FAILED);
  1697.     case syserr_invalid_dos_dd:    return (ERROR_INVALID_DOS_DD);
  1698.     case syserr_blocked:    return (ERROR_BLOCKED);
  1699.     case syserr_noblock:    return (ERROR_NOBLOCK);
  1700.     case syserr_instance_shared:    return (ERROR_INSTANCE_SHARED);
  1701.     case syserr_no_object:    return (ERROR_NO_OBJECT);
  1702.     case syserr_partial_attach:    return (ERROR_PARTIAL_ATTACH);
  1703.     case syserr_incache:    return (ERROR_INCACHE);
  1704.     case syserr_swap_io_problems:    return (ERROR_SWAP_IO_PROBLEMS);
  1705.     case syserr_crosses_object_boundary:    return (ERROR_CROSSES_OBJECT_BOUNDARY);
  1706.     case syserr_longlock:    return (ERROR_LONGLOCK);
  1707.     case syserr_shortlock:    return (ERROR_SHORTLOCK);
  1708.     case syserr_uvirtlock:    return (ERROR_UVIRTLOCK);
  1709.     case syserr_aliaslock:    return (ERROR_ALIASLOCK);
  1710.     case syserr_alias:    return (ERROR_ALIAS);
  1711.     case syserr_no_more_handles:    return (ERROR_NO_MORE_HANDLES);
  1712.     case syserr_scan_terminated:    return (ERROR_SCAN_TERMINATED);
  1713.     case syserr_terminator_not_found:    return (ERROR_TERMINATOR_NOT_FOUND);
  1714.     case syserr_not_direct_child:    return (ERROR_NOT_DIRECT_CHILD);
  1715.     case syserr_delay_free:    return (ERROR_DELAY_FREE);
  1716.     case syserr_guardpage:    return (ERROR_GUARDPAGE);
  1717.     case syserr_swaperror:    return (ERROR_SWAPERROR);
  1718.     case syserr_ldrerror:    return (ERROR_LDRERROR);
  1719.     case syserr_nomemory:    return (ERROR_NOMEMORY);
  1720.     case syserr_noaccess:    return (ERROR_NOACCESS);
  1721.     case syserr_no_dll_term:    return (ERROR_NO_DLL_TERM);
  1722.     case syserr_cpsio_code_page_invalid:    return (ERROR_CPSIO_CODE_PAGE_INVALID);
  1723.     case syserr_cpsio_no_spooler:    return (ERROR_CPSIO_NO_SPOOLER);
  1724.     case syserr_cpsio_font_id_invalid:    return (ERROR_CPSIO_FONT_ID_INVALID);
  1725.     case syserr_cpsio_internal_error:    return (ERROR_CPSIO_INTERNAL_ERROR);
  1726.     case syserr_cpsio_invalid_ptr_name:    return (ERROR_CPSIO_INVALID_PTR_NAME);
  1727.     case syserr_cpsio_not_active:    return (ERROR_CPSIO_NOT_ACTIVE);
  1728.     case syserr_cpsio_pid_full:    return (ERROR_CPSIO_PID_FULL);
  1729.     case syserr_cpsio_pid_not_found:    return (ERROR_CPSIO_PID_NOT_FOUND);
  1730.     case syserr_cpsio_read_ctl_seq:    return (ERROR_CPSIO_READ_CTL_SEQ);
  1731.     case syserr_cpsio_read_fnt_def:    return (ERROR_CPSIO_READ_FNT_DEF);
  1732.     case syserr_cpsio_write_error:    return (ERROR_CPSIO_WRITE_ERROR);
  1733.     case syserr_cpsio_write_full_error:    return (ERROR_CPSIO_WRITE_FULL_ERROR);
  1734.     case syserr_cpsio_write_handle_bad:    return (ERROR_CPSIO_WRITE_HANDLE_BAD);
  1735.     case syserr_cpsio_swit_load:    return (ERROR_CPSIO_SWIT_LOAD);
  1736.     case syserr_cpsio_inv_command:    return (ERROR_CPSIO_INV_COMMAND);
  1737.     case syserr_cpsio_no_font_swit:    return (ERROR_CPSIO_NO_FONT_SWIT);
  1738.     case syserr_entry_is_callgate:    return (ERROR_ENTRY_IS_CALLGATE);
  1739.  
  1740. #ifndef DISABLE_SOCKET_SUPPORT
  1741.     case syserr_socket_perm:        return (SOCEPERM);
  1742.     case syserr_socket_srch:        return (SOCESRCH);
  1743.     case syserr_socket_intr:        return (SOCEINTR);
  1744.     case syserr_socket_nxio:        return (SOCENXIO);
  1745.     case syserr_socket_badf:        return (SOCEBADF);
  1746.     case syserr_socket_acces:        return (SOCEACCES);
  1747.     case syserr_socket_fault:        return (SOCEFAULT);
  1748.     case syserr_socket_inval:        return (SOCEINVAL);
  1749.     case syserr_socket_mfile:        return (SOCEMFILE);
  1750.     case syserr_socket_pipe:        return (SOCEPIPE);
  1751.     case syserr_socket_os2err:        return (SOCEOS2ERR);
  1752.     case syserr_socket_wouldblock:    return (SOCEWOULDBLOCK);
  1753.     case syserr_socket_inprogress:    return (SOCEINPROGRESS);
  1754.     case syserr_socket_already:        return (SOCEALREADY);
  1755.     case syserr_socket_notsock:        return (SOCENOTSOCK);
  1756.     case syserr_socket_destaddrreq:    return (SOCEDESTADDRREQ);
  1757.     case syserr_socket_msgsize:        return (SOCEMSGSIZE);
  1758.     case syserr_socket_prototype:    return (SOCEPROTOTYPE);
  1759.     case syserr_socket_noprotoopt:    return (SOCENOPROTOOPT);
  1760.     case syserr_socket_protonosupport:    return (SOCEPROTONOSUPPORT);
  1761.     case syserr_socket_socktnosupport:    return (SOCESOCKTNOSUPPORT);
  1762.     case syserr_socket_opnotsupp:    return (SOCEOPNOTSUPP);
  1763.     case syserr_socket_pfnosupport:    return (SOCEPFNOSUPPORT);
  1764.     case syserr_socket_afnosupport:    return (SOCEAFNOSUPPORT);
  1765.     case syserr_socket_addrinuse:    return (SOCEADDRINUSE);
  1766.     case syserr_socket_addrnotavail:    return (SOCEADDRNOTAVAIL);
  1767.     case syserr_socket_netdown:        return (SOCENETDOWN);
  1768.     case syserr_socket_netunreach:    return (SOCENETUNREACH);
  1769.     case syserr_socket_netreset:    return (SOCENETRESET);
  1770.     case syserr_socket_connaborted:    return (SOCECONNABORTED);
  1771.     case syserr_socket_connreset:    return (SOCECONNRESET);
  1772.     case syserr_socket_nobufs:        return (SOCENOBUFS);
  1773.     case syserr_socket_isconn:        return (SOCEISCONN);
  1774.     case syserr_socket_notconn:        return (SOCENOTCONN);
  1775.     case syserr_socket_shutdown:    return (SOCESHUTDOWN);
  1776.     case syserr_socket_toomanyrefs:    return (SOCETOOMANYREFS);
  1777.     case syserr_socket_timedout:    return (SOCETIMEDOUT);
  1778.     case syserr_socket_connrefused:    return (SOCECONNREFUSED);
  1779.     case syserr_socket_loop:        return (SOCELOOP);
  1780.     case syserr_socket_nametoolong:    return (SOCENAMETOOLONG);
  1781.     case syserr_socket_hostdown:    return (SOCEHOSTDOWN);
  1782.     case syserr_socket_hostunreach:    return (SOCEHOSTUNREACH);
  1783.     case syserr_socket_notempty:    return (SOCENOTEMPTY);
  1784. #endif /* not DISABLE_SOCKET_SUPPORT */
  1785.  
  1786.     default:    return (NO_ERROR);
  1787.     }
  1788. }
  1789.  
  1790. #ifdef __GCC2__
  1791. /* Grumble... stupid linking bug.  */
  1792. #define dos_error_message(rc) 0
  1793. #else /* not __GCC2__ */
  1794.  
  1795. static const char *
  1796. dos_error_message (APIRET rc)
  1797. {
  1798.   unsigned int blength_increment = 64;
  1799.   unsigned int blength = blength_increment;
  1800.   char * buffer = (OS2_malloc_noerror (blength));
  1801.   ULONG mlength;
  1802.  
  1803.   if (buffer == 0)
  1804.     return (0);
  1805.   while (1)
  1806.     {
  1807.       if ((dos_get_message
  1808.        (0, 0, buffer, blength, rc, "OSO001.MSG", (&mlength)))
  1809.       != NO_ERROR)
  1810.     {
  1811.       OS_free (buffer);
  1812.       return (0);
  1813.     }
  1814.       if (mlength < blength)
  1815.     {
  1816.       while ((mlength > 0) && (isspace (buffer [mlength - 1])))
  1817.         mlength -= 1;
  1818.       buffer = (OS2_realloc_noerror (buffer, (mlength + 1)));
  1819.       if (buffer != 0)
  1820.         (buffer[mlength]) = '\0';
  1821.       return (buffer);
  1822.     }
  1823.       blength += blength_increment;
  1824.       buffer = (OS2_realloc_noerror (buffer, (blength)));
  1825.       if (buffer == 0)
  1826.     return (0);
  1827.     }
  1828. }
  1829.  
  1830. #endif /* not __GCC2__ */
  1831.  
  1832. const char *
  1833. OS_error_code_to_message (unsigned int syserr)
  1834. {
  1835.   static const char * last_message = 0;
  1836.   APIRET code = (syserr_to_error_code ((enum syserr_names) syserr));
  1837.   if (code == NO_ERROR)
  1838.     return (0);
  1839.   if (last_message != 0)
  1840.     OS_free ((void *) last_message);
  1841.   last_message = (dos_error_message (code));
  1842.   /* Many of OS/2's error messages are terminated with a period, but
  1843.      the runtime system is assuming that the messages have no period,
  1844.      and adding its own.  */
  1845.   if (last_message != 0)
  1846.     {
  1847.       unsigned int length = (strlen (last_message));
  1848.       if ((length > 0) && ((last_message [length - 1]) == '.'))
  1849.     (((char *) last_message) [length - 1]) = '\0';
  1850.     }
  1851.   return (last_message);
  1852. }
  1853.  
  1854. /* Machine-generated table, do not edit: */
  1855. static char * syserr_names_table [] =
  1856. {
  1857.   "invalid-function",
  1858.   "file-not-found",
  1859.   "path-not-found",
  1860.   "too-many-open-files",
  1861.   "access-denied",
  1862.   "invalid-handle",
  1863.   "arena-trashed",
  1864.   "not-enough-memory",
  1865.   "invalid-block",
  1866.   "bad-environment",
  1867.   "bad-format",
  1868.   "invalid-access",
  1869.   "invalid-data",
  1870.   "invalid-drive",
  1871.   "current-directory",
  1872.   "not-same-device",
  1873.   "no-more-files",
  1874.   "write-protect",
  1875.   "bad-unit",
  1876.   "not-ready",
  1877.   "bad-command",
  1878.   "crc",
  1879.   "bad-length",
  1880.   "seek",
  1881.   "not-dos-disk",
  1882.   "sector-not-found",
  1883.   "out-of-paper",
  1884.   "write-fault",
  1885.   "read-fault",
  1886.   "gen-failure",
  1887.   "sharing-violation",
  1888.   "lock-violation",
  1889.   "wrong-disk",
  1890.   "fcb-unavailable",
  1891.   "sharing-buffer-exceeded",
  1892.   "code-page-mismatched",
  1893.   "handle-eof",
  1894.   "handle-disk-full",
  1895.   "not-supported",
  1896.   "rem-not-list",
  1897.   "dup-name",
  1898.   "bad-netpath",
  1899.   "network-busy",
  1900.   "dev-not-exist",
  1901.   "too-many-cmds",
  1902.   "adap-hdw-err",
  1903.   "bad-net-resp",
  1904.   "unexp-net-err",
  1905.   "bad-rem-adap",
  1906.   "printq-full",
  1907.   "no-spool-space",
  1908.   "print-cancelled",
  1909.   "netname-deleted",
  1910.   "network-access-denied",
  1911.   "bad-dev-type",
  1912.   "bad-net-name",
  1913.   "too-many-names",
  1914.   "too-many-sess",
  1915.   "sharing-paused",
  1916.   "req-not-accep",
  1917.   "redir-paused",
  1918.   "sbcs-att-write-prot",
  1919.   "sbcs-general-failure",
  1920.   "xga-out-memory",
  1921.   "file-exists",
  1922.   "dup-fcb",
  1923.   "cannot-make",
  1924.   "fail-i24",
  1925.   "out-of-structures",
  1926.   "already-assigned",
  1927.   "invalid-password",
  1928.   "invalid-parameter",
  1929.   "net-write-fault",
  1930.   "no-proc-slots",
  1931.   "not-frozen",
  1932.   "tstovfl",
  1933.   "tstdup",
  1934.   "no-items",
  1935.   "interrupt",
  1936.   "device-in-use",
  1937.   "too-many-semaphores",
  1938.   "excl-sem-already-owned",
  1939.   "sem-is-set",
  1940.   "too-many-sem-requests",
  1941.   "invalid-at-interrupt-time",
  1942.   "sem-owner-died",
  1943.   "sem-user-limit",
  1944.   "disk-change",
  1945.   "drive-locked",
  1946.   "broken-pipe",
  1947.   "open-failed",
  1948.   "buffer-overflow",
  1949.   "disk-full",
  1950.   "no-more-search-handles",
  1951.   "invalid-target-handle",
  1952.   "protection-violation",
  1953.   "viokbd-request",
  1954.   "invalid-category",
  1955.   "invalid-verify-switch",
  1956.   "bad-driver-level",
  1957.   "call-not-implemented",
  1958.   "sem-timeout",
  1959.   "insufficient-buffer",
  1960.   "invalid-name",
  1961.   "invalid-level",
  1962.   "no-volume-label",
  1963.   "mod-not-found",
  1964.   "proc-not-found",
  1965.   "wait-no-children",
  1966.   "child-not-complete",
  1967.   "direct-access-handle",
  1968.   "negative-seek",
  1969.   "seek-on-device",
  1970.   "is-join-target",
  1971.   "is-joined",
  1972.   "is-substed",
  1973.   "not-joined",
  1974.   "not-substed",
  1975.   "join-to-join",
  1976.   "subst-to-subst",
  1977.   "join-to-subst",
  1978.   "subst-to-join",
  1979.   "busy-drive",
  1980.   "same-drive",
  1981.   "dir-not-root",
  1982.   "dir-not-empty",
  1983.   "is-subst-path",
  1984.   "is-join-path",
  1985.   "path-busy",
  1986.   "is-subst-target",
  1987.   "system-trace",
  1988.   "invalid-event-count",
  1989.   "too-many-muxwaiters",
  1990.   "invalid-list-format",
  1991.   "label-too-long",
  1992.   "too-many-tcbs",
  1993.   "signal-refused",
  1994.   "discarded",
  1995.   "not-locked",
  1996.   "bad-threadid-addr",
  1997.   "bad-arguments",
  1998.   "bad-pathname",
  1999.   "signal-pending",
  2000.   "uncertain-media",
  2001.   "max-thrds-reached",
  2002.   "monitors-not-supported",
  2003.   "unc-driver-not-installed",
  2004.   "lock-failed",
  2005.   "swapio-failed",
  2006.   "swapin-failed",
  2007.   "busy",
  2008.   "cancel-violation",
  2009.   "atomic-lock-not-supported",
  2010.   "read-locks-not-supported",
  2011.   "invalid-segment-number",
  2012.   "invalid-callgate",
  2013.   "invalid-ordinal",
  2014.   "already-exists",
  2015.   "no-child-process",
  2016.   "child-alive-nowait",
  2017.   "invalid-flag-number",
  2018.   "sem-not-found",
  2019.   "invalid-starting-codeseg",
  2020.   "invalid-stackseg",
  2021.   "invalid-moduletype",
  2022.   "invalid-exe-signature",
  2023.   "exe-marked-invalid",
  2024.   "bad-exe-format",
  2025.   "iterated-data-exceeds-64k",
  2026.   "invalid-minallocsize",
  2027.   "dynlink-from-invalid-ring",
  2028.   "iopl-not-enabled",
  2029.   "invalid-segdpl",
  2030.   "autodataseg-exceeds-64k",
  2031.   "ring2seg-must-be-movable",
  2032.   "reloc-chain-xeeds-seglim",
  2033.   "infloop-in-reloc-chain",
  2034.   "envvar-not-found",
  2035.   "not-current-ctry",
  2036.   "no-signal-sent",
  2037.   "filename-exced-range",
  2038.   "ring2-stack-in-use",
  2039.   "meta-expansion-too-long",
  2040.   "invalid-signal-number",
  2041.   "thread-1-inactive",
  2042.   "info-not-avail",
  2043.   "locked",
  2044.   "bad-dynalink",
  2045.   "too-many-modules",
  2046.   "nesting-not-allowed",
  2047.   "cannot-shrink",
  2048.   "zombie-process",
  2049.   "stack-in-high-memory",
  2050.   "invalid-exitroutine-ring",
  2051.   "getbuf-failed",
  2052.   "flushbuf-failed",
  2053.   "transfer-too-long",
  2054.   "forcenoswap-failed",
  2055.   "smg-no-target-window",
  2056.   "no-children",
  2057.   "invalid-screen-group",
  2058.   "bad-pipe",
  2059.   "pipe-busy",
  2060.   "no-data",
  2061.   "pipe-not-connected",
  2062.   "more-data",
  2063.   "vc-disconnected",
  2064.   "circularity-requested",
  2065.   "directory-in-cds",
  2066.   "invalid-fsd-name",
  2067.   "invalid-path",
  2068.   "invalid-ea-name",
  2069.   "ea-list-inconsistent",
  2070.   "ea-list-too-long",
  2071.   "no-meta-match",
  2072.   "findnotify-timeout",
  2073.   "no-more-items",
  2074.   "search-struc-reused",
  2075.   "char-not-found",
  2076.   "too-much-stack",
  2077.   "invalid-attr",
  2078.   "invalid-starting-ring",
  2079.   "invalid-dll-init-ring",
  2080.   "cannot-copy",
  2081.   "directory",
  2082.   "oplocked-file",
  2083.   "oplock-thread-exists",
  2084.   "volume-changed",
  2085.   "findnotify-handle-in-use",
  2086.   "findnotify-handle-closed",
  2087.   "notify-object-removed",
  2088.   "already-shutdown",
  2089.   "eas-didnt-fit",
  2090.   "ea-file-corrupt",
  2091.   "ea-table-full",
  2092.   "invalid-ea-handle",
  2093.   "no-cluster",
  2094.   "create-ea-file",
  2095.   "cannot-open-ea-file",
  2096.   "eas-not-supported",
  2097.   "need-eas-found",
  2098.   "duplicate-handle",
  2099.   "duplicate-name",
  2100.   "empty-muxwait",
  2101.   "mutex-owned",
  2102.   "not-owner",
  2103.   "param-too-small",
  2104.   "too-many-handles",
  2105.   "too-many-opens",
  2106.   "wrong-type",
  2107.   "unused-code",
  2108.   "thread-not-terminated",
  2109.   "init-routine-failed",
  2110.   "module-in-use",
  2111.   "not-enough-watchpoints",
  2112.   "too-many-posts",
  2113.   "already-posted",
  2114.   "already-reset",
  2115.   "sem-busy",
  2116.   "invalid-procid",
  2117.   "invalid-pdelta",
  2118.   "not-descendant",
  2119.   "not-session-manager",
  2120.   "invalid-pclass",
  2121.   "invalid-scope",
  2122.   "invalid-threadid",
  2123.   "dossub-shrink",
  2124.   "dossub-nomem",
  2125.   "dossub-overlap",
  2126.   "dossub-badsize",
  2127.   "dossub-badflag",
  2128.   "dossub-badselector",
  2129.   "mr-msg-too-long",
  2130.   "mr-mid-not-found",
  2131.   "mr-un-acc-msgf",
  2132.   "mr-inv-msgf-format",
  2133.   "mr-inv-ivcount",
  2134.   "mr-un-perform",
  2135.   "ts-wakeup",
  2136.   "ts-semhandle",
  2137.   "ts-notimer",
  2138.   "ts-handle",
  2139.   "ts-datetime",
  2140.   "sys-internal",
  2141.   "que-current-name",
  2142.   "que-proc-not-owned",
  2143.   "que-proc-owned",
  2144.   "que-duplicate",
  2145.   "que-element-not-exist",
  2146.   "que-no-memory",
  2147.   "que-invalid-name",
  2148.   "que-invalid-priority",
  2149.   "que-invalid-handle",
  2150.   "que-link-not-found",
  2151.   "que-memory-error",
  2152.   "que-prev-at-end",
  2153.   "que-proc-no-access",
  2154.   "que-empty",
  2155.   "que-name-not-exist",
  2156.   "que-not-initialized",
  2157.   "que-unable-to-access",
  2158.   "que-unable-to-add",
  2159.   "que-unable-to-init",
  2160.   "vio-invalid-mask",
  2161.   "vio-ptr",
  2162.   "vio-aptr",
  2163.   "vio-rptr",
  2164.   "vio-cptr",
  2165.   "vio-lptr",
  2166.   "vio-mode",
  2167.   "vio-width",
  2168.   "vio-attr",
  2169.   "vio-row",
  2170.   "vio-col",
  2171.   "vio-toprow",
  2172.   "vio-botrow",
  2173.   "vio-rightcol",
  2174.   "vio-leftcol",
  2175.   "scs-call",
  2176.   "scs-value",
  2177.   "vio-wait-flag",
  2178.   "vio-unlock",
  2179.   "sgs-not-session-mgr",
  2180.   "smg-invalid-session-id",
  2181.   "smg-no-sessions",
  2182.   "smg-session-not-found",
  2183.   "smg-set-title",
  2184.   "kbd-parameter",
  2185.   "kbd-no-device",
  2186.   "kbd-invalid-iowait",
  2187.   "kbd-invalid-length",
  2188.   "kbd-invalid-echo-mask",
  2189.   "kbd-invalid-input-mask",
  2190.   "mon-invalid-parms",
  2191.   "mon-invalid-devname",
  2192.   "mon-invalid-handle",
  2193.   "mon-buffer-too-small",
  2194.   "mon-buffer-empty",
  2195.   "mon-data-too-large",
  2196.   "mouse-no-device",
  2197.   "mouse-inv-handle",
  2198.   "mouse-inv-parms",
  2199.   "mouse-cant-reset",
  2200.   "mouse-display-parms",
  2201.   "mouse-inv-module",
  2202.   "mouse-inv-entry-pt",
  2203.   "mouse-inv-mask",
  2204.   "mouse-no-data",
  2205.   "mouse-ptr-drawn",
  2206.   "invalid-frequency",
  2207.   "nls-no-country-file",
  2208.   "nls-open-failed",
  2209.   "no-country-or-codepage",
  2210.   "nls-table-truncated",
  2211.   "nls-bad-type",
  2212.   "nls-type-not-found",
  2213.   "vio-smg-only",
  2214.   "vio-invalid-asciiz",
  2215.   "vio-deregister",
  2216.   "vio-no-popup",
  2217.   "vio-existing-popup",
  2218.   "kbd-smg-only",
  2219.   "kbd-invalid-asciiz",
  2220.   "kbd-invalid-mask",
  2221.   "kbd-register",
  2222.   "kbd-deregister",
  2223.   "mouse-smg-only",
  2224.   "mouse-invalid-asciiz",
  2225.   "mouse-invalid-mask",
  2226.   "mouse-register",
  2227.   "mouse-deregister",
  2228.   "smg-bad-action",
  2229.   "smg-invalid-call",
  2230.   "scs-sg-notfound",
  2231.   "scs-not-shell",
  2232.   "vio-invalid-parms",
  2233.   "vio-function-owned",
  2234.   "vio-return",
  2235.   "scs-invalid-function",
  2236.   "scs-not-session-mgr",
  2237.   "vio-register",
  2238.   "vio-no-mode-thread",
  2239.   "vio-no-save-restore-thd",
  2240.   "vio-in-bg",
  2241.   "vio-illegal-during-popup",
  2242.   "smg-not-baseshell",
  2243.   "smg-bad-statusreq",
  2244.   "que-invalid-wait",
  2245.   "vio-lock",
  2246.   "mouse-invalid-iowait",
  2247.   "vio-invalid-handle",
  2248.   "vio-illegal-during-lock",
  2249.   "vio-invalid-length",
  2250.   "kbd-invalid-handle",
  2251.   "kbd-no-more-handle",
  2252.   "kbd-cannot-create-kcb",
  2253.   "kbd-codepage-load-incompl",
  2254.   "kbd-invalid-codepage-id",
  2255.   "kbd-no-codepage-support",
  2256.   "kbd-focus-required",
  2257.   "kbd-focus-already-active",
  2258.   "kbd-keyboard-busy",
  2259.   "kbd-invalid-codepage",
  2260.   "kbd-unable-to-focus",
  2261.   "smg-session-non-select",
  2262.   "smg-session-not-foregrnd",
  2263.   "smg-session-not-parent",
  2264.   "smg-invalid-start-mode",
  2265.   "smg-invalid-related-opt",
  2266.   "smg-invalid-bond-option",
  2267.   "smg-invalid-select-opt",
  2268.   "smg-start-in-background",
  2269.   "smg-invalid-stop-option",
  2270.   "smg-bad-reserve",
  2271.   "smg-process-not-parent",
  2272.   "smg-invalid-data-length",
  2273.   "smg-not-bound",
  2274.   "smg-retry-sub-alloc",
  2275.   "kbd-detached",
  2276.   "vio-detached",
  2277.   "mou-detached",
  2278.   "vio-font",
  2279.   "vio-user-font",
  2280.   "vio-bad-cp",
  2281.   "vio-no-cp",
  2282.   "vio-na-cp",
  2283.   "invalid-code-page",
  2284.   "cplist-too-small",
  2285.   "cp-not-moved",
  2286.   "mode-switch-init",
  2287.   "code-page-not-found",
  2288.   "unexpected-slot-returned",
  2289.   "smg-invalid-trace-option",
  2290.   "vio-internal-resource",
  2291.   "vio-shell-init",
  2292.   "smg-no-hard-errors",
  2293.   "cp-switch-incomplete",
  2294.   "vio-transparent-popup",
  2295.   "critsec-overflow",
  2296.   "critsec-underflow",
  2297.   "vio-bad-reserve",
  2298.   "invalid-address",
  2299.   "zero-selectors-requested",
  2300.   "not-enough-selectors-ava",
  2301.   "invalid-selector",
  2302.   "smg-invalid-program-type",
  2303.   "smg-invalid-pgm-control",
  2304.   "smg-invalid-inherit-opt",
  2305.   "vio-extended-sg",
  2306.   "vio-not-pres-mgr-sg",
  2307.   "vio-shield-owned",
  2308.   "vio-no-more-handles",
  2309.   "vio-see-error-log",
  2310.   "vio-associated-dc",
  2311.   "kbd-no-console",
  2312.   "mouse-no-console",
  2313.   "mouse-invalid-handle",
  2314.   "smg-invalid-debug-parms",
  2315.   "kbd-extended-sg",
  2316.   "mou-extended-sg",
  2317.   "smg-invalid-icon-file",
  2318.   "trc-pid-non-existent",
  2319.   "trc-count-active",
  2320.   "trc-suspended-by-count",
  2321.   "trc-count-inactive",
  2322.   "trc-count-reached",
  2323.   "no-mc-trace",
  2324.   "mc-trace",
  2325.   "trc-count-zero",
  2326.   "smg-too-many-dds",
  2327.   "smg-invalid-notification",
  2328.   "lf-invalid-function",
  2329.   "lf-not-avail",
  2330.   "lf-suspended",
  2331.   "lf-buf-too-small",
  2332.   "lf-buffer-full",
  2333.   "lf-invalid-record",
  2334.   "lf-invalid-service",
  2335.   "lf-general-failure",
  2336.   "lf-invalid-id",
  2337.   "lf-invalid-handle",
  2338.   "lf-no-id-avail",
  2339.   "lf-template-area-full",
  2340.   "lf-id-in-use",
  2341.   "mou-not-initialized",
  2342.   "mouinitreal-done",
  2343.   "dossub-corrupted",
  2344.   "mouse-caller-not-subsys",
  2345.   "arithmetic-overflow",
  2346.   "tmr-no-device",
  2347.   "tmr-invalid-time",
  2348.   "pvw-invalid-entity",
  2349.   "pvw-invalid-entity-type",
  2350.   "pvw-invalid-spec",
  2351.   "pvw-invalid-range-type",
  2352.   "pvw-invalid-counter-blk",
  2353.   "pvw-invalid-text-blk",
  2354.   "prf-not-initialized",
  2355.   "prf-already-initialized",
  2356.   "prf-not-started",
  2357.   "prf-already-started",
  2358.   "prf-timer-out-of-range",
  2359.   "prf-timer-reset",
  2360.   "vdd-lock-useage-denied",
  2361.   "timeout",
  2362.   "vdm-down",
  2363.   "vdm-limit",
  2364.   "vdd-not-found",
  2365.   "invalid-caller",
  2366.   "pid-mismatch",
  2367.   "invalid-vdd-handle",
  2368.   "vlpt-no-spooler",
  2369.   "vcom-device-busy",
  2370.   "vlpt-device-busy",
  2371.   "nesting-too-deep",
  2372.   "vdd-missing",
  2373.   "bidi-invalid-length",
  2374.   "bidi-invalid-increment",
  2375.   "bidi-invalid-combination",
  2376.   "bidi-invalid-reserved",
  2377.   "bidi-invalid-effect",
  2378.   "bidi-invalid-csdrec",
  2379.   "bidi-invalid-csdstate",
  2380.   "bidi-invalid-level",
  2381.   "bidi-invalid-type-support",
  2382.   "bidi-invalid-orientation",
  2383.   "bidi-invalid-num-shape",
  2384.   "bidi-invalid-csd",
  2385.   "bidi-no-support",
  2386.   "bidi-rw-incomplete",
  2387.   "imp-invalid-parm",
  2388.   "imp-invalid-length",
  2389.   "hpfs-disk-error-warn",
  2390.   "mon-bad-buffer",
  2391.   "module-corrupted",
  2392.   "sm-outof-swapfile",
  2393.   "lf-timeout",
  2394.   "lf-suspend-success",
  2395.   "lf-resume-success",
  2396.   "lf-redirect-success",
  2397.   "lf-redirect-failure",
  2398.   "swapper-not-active",
  2399.   "invalid-swapid",
  2400.   "ioerr-swap-file",
  2401.   "swap-table-full",
  2402.   "swap-file-full",
  2403.   "cant-init-swapper",
  2404.   "swapper-already-init",
  2405.   "pmm-insufficient-memory",
  2406.   "pmm-invalid-flags",
  2407.   "pmm-invalid-address",
  2408.   "pmm-lock-failed",
  2409.   "pmm-unlock-failed",
  2410.   "pmm-move-incomplete",
  2411.   "ucom-drive-renamed",
  2412.   "ucom-filename-truncated",
  2413.   "ucom-buffer-length",
  2414.   "mon-chain-handle",
  2415.   "mon-not-registered",
  2416.   "smg-already-top",
  2417.   "pmm-arena-modified",
  2418.   "smg-printer-open",
  2419.   "pmm-set-flags-failed",
  2420.   "invalid-dos-dd",
  2421.   "blocked",
  2422.   "noblock",
  2423.   "instance-shared",
  2424.   "no-object",
  2425.   "partial-attach",
  2426.   "incache",
  2427.   "swap-io-problems",
  2428.   "crosses-object-boundary",
  2429.   "longlock",
  2430.   "shortlock",
  2431.   "uvirtlock",
  2432.   "aliaslock",
  2433.   "alias",
  2434.   "no-more-handles",
  2435.   "scan-terminated",
  2436.   "terminator-not-found",
  2437.   "not-direct-child",
  2438.   "delay-free",
  2439.   "guardpage",
  2440.   "swaperror",
  2441.   "ldrerror",
  2442.   "nomemory",
  2443.   "noaccess",
  2444.   "no-dll-term",
  2445.   "cpsio-code-page-invalid",
  2446.   "cpsio-no-spooler",
  2447.   "cpsio-font-id-invalid",
  2448.   "cpsio-internal-error",
  2449.   "cpsio-invalid-ptr-name",
  2450.   "cpsio-not-active",
  2451.   "cpsio-pid-full",
  2452.   "cpsio-pid-not-found",
  2453.   "cpsio-read-ctl-seq",
  2454.   "cpsio-read-fnt-def",
  2455.   "cpsio-write-error",
  2456.   "cpsio-write-full-error",
  2457.   "cpsio-write-handle-bad",
  2458.   "cpsio-swit-load",
  2459.   "cpsio-inv-command",
  2460.   "cpsio-no-font-swit",
  2461.   "entry-is-callgate",
  2462.  
  2463.   /* socket errors: */
  2464.   "soceperm",
  2465.   "socesrch",
  2466.   "soceintr",
  2467.   "socenxio",
  2468.   "socebadf",
  2469.   "soceacces",
  2470.   "socefault",
  2471.   "soceinval",
  2472.   "socemfile",
  2473.   "socepipe",
  2474.   "soceos2err",
  2475.   "socewouldblock",
  2476.   "soceinprogress",
  2477.   "socealready",
  2478.   "socenotsock",
  2479.   "socedestaddrreq",
  2480.   "socemsgsize",
  2481.   "soceprototype",
  2482.   "socenoprotoopt",
  2483.   "soceprotonosupport",
  2484.   "socesocktnosupport",
  2485.   "soceopnotsupp",
  2486.   "socepfnosupport",
  2487.   "soceafnosupport",
  2488.   "soceaddrinuse",
  2489.   "soceaddrnotavail",
  2490.   "socenetdown",
  2491.   "socenetunreach",
  2492.   "socenetreset",
  2493.   "soceconnaborted",
  2494.   "soceconnreset",
  2495.   "socenobufs",
  2496.   "soceisconn",
  2497.   "socenotconn",
  2498.   "soceshutdown",
  2499.   "socetoomanyrefs",
  2500.   "socetimedout",
  2501.   "soceconnrefused",
  2502.   "soceloop",
  2503.   "socenametoolong",
  2504.   "socehostdown",
  2505.   "socehostunreach",
  2506.   "socenotempty",
  2507.  
  2508.   "unknown"
  2509. };
  2510.  
  2511. void
  2512. OS_syserr_names (unsigned int * length, unsigned char *** names)
  2513. {
  2514.   (*length) = ((sizeof (syserr_names_table)) / (sizeof (char *)));
  2515.   (*names) = ((unsigned char **) syserr_names_table);
  2516. }
  2517.  
  2518. void
  2519. OS_syscall_names (unsigned int * length, unsigned char *** names)
  2520. {
  2521.   (*length) = ((sizeof (syscall_names_table)) / (sizeof (char *)));
  2522.   (*names) = ((unsigned char **) syscall_names_table);
  2523. }
  2524.