2008-01-08 10:59:23 +03:00
|
|
|
/* $NetBSD: nbcompat.c,v 1.10 2008/01/08 07:59:23 he Exp $ */
|
2007-12-11 16:22:50 +03:00
|
|
|
|
2006-03-31 06:43:18 +04:00
|
|
|
/* nbcompat.c
|
|
|
|
* Implementations of some FreeBSD functions on NetBSD to make things
|
|
|
|
* a bit smoother.
|
|
|
|
*/
|
2007-12-11 16:22:50 +03:00
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
2008-01-08 10:59:23 +03:00
|
|
|
__KERNEL_RCSID(0, "$NetBSD: nbcompat.c,v 1.10 2008/01/08 07:59:23 he Exp $");
|
2007-12-11 16:22:50 +03:00
|
|
|
|
2006-03-31 06:43:18 +04:00
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/systm.h>
|
|
|
|
#include <sys/kernel.h>
|
|
|
|
#include <sys/kthread.h>
|
|
|
|
#include <sys/proc.h>
|
|
|
|
#include <sys/wait.h>
|
|
|
|
#include <sys/unistd.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/errno.h>
|
|
|
|
#include <sys/lock.h>
|
2007-10-19 15:59:34 +04:00
|
|
|
#include <sys/bus.h>
|
2006-03-31 06:43:18 +04:00
|
|
|
|
|
|
|
#include <machine/stdarg.h>
|
|
|
|
|
|
|
|
#include "nbcompat.h"
|
|
|
|
|
|
|
|
/* note: this is also defined in ntoskrnl_var.h, but I didn't want to include
|
|
|
|
* the whole file here
|
|
|
|
*/
|
|
|
|
#define NDIS_KSTACK_PAGES 8
|
|
|
|
|
|
|
|
struct ndis_resource{
|
|
|
|
bus_space_handle_t res_handle;
|
|
|
|
bus_space_tag_t res_tag;
|
|
|
|
bus_addr_t res_base;
|
|
|
|
bus_size_t res_size;
|
|
|
|
};
|
|
|
|
|
2006-10-12 05:30:41 +04:00
|
|
|
int
|
2006-11-16 04:32:37 +03:00
|
|
|
bus_release_resource(device_t dev, int type, int rid,
|
2006-10-12 05:30:41 +04:00
|
|
|
struct ndis_resource *r)
|
2006-03-31 06:43:18 +04:00
|
|
|
{
|
|
|
|
switch(type) {
|
|
|
|
case SYS_RES_IOPORT:
|
|
|
|
bus_space_unmap(r->res_tag, r->res_handle, r->res_size);
|
|
|
|
break;
|
|
|
|
case SYS_RES_MEMORY:
|
|
|
|
bus_space_unmap(r->res_tag, r->res_handle, r->res_size);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
printf("error: bus_release_resource()");
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-10-12 05:30:41 +04:00
|
|
|
void
|
2006-11-16 04:32:37 +03:00
|
|
|
mtx_lock(struct mtx *mutex)
|
2006-03-31 06:43:18 +04:00
|
|
|
{
|
2007-12-05 11:34:41 +03:00
|
|
|
/* XXXSMP needs doing
|
|
|
|
*/
|
|
|
|
//mutex_enter(mutex);
|
2006-03-31 06:43:18 +04:00
|
|
|
}
|
|
|
|
|
2006-10-12 05:30:41 +04:00
|
|
|
void
|
2006-11-16 04:32:37 +03:00
|
|
|
mtx_unlock(struct mtx *mutex)
|
2006-03-31 06:43:18 +04:00
|
|
|
{
|
2007-12-05 11:34:41 +03:00
|
|
|
//mutex_exit(mutex);
|
2006-03-31 06:43:18 +04:00
|
|
|
}
|
|
|
|
|
2006-10-12 05:30:41 +04:00
|
|
|
int
|
2006-11-16 04:32:37 +03:00
|
|
|
device_is_attached(device_t dev)
|
2006-03-31 06:43:18 +04:00
|
|
|
{
|
|
|
|
/* Sure, it's attached? */
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* I took this from sys/kern/kern_kthread.c (in the NetBSD source tree).
|
|
|
|
* The only difference is the kernel stack size
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Fork a kernel thread. Any process can request this to be done.
|
|
|
|
* The VM space and limits, etc. will be shared with proc0.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
ndis_kthread_create(void (*func)(void *), void *arg,
|
2008-01-07 22:10:58 +03:00
|
|
|
struct proc **newpp, void *stack, size_t stacksize, const char *name)
|
2006-03-31 06:43:18 +04:00
|
|
|
{
|
2008-01-07 22:10:58 +03:00
|
|
|
struct lwp *l;
|
|
|
|
int error;
|
|
|
|
|
|
|
|
error = kthread_create(PRI_NONE, 0, NULL, func, arg, &l, "%s", name);
|
|
|
|
if (__predict_false(error != 0))
|
|
|
|
return (error);
|
|
|
|
|
|
|
|
/* All done! */
|
|
|
|
if (newpp != NULL)
|
|
|
|
*newpp = l->l_proc;
|
|
|
|
return (0);
|
2006-03-31 06:43:18 +04:00
|
|
|
}
|