2 * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
20 * @APPLE_LICENSE_HEADER_END@
26 * Mach Operating System
27 * Copyright (c) 1991,1990,1989 Carnegie Mellon University
28 * All Rights Reserved.
30 * Permission to use, copy, modify and distribute this software and its
31 * documentation is hereby granted, provided that both the copyright
32 * notice and this permission notice appear in all copies of the
33 * software, derivative works or modified versions, and any portions
34 * thereof, and that both notices appear in supporting documentation.
36 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
37 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
38 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
40 * Carnegie Mellon requests users of this software to return to
42 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
43 * School of Computer Science
44 * Carnegie Mellon University
45 * Pittsburgh PA 15213-3890
47 * any improvements or extensions that they make and grant Carnegie Mellon
48 * the rights to redistribute these changes.
54 #include <mach_debug.h>
56 #include <mach/vm_map.h>
57 #include <mach/vm_param.h>
58 #include <mach/std_types.h>
59 #include <mach/mach_types.h>
60 #include <mach/mach_host_server.h> /* prototype */
62 #if MACH_KDB && MACH_DEBUG
63 #include <vm/vm_map.h>
64 #include <vm/vm_kern.h>
65 #include <kern/host.h>
66 #include <kern/task.h>
67 #include <ddb/db_sym.h>
71 * Loads a symbol table for an external file into the kernel debugger.
72 * The symbol table data is an array of characters. It is assumed that
73 * the caller and the kernel debugger agree on its format.
76 host_load_symbol_table(
77 host_priv_t host_priv
,
81 mach_msg_type_number_t symtab_count
)
83 #if !MACH_DEBUG || !MACH_KDB
87 vm_offset_t symtab_start
;
88 vm_offset_t symtab_end
;
90 vm_map_copy_t symtab_copy_object
;
92 if (host_priv
== HOST_PRIV_NULL
)
93 return (KERN_INVALID_ARGUMENT
);
96 * Copy the symbol table array into the kernel.
97 * We make a copy of the copy object, and clear
98 * the old one, so that returning error will not
99 * deallocate the data twice.
101 symtab_copy_object
= (vm_map_copy_t
) symtab
;
102 result
= vm_map_copyout(
105 vm_map_copy_copy(symtab_copy_object
));
106 if (result
!= KERN_SUCCESS
)
109 symtab_end
= symtab_start
+ symtab_count
;
112 * Add the symbol table.
113 * Do not keep a reference for the task map. XXX
115 if (task
== TASK_NULL
)
119 if (!X_db_sym_init((char *)symtab_start
,
125 * Not enough room for symbol table - failure.
127 (void) vm_deallocate(kernel_map
,
130 return (KERN_FAILURE
);
134 * Wire down the symbol table
136 (void) vm_map_wire(kernel_map
,
138 round_page(symtab_end
),
139 VM_PROT_READ
|VM_PROT_WRITE
, FALSE
);
142 * Discard the original copy object
144 vm_map_copy_discard(symtab_copy_object
);
146 return (KERN_SUCCESS
);
147 #endif /* MACH_DEBUG && MACH_KDB */