--- freem/src/symtab_bltin.c 2025/03/24 02:01:41 1.5
+++ freem/src/symtab_bltin.c 2025/03/26 15:17:12 1.7
@@ -1,5 +1,5 @@
/*
- * $Id: symtab_bltin.c,v 1.5 2025/03/24 02:01:41 snw Exp $
+ * $Id: symtab_bltin.c,v 1.7 2025/03/26 15:17:12 snw Exp $
* FreeM local system table and user-defined special variable table
*
*
@@ -24,6 +24,12 @@
* along with FreeM. If not, see .
*
* $Log: symtab_bltin.c,v $
+ * Revision 1.7 2025/03/26 15:17:12 snw
+ * Fall back to global-backed SSVNs when memory-backed globals fail in attempt to fix Tru64
+ *
+ * Revision 1.6 2025/03/24 04:13:11 snw
+ * Replace action macro dat with fra_dat to avoid symbol conflict on OS/2
+ *
* Revision 1.5 2025/03/24 02:01:41 snw
* Work around some OS/2 incompatibilities in symbol table code
*
@@ -52,6 +58,7 @@
symbol-table calls */
/* #define DEBUG_SYM */
+short st_use_shm = FALSE;
short restoring_consts = FALSE;
int semid_symtab;
@@ -134,7 +141,13 @@ void symtab_init (void)
fprintf (stderr, "symtab_init: allocating partition for memory-backed globals\r\n");
mbpartition = (char *) shm_alloc ((size_t) PSIZE + 2);
- NULLPTRCHK(mbpartition,"symtab_init");
+ if (mbpartition != NULL) {
+ shm_config->hdr->use_mb_globals = TRUE;
+ }
+ else {
+ fprintf (stderr, "symtab_init: falling back to global-backed structured system variables\r\n");
+ shm_config->hdr->use_mb_globals = FALSE;
+ }
shm_config->hdr->partition = mbpartition;
@@ -204,6 +217,11 @@ void symtab_shm (short action, char *key
unsigned long stptrs[128];
register int i;
char *old_partition = partition;
+
+ if (shm_config->hdr->use_mb_globals == FALSE) {
+ symtab_bltin (action, key, data);
+ return;
+ }
partition = mbpartition;
writing_mb = TRUE;
@@ -946,7 +964,7 @@ old0: /* entry from getinc */
/* end of set_sym section */
- case dat:
+ case fra_dat:
/* note: we assume EOL