2008-03-05 03:58:54 +03:00
|
|
|
#ifndef _SPL_VMSYSTM_H
|
|
|
|
#define _SPL_VMSYSTM_H
|
|
|
|
|
|
|
|
#include <linux/mm.h>
|
2008-05-16 03:39:19 +04:00
|
|
|
#include <linux/swap.h>
|
2008-03-14 03:04:01 +03:00
|
|
|
#include <sys/types.h>
|
2008-03-15 03:05:38 +03:00
|
|
|
#include <asm/uaccess.h>
|
2008-03-14 03:04:01 +03:00
|
|
|
|
|
|
|
extern vmem_t *zio_alloc_arena; /* arena for zio caches */
|
2008-03-05 03:58:54 +03:00
|
|
|
|
|
|
|
#define physmem num_physpages
|
2008-05-16 03:39:19 +04:00
|
|
|
#define freemem nr_free_pages() /* Expensive on linux,
|
|
|
|
cheap on solaris */
|
|
|
|
#define minfree 0
|
2008-03-07 02:12:55 +03:00
|
|
|
#define ptob(pages) (pages * PAGE_SIZE)
|
|
|
|
#define membar_producer() smp_wmb()
|
|
|
|
|
2008-03-15 03:05:38 +03:00
|
|
|
#define xcopyin(from, to, size) copy_from_user(to, from, size)
|
|
|
|
#define xcopyout(from, to, size) copy_to_user(to, from, size)
|
|
|
|
|
|
|
|
static __inline__ int
|
|
|
|
copyin(const void *from, void *to, size_t len)
|
|
|
|
{
|
|
|
|
/* On error copyin routine returns -1 */
|
|
|
|
if (xcopyin(from, to, len))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline__ int
|
|
|
|
copyout(const void *from, void *to, size_t len)
|
|
|
|
{
|
|
|
|
/* On error copyout routine returns -1 */
|
|
|
|
if (xcopyout(from, to, len))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline__ int
|
|
|
|
copyinstr(const void *from, void *to, size_t len, size_t *done)
|
|
|
|
{
|
2008-04-01 21:00:06 +04:00
|
|
|
size_t rc;
|
|
|
|
|
2008-03-15 03:05:38 +03:00
|
|
|
if (len == 0)
|
|
|
|
return -ENAMETOOLONG;
|
|
|
|
|
|
|
|
if (len < 0)
|
|
|
|
return -EFAULT;
|
|
|
|
|
|
|
|
/* XXX: Should return ENAMETOOLONG if 'strlen(from) > len' */
|
|
|
|
|
|
|
|
memset(to, 0, len);
|
2008-04-01 21:00:06 +04:00
|
|
|
rc = copyin(from, to, len - 1);
|
|
|
|
if (done != NULL)
|
|
|
|
*done = rc;
|
2008-03-15 03:05:38 +03:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2008-03-13 00:33:28 +03:00
|
|
|
|
2008-03-07 02:12:55 +03:00
|
|
|
#if 0
|
|
|
|
/* The average number of free pages over the last 5 seconds */
|
|
|
|
#define avefree 0
|
|
|
|
|
|
|
|
/* The average number of free pages over the last 30 seconds */
|
|
|
|
#define avefree30 0
|
|
|
|
|
|
|
|
/* A guess as to how much memory has been promised to
|
|
|
|
* processes but not yet allocated */
|
|
|
|
#define deficit 0
|
|
|
|
|
|
|
|
/* A guess as to how many page are needed to satisfy
|
|
|
|
* stalled page creation requests */
|
|
|
|
#define needfree 0
|
|
|
|
|
|
|
|
/* A bootlean the controls the setting of deficit */
|
|
|
|
#define desperate
|
|
|
|
|
|
|
|
/* When free memory is above this limit, no paging or swapping is done */
|
|
|
|
#define lotsfree 0
|
|
|
|
|
|
|
|
/* When free memory is above this limit, swapping is not performed */
|
|
|
|
#define desfree 0
|
|
|
|
#endif
|
2008-03-05 03:58:54 +03:00
|
|
|
|
|
|
|
#endif /* SPL_VMSYSTM_H */
|