Annotation of freem/src/tp_check.c, revision 1.1.1.1
1.1 snw 1: /*
2: * *
3: * * *
4: * * *
5: * ***************
6: * * * * *
7: * * MUMPS *
8: * * * * *
9: * ***************
10: * * *
11: * * *
12: * *
13: *
14: * tp_check.c
15: * TP database checkpointing code
16: *
17: *
18: * Author: Serena Willis <jpw@coherent-logic.com>
19: * Copyright (C) 1998 MUG Deutschland
20: * Copyright (C) 2022 Coherent Logic Development LLC
21: *
22: *
23: * This file is part of FreeM.
24: *
25: * FreeM is free software: you can redistribute it and/or modify
26: * it under the terms of the GNU Affero Public License as published by
27: * the Free Software Foundation, either version 3 of the License, or
28: * (at your option) any later version.
29: *
30: * FreeM is distributed in the hope that it will be useful,
31: * but WITHOUT ANY WARRANTY; without even the implied warranty of
32: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
33: * GNU Affero Public License for more details.
34: *
35: * You should have received a copy of the GNU Affero Public License
36: * along with FreeM. If not, see <https://www.gnu.org/licenses/>.
37: *
38: **/
39:
40: #include <stdlib.h>
41: #include <string.h>
42: #include <unistd.h>
43: #include "tp_check.h"
44: #include "mpsdef.h"
45: #include "transact.h"
46: #include "journal.h"
47: #include "fs.h"
48:
49: short frm_global_exists(char *, char *, char *);
50:
51: cptab *cptab_head[TP_MAX_NEST];
52:
53: cptab *cptab_insert(int tlevel, char *global)
54: {
55: cptab *t;
56: char mode;
57:
58: short g_exists;
59:
60: char *gc_ns;
61: char *gc_pth;
62:
63: gc_ns = (char *) malloc (STRLEN * sizeof (char));
64: NULLPTRCHK(gc_ns,"cptab_insert");
65:
66: gc_pth = (char *) malloc (STRLEN * sizeof (char));
67: NULLPTRCHK(gc_pth,"cptab_insert");
68:
69: for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
70:
71: if ((strcmp (t->global, global) == 0) && (t->mode > CP_UNUSED)) {
72: /* found match */
73: return t;
74: }
75:
76: }
77:
78: /* insert */
79: t = (cptab *) malloc (sizeof (cptab));
80: NULLPTRCHK(t,"cptab_insert");
81:
82: t->global = (char *) malloc (sizeof (char) * (strlen (global) + 1));
83: NULLPTRCHK(t->global,"cptab_insert");
84:
85: strcpy (t->global, global);
86:
87: g_exists = frm_global_exists (gc_ns, gc_pth, global);
88:
89: t->file = (char *) malloc (sizeof (char) * (strlen (gc_pth)));
90: NULLPTRCHK(t->file,"cptab_insert");
91:
92: t->cp_file = (char *) malloc (sizeof (char) * STRLEN);
93: NULLPTRCHK(t->cp_file,"cptab_insert");
94:
95: strcpy (t->file, gc_pth);
96: stcnv_m2c (t->file);
97:
98: snprintf (t->cp_file, STRLEN - 1, "%s.%d.%d.chk", t->file, pid, tp_level);
99:
100: free (gc_ns);
101: free (gc_pth);
102:
103: if (!g_exists) {
104: t->mode = CP_REMOVE;
105: }
106: else {
107: t->mode = CP_RESTORE;
108: }
109:
110: t->next = cptab_head[tlevel];
111: cptab_head[tlevel] = t;
112:
113: return t;
114: }
115:
116: short cptab_precommit(int tlevel)
117: {
118: cptab *t;
119: /*char *cmd;*/
120: char *pctmp;
121: int rc;
122:
123: /*
124: cmd = (char *) malloc (STRLEN * sizeof (char));
125: NULLPTRCHK(cmd,"cptab_precommit");
126: */
127:
128: pctmp = (char *) malloc (STRLEN * sizeof (char));
129: NULLPTRCHK(pctmp,"cptab_precommit");
130:
131: for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
132:
133: if (t->mode == CP_RESTORE) {
134:
135: /*
136: snprintf (cmd, STRLEN - 1, "/bin/cp %s %s", t->file, t->cp_file);
137: rc = system (cmd);
138: */
139:
140: rc = cp (t->cp_file, t->file);
141:
142: if (rc != 0) {
143:
144: strcpy (pctmp, t->file);
145: stcnv_c2m (pctmp);
146:
147: jnl_ent_write (JNLA_CHECKPOINT_FAIL, " \201", pctmp);
148:
149: /*free (cmd);*/
150: free (pctmp);
151:
152: return FALSE;
153:
154: }
155: else {
156:
157: strcpy (pctmp, t->file);
158: stcnv_c2m (pctmp);
159:
160: jnl_ent_write (JNLA_CHECKPOINT_OK, " \201", pctmp);
161:
162: }
163:
164: }
165:
166: }
167:
168: /*free (cmd);*/
169: free (pctmp);
170:
171: return TRUE;
172: }
173:
174: void cptab_postcommit(int tlevel)
175: {
176: cptab *t;
177: /*char *cmd;*/
178: int rc;
179:
180: /*
181: cmd = (char *) malloc (STRLEN * sizeof (char));
182: NULLPTRCHK(cmd,"cptab_postcommit");
183: */
184:
185: for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
186:
187: if (t->mode == CP_RESTORE) {
188: /*
189: snprintf (cmd, STRLEN - 1, "/bin/rm -f '%s'", t->cp_file);
190: rc = system (cmd);
191: */
192: unlink (t->cp_file);
193: }
194:
195: }
196:
197: cptab_head[tlevel] = NULL;
198: }
199:
200: short cptab_rollback(int tlevel)
201: {
202: cptab *t;
203: /*char *cmd;*/
204: int rc;
205:
206: /*
207: cmd = (char *) malloc (STRLEN * sizeof (char));
208: NULLPTRCHK(cmd,"cptab_rollback");
209: */
210:
211: for (t = cptab_head[tlevel]; t != NULL; t = t->next) {
212:
213: switch (t->mode) {
214:
215: case CP_REMOVE:
216: unlink (t->file);
217: /*
218: snprintf (cmd, STRLEN - 1, "/bin/rm -f '%s'", t->file);
219: rc = system (cmd);
220: */
221: break;
222:
223: case CP_RESTORE:
224: /*
225: snprintf (cmd, STRLEN - 1, "/bin/cp '%s' '%s'", t->cp_file, t->file);
226: rc = system (cmd);
227: */
228: rc = cp (t->file, t->cp_file);
229:
230: if (rc != 0) {
231: cptab_head[tlevel] = NULL;
232: /*free (cmd);*/
233: return FALSE;
234: }
235:
236: /*
237: snprintf (cmd, STRLEN - 1, "/bin/rm -f %s", t->cp_file);
238: rc = system (cmd);
239: */
240:
241: unlink (t->cp_file);
242: if (rc != 0) {
243: cptab_head[tlevel] = NULL;
244: /*free (cmd);*/
245: return FALSE;
246: }
247:
248: break;
249:
250:
251: }
252:
253: }
254:
255: cptab_head[tlevel] = NULL;
256:
257: return TRUE;
258:
259: }
260:
261: void cptab_dump(int tlevel)
262: {
263: cptab *gt;
264: char cp_mode[15];
265:
266: printf ("\n Global database checkpoints:\n");
267:
268: printf ("\n %-30s%-20s%s\n", "GLOBAL", "MODE", "FILES");
269: printf (" %-30s%-20s%s\n", "------", "----", "-----");
270:
271: for (gt = cptab_head[tlevel]; gt != NULL; gt = gt->next) {
272:
273: switch (gt->mode) {
274:
275: case CP_UNUSED:
276: strcpy (cp_mode, "CP_UNUSED");
277: break;
278:
279: case CP_REMOVE:
280: strcpy (cp_mode, "CP_REMOVE");
281: break;
282:
283: case CP_RESTORE:
284: strcpy (cp_mode, "CP_RESTORE");
285: break;
286:
287: }
288:
289: if (gt->mode > CP_UNUSED) {
290: printf (" %-30s%-20sIN: %s\n", gt->global, cp_mode, gt->file);
291: }
292: else {
293: printf (" N/A\n");
294: }
295:
296: if (gt->mode == CP_RESTORE) {
297: printf (" %-30s%-20sOUT: %s\n", "", "", gt->cp_file);
298: }
299:
300: }
301: }
302:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>