2 * Copyright (c) 2004 David Xu <davidxu@freebsd.org>
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * $DragonFly: src/lib/libthread_db/thread_db.c,v 1.1 2005/05/07 09:25:44 davidxu Exp $
29 #include <sys/cdefs.h>
30 #include <proc_service.h>
32 #include <thread_db.h>
35 #include "thread_db_int.h"
42 static TAILQ_HEAD(, td_thragent
) proclist
= TAILQ_HEAD_INITIALIZER(proclist
);
44 extern struct ta_ops libthread_xu_ops
;
46 static struct ta_ops
*ops
[] = {
57 for (i
= 0; i
< sizeof(ops
)/sizeof(ops
[0]); i
++) {
58 if (ops
[i
]->to_init
!= NULL
) {
59 tmp
= ops
[i
]->to_init();
68 td_ta_clear_event(const td_thragent_t
*ta
, td_thr_events_t
*events
)
70 return (ta
->ta_ops
->to_ta_clear_event(ta
, events
));
74 td_ta_delete(td_thragent_t
*ta
)
76 TAILQ_REMOVE(&proclist
, ta
, ta_next
);
77 return (ta
->ta_ops
->to_ta_delete(ta
));
81 td_ta_event_addr(const td_thragent_t
*ta
, td_event_e event
, td_notify_t
*ptr
)
83 return (ta
->ta_ops
->to_ta_event_addr(ta
, event
, ptr
));
87 td_ta_event_getmsg(const td_thragent_t
*ta
, td_event_msg_t
*msg
)
89 return (ta
->ta_ops
->to_ta_event_getmsg(ta
, msg
));
93 td_ta_map_id2thr(const td_thragent_t
*ta
, thread_t id
, td_thrhandle_t
*th
)
95 return (ta
->ta_ops
->to_ta_map_id2thr(ta
, id
, th
));
99 td_ta_map_lwp2thr(const td_thragent_t
*ta
, lwpid_t lwpid
, td_thrhandle_t
*th
)
101 return (ta
->ta_ops
->to_ta_map_lwp2thr(ta
, lwpid
, th
));
105 td_ta_new(struct ps_prochandle
*ph
, td_thragent_t
**pta
)
109 for (i
= 0; i
< sizeof(ops
)/sizeof(ops
[0]); ++i
) {
110 if (ops
[i
]->to_ta_new(ph
, pta
) == TD_OK
) {
111 TAILQ_INSERT_HEAD(&proclist
, *pta
, ta_next
);
112 (*pta
)->ta_ops
= ops
[i
];
116 return (TD_NOLIBTHREAD
);
120 td_ta_set_event(const td_thragent_t
*ta
, td_thr_events_t
*events
)
122 return (ta
->ta_ops
->to_ta_set_event(ta
, events
));
126 td_ta_thr_iter(const td_thragent_t
*ta
, td_thr_iter_f
*callback
,
127 void *cbdata_p
, td_thr_state_e state
, int ti_pri
, sigset_t
*ti_sigmask_p
,
128 unsigned int ti_user_flags
)
130 return (ta
->ta_ops
->to_ta_thr_iter(ta
, callback
, cbdata_p
, state
,
131 ti_pri
, ti_sigmask_p
, ti_user_flags
));
135 td_ta_tsd_iter(const td_thragent_t
*ta
, td_key_iter_f
*callback
,
138 return (ta
->ta_ops
->to_ta_tsd_iter(ta
, callback
, cbdata_p
));
142 td_thr_clear_event(const td_thrhandle_t
*th
, td_thr_events_t
*events
)
144 const td_thragent_t
*ta
= th
->th_ta
;
145 return (ta
->ta_ops
->to_thr_clear_event(th
, events
));
149 td_thr_dbresume(const td_thrhandle_t
*th
)
151 const td_thragent_t
*ta
= th
->th_ta
;
152 return (ta
->ta_ops
->to_thr_dbresume(th
));
156 td_thr_dbsuspend(const td_thrhandle_t
*th
)
158 const td_thragent_t
*ta
= th
->th_ta
;
159 return (ta
->ta_ops
->to_thr_dbsuspend(th
));
163 td_thr_event_enable(const td_thrhandle_t
*th
, int en
)
165 const td_thragent_t
*ta
= th
->th_ta
;
166 return (ta
->ta_ops
->to_thr_event_enable(th
, en
));
170 td_thr_event_getmsg(const td_thrhandle_t
*th
, td_event_msg_t
*msg
)
172 const td_thragent_t
*ta
= th
->th_ta
;
173 return (ta
->ta_ops
->to_thr_event_getmsg(th
, msg
));
177 td_thr_get_info(const td_thrhandle_t
*th
, td_thrinfo_t
*info
)
179 const td_thragent_t
*ta
= th
->th_ta
;
180 return (ta
->ta_ops
->to_thr_get_info(th
, info
));
184 td_thr_getfpregs(const td_thrhandle_t
*th
, prfpregset_t
*fpregset
)
186 const td_thragent_t
*ta
= th
->th_ta
;
187 return (ta
->ta_ops
->to_thr_getfpregs(th
, fpregset
));
191 td_thr_getgregs(const td_thrhandle_t
*th
, prgregset_t gregs
)
193 const td_thragent_t
*ta
= th
->th_ta
;
194 return (ta
->ta_ops
->to_thr_getgregs(th
, gregs
));
198 td_thr_set_event(const td_thrhandle_t
*th
, td_thr_events_t
*events
)
200 const td_thragent_t
*ta
= th
->th_ta
;
201 return (ta
->ta_ops
->to_thr_set_event(th
, events
));
205 td_thr_setfpregs(const td_thrhandle_t
*th
, const prfpregset_t
*fpregs
)
207 const td_thragent_t
*ta
= th
->th_ta
;
208 return (ta
->ta_ops
->to_thr_setfpregs(th
, fpregs
));
212 td_thr_setgregs(const td_thrhandle_t
*th
, const prgregset_t gregs
)
214 const td_thragent_t
*ta
= th
->th_ta
;
215 return (ta
->ta_ops
->to_thr_setgregs(th
, gregs
));
219 td_thr_validate(const td_thrhandle_t
*th
)
221 const td_thragent_t
*ta
= th
->th_ta
;
222 return (ta
->ta_ops
->to_thr_validate(th
));
226 td_thr_tls_get_addr(const td_thrhandle_t
*th
, void *linkmap
, size_t offset
,
229 const td_thragent_t
*ta
= th
->th_ta
;
230 return (ta
->ta_ops
->to_thr_tls_get_addr(th
, linkmap
, offset
, address
));