Compare commits

...

19 Commits

Author SHA1 Message Date
Godzil
56bf9b87fe 5.8 break the driver (yeah again) allow to fail for now. 2020-08-21 16:16:09 +02:00
Godzil
081f817cac Update kernel support list (more recent version than 5.4 may fail though) 2020-08-21 16:05:41 +02:00
Manoël Trapier
483be78d0d
Update .travis.yml
Change travis stable test branches
5.1 -> 5.3
5.2 -> 5.4
2019-12-13 14:41:30 +00:00
Godzil
61f72c675d Fix kernel-5.1.y and 5.2.y
Fix #13 and Fix #14
2019-07-25 16:31:57 +01:00
Godzil
30f606be39 Remove a useless SUBDIRS in the main makefile. 2019-07-25 16:30:49 +01:00
Godzil
41e61a81f8 Fix kernel 4.9.y
Fix #12
2019-07-25 16:17:24 +01:00
Godzil
ac6def392c This change was not for all 4.4, but just a small subset that does not replicate on later version of the kernel. 2019-07-25 16:16:59 +01:00
Godzil
3e71c6e74f Fix for kernel 4.4.y.
Fix #11
2019-07-25 16:06:53 +01:00
Godzil
9116a9917b Remove a warning about a unused variable 2019-07-25 16:06:14 +01:00
Godzil
f184634d5f Remove unused function 2019-07-25 16:05:59 +01:00
Godzil
a765b0745d Make kernel 5.x stopping to complain about SUBDIR= being deprecated 2019-07-25 15:41:46 +01:00
Godzil
0132d11b4b Fix for kernel 3.10.
Same as 2.6.32, why <linux/aio.h> is included in all other but not that one? I don't know.

Fix #9
2019-07-25 15:41:11 +01:00
Godzil
f404dd7061 It should now build for kernel 2.6.32.
Why <linux/sched.h> is not automatically included in this release is beyond me.

Fix for #8
2019-07-25 15:40:29 +01:00
Godzil
d8fea5550c Remove static function prototypes from kfusd.h and move to kfusd.c and remove useless prototypes and functions.
Also remove reference to "STATIC" instead of "static"
2019-07-25 15:39:22 +01:00
Godzil
101f3687ff Can't get to configure 2.6.13 for now, so let's ignore it at the moment. 2019-07-25 15:36:33 +01:00
Manoël Trapier
68b4fd7b40
Update README.markdown 2019-07-25 12:14:29 +01:00
Godzil
eb9511d9b3 Add an even older version of the kernel. 2019-07-25 12:13:52 +01:00
Godzil
43b1069b54 Update .gitignore 2019-07-25 12:13:11 +01:00
Godzil
d27a3f2ee1 Add test travis build 2019-07-25 11:49:57 +01:00
7 changed files with 257 additions and 127 deletions

2
.gitignore vendored
View File

@ -21,3 +21,5 @@ examples/ioctl
examples/logring
examples/pager
examples/uid-filter
examples/mmap-read
examples/mmap-test

142
.travis.yml Normal file
View File

@ -0,0 +1,142 @@
language: c
os: linux
dist: trusty
compiler: gcc
env:
global:
- KERNEL_GIT="https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git"
matrix:
include:
# Older version of the kernel
# - name: "Kernel 2.6.13"
# env: KERNEL_BRANCH="v2.6.13" GCC_VER="gcc-4.9"
# addons:
# apt:
# packages:
# - gcc-4.9
# sources:
# - ubuntu-toolchain-r-test
- name: "Kernel 2.6.32"
env: KERNEL_BRANCH="v2.6.32" GCC_VER="gcc-4.9"
addons:
apt:
packages:
- gcc-4.9
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 3.10.0"
env: KERNEL_BRANCH="v3.10" GCC_VER="gcc-4.9"
addons:
apt:
packages:
- gcc-4.9
sources:
- ubuntu-toolchain-r-test
# Here are actively supported kernel
- name: "Kernel 3.16.y LTS"
env: KERNEL_BRANCH="linux-3.16.y" GCC_VER="gcc-5"
addons:
apt:
packages:
- gcc-5
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 4.4.y LTS"
env: KERNEL_BRANCH="linux-4.4.y" GCC_VER="gcc-5"
addons:
apt:
packages:
- gcc-5
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 4.9.y LTS"
env: KERNEL_BRANCH="linux-4.9.y" GCC_VER="gcc-6"
addons:
apt:
packages:
- gcc-6
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 4.14.y LTS"
env: KERNEL_BRANCH="linux-4.14.y" GCC_VER="gcc-7"
addons:
apt:
packages:
- libelf-dev
- gcc-7
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 4.19.y LTS"
env: KERNEL_BRANCH="linux-4.19.y" GCC_VER="gcc-7"
addons:
apt:
packages:
- libelf-dev
- gcc-7
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 5.4.y LTS"
env: KERNEL_BRANCH="linux-5.4.y" GCC_VER="gcc-8"
addons:
apt:
packages:
- libelf-dev
- gcc-8
sources:
- ubuntu-toolchain-r-test
# Stable versions
- name: "Kernel 5.7.y STABLE"
env: KERNEL_BRANCH="linux-5.7.y" GCC_VER="gcc-8"
addons:
apt:
packages:
- libelf-dev
- gcc-8
sources:
- ubuntu-toolchain-r-test
- name: "Kernel 5.8.y STABLE"
env: KERNEL_BRANCH="linux-5.8.y" GCC_VER="gcc-8"
addons:
apt:
packages:
- libelf-dev
- gcc-8
sources:
- ubuntu-toolchain-r-test
allow_failures:
- name: "Kernel 5.8.y STABLE"
# Here checkout kernels
before_script:
- eval "export CC=${GCC_VER}"
- eval "${CC} --version"
- git clone ${KERNEL_GIT} --depth=1 --branch=${KERNEL_BRANCH} ${KERNEL_BRANCH}
- pushd .
- cd $KERNEL_BRANCH
- yes "" | make oldconfig CC=${GCC_VER}
- make prepare CC=${GCC_VER}
- make scripts CC=${GCC_VER}
- popd
# Now build with kernel sources
script:
- make KDIR=${PWD}/${KERNEL_BRANCH} CC=${GCC_VER}
# Not sure if I should cache the kernel source tree...
#cache:
# directories:
# - '$HOME/.sonar/cache'

View File

@ -23,8 +23,6 @@ export
####################################################
SUBDIRS = kfusd libfusd examples
default:
$(MAKE) -C libfusd
$(MAKE) -C kfusd

View File

@ -2,6 +2,8 @@
FUSD: A Linux Framework for User-Space Devices
----------------------------------------------
[![Build Status](https://travis-ci.org/Godzil/fusd.svg?branch=master)](https://travis-ci.org/Godzil/fusd)
**Welcome to FUSD!**
This is FUSD snapshot 20110401, released 18 January 2012. This fork is based

View File

@ -150,30 +150,6 @@ struct fusd_dev_t_s {
/* pointer to allow a dev to be placed on a dev_list */
struct list_head devlist;
};
/**** Function Prototypes ****/
STATIC int maybe_free_fusd_dev(fusd_dev_t *fusd_dev);
STATIC int find_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file);
STATIC int free_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file);
STATIC int fusd_fops_call_send(fusd_file_t *fusd_file_arg,
fusd_msg_t *fusd_msg, struct fusd_transaction** transaction);
STATIC int fusd_fops_call_wait(fusd_file_t *fusd_file_arg,
fusd_msg_t **fusd_msg_reply, struct fusd_transaction* transaction);
STATIC void fusd_fops_call_done(fusd_file_t *fusd_file);
STATIC void fusd_forge_close(fusd_msg_t *msg, fusd_dev_t *fusd_dev);
STATIC int fusd_add_transaction(fusd_file_t *fusd_file, int transid, int subcmd, int size, struct fusd_transaction** out_transaction);
STATIC void fusd_cleanup_transaction(fusd_file_t *fusd_file, struct fusd_transaction* transaction);
STATIC void fusd_remove_transaction(fusd_file_t *fusd_file, struct fusd_transaction* transaction);
STATIC struct fusd_transaction* fusd_find_transaction(fusd_file_t *fusd_file, int transid);
STATIC struct fusd_transaction* fusd_find_transaction_by_pid(fusd_file_t *fusd_file, int pid);
/**** Utility functions & macros ****/

View File

@ -9,7 +9,7 @@ GIT_DESCRIBE = $(shell git describe --dirty --tags)
KERNEL_VER ?= 2.6.32.7
default:
$(MAKE) -C $(KDIR) SUBDIRS=$(PWD) EXTRA_CFLAGS="-I$(PWD)/../include -DGIT_DESCRIBE='\"${GIT_DESCRIBE}\"'" V=1 modules
$(MAKE) -C $(KDIR) M=$(PWD) EXTRA_CFLAGS="-I$(PWD)/../include -DGIT_DESCRIBE='\"${GIT_DESCRIBE}\"'" V=1 modules
install:
install -d -m 0755 $(ROOTFS)/lib/modules/$(KERNEL_VER)/kernel/drivers/misc

View File

@ -65,6 +65,7 @@
#include <linux/init.h>
#include <linux/fs.h>
#include <linux/mm.h>
#include <linux/aio.h>
#include <linux/mman.h>
#include <linux/slab.h>
#include <linux/vmalloc.h>
@ -75,6 +76,7 @@
#include <linux/cdev.h>
#include <linux/device.h>
#include <linux/highmem.h>
#include <linux/sched.h>
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
#include <linux/sched/signal.h>
@ -86,8 +88,6 @@
#include <asm/pgtable.h>
#include <asm/pgalloc.h>
#define STATIC
#ifndef GIT_DESCRIBE
#define GIT_DESCRIBE "unknownversion-dirty"
#endif
@ -145,10 +145,15 @@
#define CLASS_DEVICE_DESTROY(a, b) device_destroy(a, b)
#endif
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0)
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0)
#define GET_USER_PAGES(t,m,s,n,w,f,p,v) get_user_pages_remote(t,m,s,n,(w?FOLL_WRITE:0)|(f?FOLL_FORCE:0),p,v, NULL)
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0)
#define GET_USER_PAGES(t,m,s,n,w,f,p,v) get_user_pages_remote(t,m,s,n,(w?FOLL_WRITE:0)|(f?FOLL_FORCE:0),p,v)
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4, 6, 0)
#define GET_USER_PAGES(t,m,s,n,w,f,p,v) get_user_pages_remote(t,m,s,n,w,f,p,v)
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 168) && LINUX_VERSION_CODE < KERNEL_VERSION(4, 5, 0)
/* WTH? a small subset of 4.4 have changes that does not exist until 4.9 with a new function name */
#define GET_USER_PAGES(t,m,s,n,w,f,p,v) get_user_pages(t,m,s,n,(w?FOLL_WRITE:0)|(f?FOLL_FORCE:0),p,v)
#else
#define GET_USER_PAGES(t, m, s, n, w, f, p, v) get_user_pages(t,m,s,n,w,f,p,v)
#endif
@ -169,11 +174,11 @@
#error "***FUSD doesn't work before Linux Kernel v2.6.13"
#endif
STATIC struct cdev *fusd_control_cdev;
STATIC struct cdev *fusd_status_cdev;
static struct cdev *fusd_control_cdev;
static struct cdev *fusd_status_cdev;
STATIC dev_t control_id;
STATIC dev_t status_id;
static dev_t control_id;
static dev_t status_id;
static struct CLASS *fusd_class;
@ -186,13 +191,13 @@ static struct device *fusd_status_device;
#endif
/* version number incremented for each registered device */
STATIC int last_version = 1;
static int last_version = 1;
/* version number incremented for each transaction to userspace */
STATIC int last_transid = 1;
static int last_transid = 1;
/* wait queue that is awakened when new devices are registered */
STATIC DECLARE_WAIT_QUEUE_HEAD (new_device_wait);
static DECLARE_WAIT_QUEUE_HEAD (new_device_wait);
/* the list of valid devices, and sem to protect it */
LIST_HEAD (fusd_devlist_head);
@ -210,11 +215,31 @@ MODULE_VERSION(GIT_DESCRIBE);
MODULE_LICENSE ("GPL");
//#endif
/**** Function Prototypes ****/
static int maybe_free_fusd_dev(fusd_dev_t *fusd_dev);
static int find_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file);
static int free_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file);
static int fusd_fops_call_send(fusd_file_t *fusd_file_arg,
fusd_msg_t *fusd_msg, struct fusd_transaction** transaction);
static int fusd_fops_call_wait(fusd_file_t *fusd_file_arg,
fusd_msg_t **fusd_msg_reply, struct fusd_transaction* transaction);
static void fusd_forge_close(fusd_msg_t *msg, fusd_dev_t *fusd_dev);
static int fusd_add_transaction(fusd_file_t *fusd_file, int transid, int subcmd, int size, struct fusd_transaction** out_transaction);
static void fusd_cleanup_transaction(fusd_file_t *fusd_file, struct fusd_transaction* transaction);
static void fusd_remove_transaction(fusd_file_t *fusd_file, struct fusd_transaction* transaction);
static struct fusd_transaction* fusd_find_transaction(fusd_file_t *fusd_file, int transid);
static struct fusd_transaction* fusd_find_transaction_by_pid(fusd_file_t *fusd_file, int pid);
/***************************Debugging Support*****************************/
#ifdef CONFIG_FUSD_DEBUG
STATIC int fusd_debug_level = CONFIG_FUSD_DEBUGLEVEL;
static int fusd_debug_level = CONFIG_FUSD_DEBUGLEVEL;
module_param (fusd_debug_level, int, S_IRUGO);
# define BUFSIZE 1000 /* kernel's kmalloc pool has a 1012-sized bucket */
@ -223,7 +248,7 @@ static int debug_throttle = 0; /* emit a maximum number of debug
out the machine accidentally if a
daemon disappears with open files */
STATIC void rdebug_real(char *fmt, ...)
static void rdebug_real(char *fmt, ...)
{
va_list ap;
int len;
@ -276,7 +301,7 @@ typedef struct
mem_debug_t *mem_debug;
STATIC int fusd_mem_init (void)
static int fusd_mem_init (void)
{
int i;
@ -296,7 +321,7 @@ STATIC int fusd_mem_init (void)
return 0;
}
STATIC void fusd_mem_cleanup (void)
static void fusd_mem_cleanup (void)
{
int i;
int count = 0;
@ -312,7 +337,7 @@ STATIC void fusd_mem_cleanup (void)
kfree(mem_debug);
}
STATIC void fusd_mem_add (void *ptr, int line, int size)
static void fusd_mem_add (void *ptr, int line, int size)
{
int i;
@ -332,7 +357,7 @@ STATIC void fusd_mem_add (void *ptr, int line, int size)
RDEBUG(1, "WARNING - memdebug out of space!!!!");
}
STATIC void fusd_mem_del (void *ptr)
static void fusd_mem_del (void *ptr)
{
int i;
for ( i = 0; i < MAX_MEM_DEBUG; i++ )
@ -346,7 +371,7 @@ STATIC void fusd_mem_del (void *ptr)
RDEBUG(2, "WARNING - memdebug is confused!!!!");
}
STATIC void *fusd_kmalloc (size_t size, int type, int line)
static void *fusd_kmalloc (size_t size, int type, int line)
{
void *ptr = kmalloc(size, type);
down(&fusd_memdebug_sem);
@ -355,7 +380,7 @@ STATIC void *fusd_kmalloc (size_t size, int type, int line)
return ptr;
}
STATIC void fusd_kfree (void *ptr)
static void fusd_kfree (void *ptr)
{
down(&fusd_memdebug_sem);
fusd_mem_del(ptr);
@ -363,7 +388,7 @@ STATIC void fusd_kfree (void *ptr)
up(&fusd_memdebug_sem);
}
STATIC void *fusd_vmalloc (size_t size, int line)
static void *fusd_vmalloc (size_t size, int line)
{
void *ptr = vmalloc(size);
down(&fusd_memdebug_sem);
@ -372,7 +397,7 @@ STATIC void *fusd_vmalloc (size_t size, int line)
return ptr;
}
STATIC void fusd_vfree (void *ptr)
static void fusd_vfree (void *ptr)
{
down(&fusd_memdebug_sem);
fusd_mem_del(ptr);
@ -391,7 +416,7 @@ STATIC void fusd_vfree (void *ptr)
/************** STATE MANAGEMENT AND BOOKKEEPING UTILITIES ***************/
/*************************************************************************/
STATIC inline void init_fusd_msg(fusd_msg_t *fusd_msg)
static inline void init_fusd_msg(fusd_msg_t *fusd_msg)
{
if (fusd_msg == NULL)
return;
@ -404,7 +429,7 @@ STATIC inline void init_fusd_msg(fusd_msg_t *fusd_msg)
/*
* free a fusd_msg, and NULL out the pointer that points to that fusd_msg.
*/
STATIC inline void free_fusd_msg(fusd_msg_t **fusd_msg)
static inline void free_fusd_msg(fusd_msg_t **fusd_msg)
{
if (fusd_msg == NULL || *fusd_msg == NULL)
return;
@ -425,7 +450,7 @@ STATIC inline void free_fusd_msg(fusd_msg_t **fusd_msg)
* num_files<array_size/4, the size is halved. Array is kept as is if
* the malloc fails. Returns a pointer to the new file struct or NULL
* if there isn't one. */
STATIC fusd_file_t **fusd_dev_adjsize(fusd_dev_t *fusd_dev)
static fusd_file_t **fusd_dev_adjsize(fusd_dev_t *fusd_dev)
{
fusd_file_t **old_array;
int old_size;
@ -489,7 +514,7 @@ STATIC fusd_file_t **fusd_dev_adjsize(fusd_dev_t *fusd_dev)
*
* Returns: 1 if the device was freed
* 0 if the device still exists (and can be unlocked) */
STATIC int maybe_free_fusd_dev(fusd_dev_t *fusd_dev)
static int maybe_free_fusd_dev(fusd_dev_t *fusd_dev)
{
fusd_msgC_t *ptr, *next;
@ -563,7 +588,7 @@ STATIC int maybe_free_fusd_dev(fusd_dev_t *fusd_dev)
* device state itself is freed.
*
*/
STATIC void zombify_dev(fusd_dev_t *fusd_dev)
static void zombify_dev(fusd_dev_t *fusd_dev)
{
int i;
@ -588,7 +613,7 @@ STATIC void zombify_dev(fusd_dev_t *fusd_dev)
* returns index if found, -1 if not found. ASSUMES WE HAVE A VALID
* fusd_dev. fusd_file may be NULL if we are searching for an empty
* slot. */
STATIC int find_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file)
static int find_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file)
{
int i, num_files = fusd_dev->num_files;
fusd_file_t **files = fusd_dev->files;
@ -607,7 +632,7 @@ STATIC int find_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file)
* freed. If the device is freed, then do not try to unlock it!
* (Callers: Check the return value before unlocking!)
*/
STATIC int free_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file)
static int free_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file)
{
int i;
struct list_head *tmp, *it;
@ -673,7 +698,7 @@ STATIC int free_fusd_file(fusd_dev_t *fusd_dev, fusd_file_t *fusd_file)
* call on that file descriptor -- well, we lose. Clear state of that
* old syscall out and continue as usual.
*/
STATIC struct fusd_transaction *fusd_find_incomplete_transaction(fusd_file_t *fusd_file, int subcmd)
static struct fusd_transaction *fusd_find_incomplete_transaction(fusd_file_t *fusd_file, int subcmd)
{
struct fusd_transaction *transaction = fusd_find_transaction_by_pid(fusd_file, current->pid);
if (transaction == NULL)
@ -692,7 +717,7 @@ STATIC struct fusd_transaction *fusd_find_incomplete_transaction(fusd_file_t *fu
return transaction;
}
STATIC int send_to_dev(fusd_dev_t *fusd_dev, fusd_msg_t *fusd_msg, int locked)
static int send_to_dev(fusd_dev_t *fusd_dev, fusd_msg_t *fusd_msg, int locked)
{
fusd_msgC_t *fusd_msgC;
@ -735,7 +760,7 @@ zombie_dev:
* free_fusd_file, when we throw away a reply that had been
* pending for a restart.
*/
STATIC void fusd_forge_close(fusd_msg_t *msg, fusd_dev_t *fusd_dev)
static void fusd_forge_close(fusd_msg_t *msg, fusd_dev_t *fusd_dev)
{
RDEBUG(2, "/dev/%s tried to complete an open for transid %ld, "
"forging a close", NAME(fusd_dev), msg->parm.fops_msg.transid);
@ -751,7 +776,7 @@ STATIC void fusd_forge_close(fusd_msg_t *msg, fusd_dev_t *fusd_dev)
* NOTE - we are already holding the lock on fusd_file_arg when this
* function is called, but NOT the lock on the fusd_dev
*/
STATIC int fusd_fops_call_send(fusd_file_t *fusd_file_arg,
static int fusd_fops_call_send(fusd_file_t *fusd_file_arg,
fusd_msg_t *fusd_msg, struct fusd_transaction **transaction)
{
fusd_dev_t *fusd_dev;
@ -825,7 +850,7 @@ invalid_file:
* NOTE - we are already holding the lock on fusd_file_arg when this
* function is called, but NOT the lock on the fusd_dev
*/
STATIC int fusd_fops_call_wait(fusd_file_t *fusd_file_arg,
static int fusd_fops_call_wait(fusd_file_t *fusd_file_arg,
fusd_msg_t **fusd_msg_reply, struct fusd_transaction *transaction)
{
fusd_dev_t *fusd_dev;
@ -931,16 +956,6 @@ zombie_dev:
return -EPIPE;
}
/* fusd client system call handlers should call this after they call
* fops_call, to destroy the message that was returned to them. */
STATIC void fusd_transaction_done(struct fusd_transaction *transaction)
{
transaction->transid = -1;
transaction->pid = 0;
}
/********* Functions for opening a FUSD device *******************/
@ -1082,7 +1097,7 @@ int fusd_dev_add_file(struct file *file, fusd_dev_t *fusd_dev, fusd_file_t **fus
return 0;
}
STATIC struct fusd_dev_t_s *find_user_device(int dev_id)
static struct fusd_dev_t_s *find_user_device(int dev_id)
{
struct list_head *entry;
down(&fusd_devlist_sem);
@ -1103,7 +1118,7 @@ STATIC struct fusd_dev_t_s *find_user_device(int dev_id)
* A client has called open() has been called on a registered device.
* See comment higher up for detailed notes on this function.
*/
STATIC int fusd_client_open(struct inode *inode, struct file *file)
static int fusd_client_open(struct inode *inode, struct file *file)
{
int retval;
int device_freed = 0;
@ -1188,7 +1203,7 @@ STATIC int fusd_client_open(struct inode *inode, struct file *file)
/* close() has been called on a registered device. like
* fusd_client_open, we must lock the entire device. */
STATIC int fusd_client_release(struct inode *inode, struct file *file)
static int fusd_client_release(struct inode *inode, struct file *file)
{
int retval;
fusd_file_t *fusd_file;
@ -1229,7 +1244,7 @@ invalid_file:
return -EPIPE;
}
STATIC ssize_t fusd_client_read(struct file *file, char *buf,
static ssize_t fusd_client_read(struct file *file, char *buf,
size_t count, loff_t *offset)
{
fusd_dev_t *fusd_dev;
@ -1326,7 +1341,7 @@ zombie_dev:
return -EPIPE;
}
STATIC int fusd_add_transaction(fusd_file_t *fusd_file, int transid, int subcmd, int size,
static int fusd_add_transaction(fusd_file_t *fusd_file, int transid, int subcmd, int size,
struct fusd_transaction **out_transaction)
{
struct fusd_transaction *transaction = (struct fusd_transaction *) KMALLOC(sizeof(struct fusd_transaction),
@ -1350,13 +1365,13 @@ STATIC int fusd_add_transaction(fusd_file_t *fusd_file, int transid, int subcmd,
return 0;
}
STATIC void fusd_cleanup_transaction(fusd_file_t *fusd_file, struct fusd_transaction *transaction)
static void fusd_cleanup_transaction(fusd_file_t *fusd_file, struct fusd_transaction *transaction)
{
free_fusd_msg(&transaction->msg_in);
fusd_remove_transaction(fusd_file, transaction);
}
STATIC void fusd_remove_transaction(fusd_file_t *fusd_file, struct fusd_transaction *transaction)
static void fusd_remove_transaction(fusd_file_t *fusd_file, struct fusd_transaction *transaction)
{
down(&fusd_file->transactions_sem);
list_del(&transaction->list);
@ -1365,7 +1380,7 @@ STATIC void fusd_remove_transaction(fusd_file_t *fusd_file, struct fusd_transact
KFREE(transaction);
}
STATIC struct fusd_transaction *fusd_find_transaction(fusd_file_t *fusd_file, int transid)
static struct fusd_transaction *fusd_find_transaction(fusd_file_t *fusd_file, int transid)
{
struct list_head *i;
down(&fusd_file->transactions_sem);
@ -1383,7 +1398,7 @@ STATIC struct fusd_transaction *fusd_find_transaction(fusd_file_t *fusd_file, in
return NULL;
}
STATIC struct fusd_transaction *fusd_find_transaction_by_pid(fusd_file_t *fusd_file, int pid)
static struct fusd_transaction *fusd_find_transaction_by_pid(fusd_file_t *fusd_file, int pid)
{
struct list_head *i;
down(&fusd_file->transactions_sem);
@ -1401,7 +1416,7 @@ STATIC struct fusd_transaction *fusd_find_transaction_by_pid(fusd_file_t *fusd_f
return NULL;
}
STATIC ssize_t fusd_client_write(struct file *file,
static ssize_t fusd_client_write(struct file *file,
const char *buffer,
size_t length,
loff_t *offset)
@ -1499,10 +1514,10 @@ zombie_dev:
}
#ifndef HAVE_UNLOCKED_IOCTL
STATIC int fusd_client_ioctl(struct inode *inode, struct file *file,
static int fusd_client_ioctl(struct inode *inode, struct file *file,
unsigned int cmd, unsigned long arg)
#else
STATIC long fusd_client_unlocked_ioctl (struct file *file,
static long fusd_client_unlocked_ioctl (struct file *file,
unsigned int cmd, unsigned long arg)
#endif
{
@ -1599,15 +1614,14 @@ static void fusd_client_mm_open(struct vm_area_struct *vma);
static void fusd_client_mm_close(struct vm_area_struct *vma);
/* int (*fault)(struct vm_area_struct *vma, struct vm_fault *vmf); */
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 17, 0)
static vm_fault_t fusd_client_fault (struct vm_fault *vmf);
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
static int fusd_client_fault (struct vm_fault *vmf);
#elif LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 30)
static int fusd_client_fault (struct vm_area_struct *vma, struct vm_fault *vmf);
#else
static int fusd_client_fault(struct vm_area_struct *vma, struct vm_fault *vmf, int *type);
#endif
static struct vm_operations_struct fusd_remap_vm_ops = {
@ -1721,7 +1735,9 @@ zombie_dev:
return -EPIPE;
}
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 17, 0)
static vm_fault_t fusd_client_fault (struct vm_fault *vmf)
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
static int fusd_client_fault (struct vm_fault *vmf)
#elif LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 30)
static int fusd_client_fault (struct vm_area_struct *vma, struct vm_fault *vmf)
@ -1795,7 +1811,7 @@ out:
* cached from the driver.
*
*/
STATIC unsigned int fusd_client_poll(struct file *file, poll_table *wait)
static unsigned int fusd_client_poll(struct file *file, poll_table *wait)
{
fusd_dev_t *fusd_dev;
fusd_file_t *fusd_file;
@ -1872,7 +1888,7 @@ invalid_file:
}
#ifndef HAVE_UNLOCKED_IOCTL
STATIC struct file_operations fusd_client_fops = {
static struct file_operations fusd_client_fops = {
.owner = THIS_MODULE,
.open = fusd_client_open,
.release = fusd_client_release,
@ -1883,7 +1899,7 @@ STATIC struct file_operations fusd_client_fops = {
.mmap = fusd_client_mmap
};
#else
STATIC struct file_operations fusd_client_fops = {
static struct file_operations fusd_client_fops = {
.owner = THIS_MODULE,
.open = fusd_client_open,
.release = fusd_client_release,
@ -1900,7 +1916,7 @@ STATIC struct file_operations fusd_client_fops = {
/*************************************************************************/
STATIC fusd_file_t *find_fusd_reply_file(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
static fusd_file_t *find_fusd_reply_file(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
{
/* first, try the hint */
int i = msg->parm.fops_msg.hint;
@ -1925,7 +1941,7 @@ STATIC fusd_file_t *find_fusd_reply_file(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
/* Process an incoming reply to a message dispatched by
* fusd_fops_call. Called by fusd_write when a driver writes to
* /dev/fusd. */
STATIC int fusd_fops_reply(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
static int fusd_fops_reply(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
{
fusd_file_t *fusd_file;
struct fusd_transaction *transaction;
@ -1974,7 +1990,7 @@ discard:
}
/* special function to process responses to POLL_DIFF */
STATIC int fusd_polldiff_reply(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
static int fusd_polldiff_reply(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
{
fusd_file_t *fusd_file;
@ -2001,13 +2017,7 @@ STATIC int fusd_polldiff_reply(fusd_dev_t *fusd_dev, fusd_msg_t *msg)
return 0;
}
STATIC int systest(struct super_block *sb, void *data)
{
return 1;
}
STATIC int fusd_register_device(fusd_dev_t *fusd_dev,
static int fusd_register_device(fusd_dev_t *fusd_dev,
register_msg_t register_msg)
{
int error = 0;
@ -2134,7 +2144,7 @@ register_failed:
/****************************************************************************/
/* open() called on /dev/fusd itself */
STATIC int fusd_open(struct inode *inode, struct file *file)
static int fusd_open(struct inode *inode, struct file *file)
{
fusd_dev_t *fusd_dev = NULL;
fusd_file_t **file_array = NULL;
@ -2179,7 +2189,7 @@ dev_malloc_failed:
/* close() called on /dev/fusd itself. destroy the device that
* was registered by it, if any. */
STATIC int fusd_release(struct inode *inode, struct file *file)
static int fusd_release(struct inode *inode, struct file *file)
{
fusd_dev_t *fusd_dev;
@ -2238,7 +2248,7 @@ invalid_dev:
* This function processes messages coming from userspace device drivers
* (i.e., writes to the /dev/fusd control channel.)
*/
STATIC ssize_t fusd_process_write(struct file *file,
static ssize_t fusd_process_write(struct file *file,
const char *user_msg_buffer, size_t user_msg_len,
const char *user_data_buffer, size_t user_data_len)
{
@ -2386,7 +2396,7 @@ invalid_dev:
return -EPIPE;
}
STATIC ssize_t fusd_write(struct file *file,
static ssize_t fusd_write(struct file *file,
const char *buffer,
size_t length,
loff_t *offset)
@ -2396,7 +2406,7 @@ STATIC ssize_t fusd_write(struct file *file,
}
#ifndef HAVE_UNLOCKED_IOCTL
STATIC ssize_t fusd_writev(struct file *file,
static ssize_t fusd_writev(struct file *file,
const struct iovec *iov,
unsigned long count,
loff_t *offset)
@ -2414,7 +2424,7 @@ STATIC ssize_t fusd_writev(struct file *file,
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)
ssize_t fusd_write_iter (struct kiocb *iocb, struct iov_iter *iov)
{
unsigned long count = iov_iter_count(iov);
// unsigned long count = iov_iter_count(iov);
char *msg, *data;
size_t msg_len, data_len;
@ -2437,7 +2447,7 @@ ssize_t fusd_write_iter (struct kiocb *iocb, struct iov_iter *iov)
data, data_len);
}
#else
STATIC ssize_t fusd_aio_write (struct kiocb *iocb,
static ssize_t fusd_aio_write (struct kiocb *iocb,
const struct iovec *iov,
unsigned long count,
loff_t offset)
@ -2455,10 +2465,10 @@ STATIC ssize_t fusd_aio_write (struct kiocb *iocb,
#endif
#ifndef HAVE_UNLOCKED_IOCTL
STATIC int fusd_ioctl(struct inode *inode, struct file *file,
static int fusd_ioctl(struct inode *inode, struct file *file,
unsigned int cmd, unsigned long arg)
#else
STATIC long fusd_unlocked_ioctl (struct file *file,
static long fusd_unlocked_ioctl (struct file *file,
unsigned int cmd, unsigned long arg)
#endif
{
@ -2528,7 +2538,7 @@ STATIC long fusd_unlocked_ioctl (struct file *file,
* message queue.) */
/* do a "header" read: used by fusd_read */
STATIC int fusd_read_header(char *user_buffer, size_t user_length, fusd_msg_t *msg)
static int fusd_read_header(char *user_buffer, size_t user_length, fusd_msg_t *msg)
{
int len = sizeof(fusd_msg_t);
@ -2544,7 +2554,7 @@ STATIC int fusd_read_header(char *user_buffer, size_t user_length, fusd_msg_t *m
}
/* do a "data" read: used by fusd_read */
STATIC int fusd_read_data(char *user_buffer, size_t user_length, fusd_msg_t *msg)
static int fusd_read_data(char *user_buffer, size_t user_length, fusd_msg_t *msg)
{
int len = msg->datalen;
@ -2568,7 +2578,7 @@ STATIC int fusd_read_data(char *user_buffer, size_t user_length, fusd_msg_t *msg
return len;
}
STATIC ssize_t fusd_read(struct file *file,
static ssize_t fusd_read(struct file *file,
char *user_buffer, /* The buffer to fill with data */
size_t user_length, /* The length of the buffer */
loff_t *offset) /* Our offset in the file */
@ -2651,7 +2661,7 @@ invalid_dev:
}
/* a poll on /dev/fusd itself (the control channel) */
STATIC unsigned int fusd_poll(struct file *file, poll_table *wait)
static unsigned int fusd_poll(struct file *file, poll_table *wait)
{
fusd_dev_t *fusd_dev;
GET_FUSD_DEV(file->private_data, fusd_dev);
@ -2667,7 +2677,7 @@ invalid_dev:
}
#ifndef HAVE_UNLOCKED_IOCTL
STATIC struct file_operations fusd_fops = {
static struct file_operations fusd_fops = {
.owner = THIS_MODULE,
.open = fusd_open,
.read = fusd_read,
@ -2678,7 +2688,7 @@ STATIC struct file_operations fusd_fops = {
.poll = fusd_poll,
};
#else
STATIC struct file_operations fusd_fops = {
static struct file_operations fusd_fops = {
.owner = THIS_MODULE,
.open = fusd_open,
.read = fusd_read,
@ -2706,7 +2716,7 @@ typedef struct fusd_status_state {
} fusd_statcontext_t;
/* open() called on /dev/fusd/status */
STATIC int fusd_status_open(struct inode *inode, struct file *file)
static int fusd_status_open(struct inode *inode, struct file *file)
{
int error = 0;
fusd_statcontext_t *fs;
@ -2730,7 +2740,7 @@ out:
}
/* close on /dev/fusd_status */
STATIC int fusd_status_release(struct inode *inode, struct file *file)
static int fusd_status_release(struct inode *inode, struct file *file)
{
fusd_statcontext_t *fs = (fusd_statcontext_t *) file->private_data;
@ -2746,10 +2756,10 @@ STATIC int fusd_status_release(struct inode *inode, struct file *file)
/* ioctl() on /dev/fusd/status */
#ifndef HAVE_UNLOCKED_IOCTL
STATIC int fusd_status_ioctl(struct inode *inode, struct file *file,
static int fusd_status_ioctl(struct inode *inode, struct file *file,
unsigned int cmd, unsigned long arg)
#else
STATIC long fusd_status_unlocked_ioctl (struct file *file,
static long fusd_status_unlocked_ioctl (struct file *file,
unsigned int cmd, unsigned long arg)
#endif
{
@ -2780,7 +2790,7 @@ STATIC long fusd_status_unlocked_ioctl (struct file *file,
* If there isn't at least space_needed difference between buf_size
* and len, the existing contents are moved into a larger buffer.
*/
STATIC int maybe_expand_buffer(char **buf, int *buf_size, int len,
static int maybe_expand_buffer(char **buf, int *buf_size, int len,
int space_needed)
{
if (*buf_size - len < space_needed) {
@ -2801,7 +2811,7 @@ STATIC int maybe_expand_buffer(char **buf, int *buf_size, int len,
}
/* Build a text buffer containing current fusd status. */
STATIC void fusd_status_build_text(fusd_statcontext_t *fs)
static void fusd_status_build_text(fusd_statcontext_t *fs)
{
int buf_size = 512;
char *buf = KMALLOC(buf_size, GFP_KERNEL);
@ -2856,7 +2866,7 @@ out:
}
/* Build the binary version of status */
STATIC void fusd_status_build_binary(fusd_statcontext_t *fs)
static void fusd_status_build_binary(fusd_statcontext_t *fs)
{
int buf_size = 512;
char *buf = KMALLOC(buf_size, GFP_KERNEL);
@ -2907,7 +2917,7 @@ out:
fs->need_new_status = 0;
}
STATIC ssize_t fusd_status_read(struct file *file,
static ssize_t fusd_status_read(struct file *file,
char *user_buffer, /* The buffer to fill with data */
size_t user_length, /* The length of the buffer */
loff_t *offset) /* Our offset in the file */
@ -2950,7 +2960,7 @@ STATIC ssize_t fusd_status_read(struct file *file,
}
/* a poll on /dev/fusd itself (the control channel) */
STATIC unsigned int fusd_status_poll(struct file *file, poll_table *wait)
static unsigned int fusd_status_poll(struct file *file, poll_table *wait)
{
fusd_statcontext_t *fs = (fusd_statcontext_t *) file->private_data;
@ -2963,7 +2973,7 @@ STATIC unsigned int fusd_status_poll(struct file *file, poll_table *wait)
}
#ifndef HAVE_UNLOCKED_IOCTL
STATIC struct file_operations fusd_status_fops = {
static struct file_operations fusd_status_fops = {
.owner = THIS_MODULE,
.open = fusd_status_open,
.ioctl = fusd_status_ioctl,
@ -2972,7 +2982,7 @@ STATIC struct file_operations fusd_status_fops = {
.poll = fusd_status_poll,
};
#else
STATIC struct file_operations fusd_status_fops = {
static struct file_operations fusd_status_fops = {
.owner = THIS_MODULE,
.open = fusd_status_open,
.unlocked_ioctl = fusd_status_unlocked_ioctl,
@ -2985,7 +2995,7 @@ STATIC struct file_operations fusd_status_fops = {
/*************************************************************************/
STATIC int init_fusd(void)
static int init_fusd(void)
{
int retval;
@ -3096,7 +3106,7 @@ fail0:
return retval;
}
STATIC void cleanup_fusd(void)
static void cleanup_fusd(void)
{
RDEBUG(1, "cleaning up");