170025d76Sjohnny /*
270025d76Sjohnny  * CDDL HEADER START
370025d76Sjohnny  *
470025d76Sjohnny  * The contents of this file are subject to the terms of the
5337fc9e2Sanish  * Common Development and Distribution License (the "License").
6337fc9e2Sanish  * You may not use this file except in compliance with the License.
770025d76Sjohnny  *
870025d76Sjohnny  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
970025d76Sjohnny  * or http://www.opensolaris.org/os/licensing.
1070025d76Sjohnny  * See the License for the specific language governing permissions
1170025d76Sjohnny  * and limitations under the License.
1270025d76Sjohnny  *
1370025d76Sjohnny  * When distributing Covered Code, include this CDDL HEADER in each
1470025d76Sjohnny  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
1570025d76Sjohnny  * If applicable, add the following below this CDDL HEADER, with the
1670025d76Sjohnny  * fields enclosed by brackets "[]" replaced with your own identifying
1770025d76Sjohnny  * information: Portions Copyright [yyyy] [name of copyright owner]
1870025d76Sjohnny  *
1970025d76Sjohnny  * CDDL HEADER END
2070025d76Sjohnny  */
2170025d76Sjohnny /*
22ae115bc7Smrj  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
2370025d76Sjohnny  * Use is subject to license terms.
2470025d76Sjohnny  */
2570025d76Sjohnny 
261320caf7SBryan Cantrill /*
271320caf7SBryan Cantrill  * Copyright (c) 2013, Joyent, Inc.  All rights reserved.
281320caf7SBryan Cantrill  */
2970025d76Sjohnny 
3070025d76Sjohnny /*
31843e1988Sjohnlev  * The default KVM backend, which simply calls directly into libkvm for all
32843e1988Sjohnlev  * operations.
3370025d76Sjohnny  */
3470025d76Sjohnny 
35843e1988Sjohnlev #include <mdb/mdb_kb.h>
36843e1988Sjohnlev #include <mdb/mdb_target_impl.h>
37843e1988Sjohnlev 
38843e1988Sjohnlev #include <fcntl.h>
39843e1988Sjohnlev #include <dlfcn.h>
40843e1988Sjohnlev #include <kvm.h>
4170025d76Sjohnny 
42843e1988Sjohnlev /*ARGSUSED*/
43843e1988Sjohnlev static mdb_io_t *
libkvm_sym_io(void * kvm,const char * ignored)441320caf7SBryan Cantrill libkvm_sym_io(void *kvm, const char *ignored)
45843e1988Sjohnlev {
46843e1988Sjohnlev 	mdb_io_t *io;
471320caf7SBryan Cantrill 	const char *symfile = kvm_namelist(kvm);
4870025d76Sjohnny 
49843e1988Sjohnlev 	if ((io = mdb_fdio_create_path(NULL, symfile, O_RDONLY, 0)) == NULL)
50843e1988Sjohnlev 		mdb_warn("failed to open %s", symfile);
51843e1988Sjohnlev 
52843e1988Sjohnlev 	return (io);
5370025d76Sjohnny }
5470025d76Sjohnny 
55843e1988Sjohnlev mdb_kb_ops_t *
libkvm_kb_ops(void)56843e1988Sjohnlev libkvm_kb_ops(void)
57843e1988Sjohnlev {
58843e1988Sjohnlev 	static mdb_kb_ops_t ops = {
59843e1988Sjohnlev 		.kb_open = (void *(*)())kvm_open,
60843e1988Sjohnlev 		.kb_close = (int (*)())kvm_close,
61843e1988Sjohnlev 		.kb_sym_io = libkvm_sym_io,
62843e1988Sjohnlev 		.kb_kread = (ssize_t (*)())kvm_kread,
63843e1988Sjohnlev 		.kb_kwrite = (ssize_t (*)())kvm_kwrite,
64843e1988Sjohnlev 		.kb_aread = (ssize_t (*)())kvm_aread,
65843e1988Sjohnlev 		.kb_awrite = (ssize_t (*)())kvm_awrite,
66843e1988Sjohnlev 		.kb_pread = (ssize_t (*)())kvm_pread,
67843e1988Sjohnlev 		.kb_pwrite = (ssize_t (*)())kvm_pwrite,
68*2c687d68SToomas Soome 		.kb_getmregs = (int (*)())(uintptr_t)mdb_tgt_notsup,
69843e1988Sjohnlev 		.kb_vtop = (uint64_t (*)())kvm_physaddr,
70843e1988Sjohnlev 	};
71843e1988Sjohnlev 	return (&ops);
72843e1988Sjohnlev }
73