dynwind fixes
[bpt/emacs.git] / src / w32heap.h
... / ...
CommitLineData
1/* Heap management routines (including unexec) for GNU Emacs on Windows NT.
2 Copyright (C) 1994, 2001-2014 Free Software Foundation, Inc.
3
4This file is part of GNU Emacs.
5
6GNU Emacs is free software: you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
8the Free Software Foundation, either version 3 of the License, or
9(at your option) any later version.
10
11GNU Emacs is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
18
19 Geoff Voelker (voelker@cs.washington.edu) 7-29-94
20*/
21
22#ifndef NTHEAP_H_
23#define NTHEAP_H_
24
25#include <windows.h>
26
27/*
28 * Heap related stuff.
29 */
30
31extern unsigned char *get_data_start (void);
32extern unsigned char *get_data_end (void);
33extern size_t reserved_heap_size;
34extern BOOL using_dynamic_heap;
35
36extern void *mmap_realloc (void **, size_t);
37extern void mmap_free (void **);
38extern void *mmap_alloc (void **, size_t);
39
40extern void report_temacs_memory_usage (void);
41
42/* Emulation of Unix sbrk(). */
43extern void *sbrk (ptrdiff_t size);
44
45/* Initialize heap structures for sbrk on startup. */
46extern void init_heap (void);
47
48/* ----------------------------------------------------------------- */
49/* Useful routines for manipulating memory-mapped files. */
50
51typedef struct file_data {
52 char *name;
53 unsigned long size;
54 HANDLE file;
55 HANDLE file_mapping;
56 unsigned char *file_base;
57} file_data;
58
59int open_input_file (file_data *p_file, char *name);
60int open_output_file (file_data *p_file, char *name, unsigned long size);
61void close_file_data (file_data *p_file);
62
63/* Return pointer to section header for named section. */
64IMAGE_SECTION_HEADER * find_section (char * name, IMAGE_NT_HEADERS * nt_header);
65
66/* Return pointer to section header for section containing the given
67 relative virtual address. */
68IMAGE_SECTION_HEADER * rva_to_section (DWORD_PTR rva, IMAGE_NT_HEADERS * nt_header);
69
70#endif /* NTHEAP_H_ */