Path: blob/main/sys/compat/linuxkpi/common/include/linux/cdev.h
39604 views
/*-1* Copyright (c) 2010 Isilon Systems, Inc.2* Copyright (c) 2010 iX Systems, Inc.3* Copyright (c) 2010 Panasas, Inc.4* Copyright (c) 2013-2021 Mellanox Technologies, Ltd.5* All rights reserved.6*7* Redistribution and use in source and binary forms, with or without8* modification, are permitted provided that the following conditions9* are met:10* 1. Redistributions of source code must retain the above copyright11* notice unmodified, this list of conditions, and the following12* disclaimer.13* 2. Redistributions in binary form must reproduce the above copyright14* notice, this list of conditions and the following disclaimer in the15* documentation and/or other materials provided with the distribution.16*17* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR18* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES19* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.20* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,21* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT22* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,23* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY24* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT25* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF26* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.27*/28#ifndef _LINUXKPI_LINUX_CDEV_H_29#define _LINUXKPI_LINUX_CDEV_H_3031#include <linux/kobject.h>32#include <linux/sysfs.h>33#include <linux/kdev_t.h>34#include <linux/list.h>3536#include <asm/atomic-long.h>3738struct device;39struct file_operations;40struct inode;41struct module;4243extern struct cdevsw linuxcdevsw;44extern const struct kobj_type linux_cdev_ktype;45extern const struct kobj_type linux_cdev_static_ktype;4647struct linux_cdev {48struct kobject kobj;49struct module *owner;50struct cdev *cdev;51dev_t dev;52const struct file_operations *ops;53u_int refs;54u_int siref;55};5657struct linux_cdev *cdev_alloc(void);5859static inline void60cdev_init(struct linux_cdev *cdev, const struct file_operations *ops)61{6263kobject_init(&cdev->kobj, &linux_cdev_static_ktype);64cdev->ops = ops;65cdev->refs = 1;66}6768static inline void69cdev_put(struct linux_cdev *p)70{71kobject_put(&p->kobj);72}7374static inline int75cdev_add(struct linux_cdev *cdev, dev_t dev, unsigned count)76{77struct make_dev_args args;78int error;7980if (count != 1)81return (-EINVAL);8283cdev->dev = dev;8485/* Setup arguments for make_dev_s() */86make_dev_args_init(&args);87args.mda_devsw = &linuxcdevsw;88args.mda_uid = 0;89args.mda_gid = 0;90args.mda_mode = 0700;91args.mda_si_drv1 = cdev;9293error = make_dev_s(&args, &cdev->cdev, "%s",94kobject_name(&cdev->kobj));95if (error)96return (-error);9798kobject_get(cdev->kobj.parent);99return (0);100}101102static inline int103cdev_add_ext(struct linux_cdev *cdev, dev_t dev, uid_t uid, gid_t gid, int mode)104{105struct make_dev_args args;106int error;107108cdev->dev = dev;109110/* Setup arguments for make_dev_s() */111make_dev_args_init(&args);112args.mda_devsw = &linuxcdevsw;113args.mda_uid = uid;114args.mda_gid = gid;115args.mda_mode = mode;116args.mda_si_drv1 = cdev;117118error = make_dev_s(&args, &cdev->cdev, "%s/%d",119kobject_name(&cdev->kobj), MINOR(dev));120if (error)121return (-error);122123kobject_get(cdev->kobj.parent);124return (0);125}126127static inline void128cdev_del(struct linux_cdev *cdev)129{130kobject_put(&cdev->kobj);131}132133struct linux_cdev *linux_find_cdev(const char *name, unsigned major, unsigned minor);134135int linux_cdev_device_add(struct linux_cdev *, struct device *);136void linux_cdev_device_del(struct linux_cdev *, struct device *);137138#define cdev_device_add(...) \139linux_cdev_device_add(__VA_ARGS__)140#define cdev_device_del(...) \141linux_cdev_device_del(__VA_ARGS__)142143#define cdev linux_cdev144145#endif /* _LINUXKPI_LINUX_CDEV_H_ */146147148