1 /** 2 * Compiler implementation of the 3 * $(LINK2 http://www.dlang.org, D programming language). 4 * 5 * Copyright: Copyright (C) 1987-1998 by Symantec 6 * Copyright (C) 2000-2021 by The D Language Foundation, All Rights Reserved 7 * Authors: $(LINK2 http://www.digitalmars.com, Walter Bright) 8 * License: $(LINK2 http://www.boost.org/LICENSE_1_0.txt, Boost License 1.0) 9 * Source: $(LINK2 https://github.com/dlang/dmd/blob/master/src/dmd/backend/dcode.d, backend/dcode.d) 10 */ 11 12 module dmd.backend.dcode; 13 14 version (SCPP) 15 version = COMPILE; 16 version (MARS) 17 version = COMPILE; 18 19 version (COMPILE) 20 { 21 22 import core.stdc.stdio; 23 import core.stdc.stdlib; 24 import core.stdc.string; 25 26 import dmd.backend.cc; 27 import dmd.backend.cdef; 28 import dmd.backend.code; 29 import dmd.backend.code_x86; 30 import dmd.backend.global; 31 import dmd.backend.mem; 32 33 extern (C++): 34 35 nothrow: 36 37 __gshared 38 code *code_list = null; 39 40 /************************************ 41 * Allocate a chunk of code's and add them to 42 * code_list. 43 */ 44 code *code_chunk_alloc() 45 { 46 const size_t n = 4096 / code.sizeof; 47 //printf("code_chunk_alloc() n = %d\n", n); 48 code *chunk = cast(code *)mem_fmalloc(n * code.sizeof); 49 for (size_t i = 0; i < n - 1; ++i) 50 { 51 chunk[i].next = &chunk[i + 1]; 52 } 53 chunk[n - 1].next = null; 54 code_list = chunk; 55 return chunk; 56 } 57 58 /***************** 59 * Allocate code 60 */ 61 62 code *code_calloc() 63 { 64 //printf("code %d\n", code.sizeof); 65 code *c = code_list ? code_list : code_chunk_alloc(); 66 code_list = code_next(c); 67 memset(c, 0, code.sizeof); 68 69 //dbg_printf("code_calloc: %p\n",c); 70 return c; 71 } 72 73 74 /***************** 75 * Free code 76 */ 77 78 void code_free(code *cstart) 79 { 80 if (cstart) 81 { 82 code *c = cstart; 83 while (1) 84 { 85 if (c.Iop == ASM) 86 { 87 mem_free(c.IEV1.bytes); 88 } 89 code *cnext = code_next(c); 90 if (!cnext) 91 break; 92 c = cnext; 93 } 94 c.next = code_list; 95 code_list = cstart; 96 } 97 } 98 99 /***************** 100 * Terminate code 101 */ 102 103 void code_term() 104 { 105 static if (TERMCODE) 106 { 107 code *cn; 108 int count = 0; 109 110 while (code_list) 111 { cn = code_next(code_list); 112 //mem_ffree(code_list); 113 code_list = cn; 114 count++; 115 } 116 debug printf("Max # of codes = %d\n",count); 117 } 118 else 119 { 120 debug 121 { 122 int count = 0; 123 124 for (code *cn = code_list; cn; cn = code_next(cn)) 125 count++; 126 printf("Max # of codes = %d\n",count); 127 } 128 } 129 } 130 131 }