mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-08 13:44:01 +08:00
e2be04c7f9
Many user space API headers have licensing information, which is either incomplete, badly formatted or just a shorthand for referring to the license under which the file is supposed to be. This makes it hard for compliance tools to determine the correct license. Update these files with an SPDX license identifier. The identifier was chosen based on the license information in the file. GPL/LGPL licensed headers get the matching GPL/LGPL SPDX license identifier with the added 'WITH Linux-syscall-note' exception, which is the officially assigned exception identifier for the kernel syscall exception: NOTE! This copyright does *not* cover user programs that use kernel services by normal system calls - this is merely considered normal use of the kernel, and does *not* fall under the heading of "derived work". This exception makes it possible to include GPL headers into non GPL code, without confusing license compliance tools. Headers which have either explicit dual licensing or are just licensed under a non GPL license are updated with the corresponding SPDX identifier and the GPLv2 with syscall exception identifier. The format is: ((GPL-2.0 WITH Linux-syscall-note) OR SPDX-ID-OF-OTHER-LICENSE) SPDX license identifiers are a legally binding shorthand, which can be used instead of the full boiler plate text. The update does not remove existing license information as this has to be done on a case by case basis and the copyright holders might have to be consulted. This will happen in a separate step. This patch is based on work done by Thomas Gleixner and Kate Stewart and Philippe Ombredanne. See the previous patch in this series for the methodology of how this patch was researched. Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Reviewed-by: Philippe Ombredanne <pombredanne@nexb.com> Reviewed-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
57 lines
2.1 KiB
C
57 lines
2.1 KiB
C
/* SPDX-License-Identifier: LGPL-2.1+ WITH Linux-syscall-note */
|
|
/* Copyright (C) 2003 Krzysztof Benedyczak & Michal Wronski
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
It is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with this software; if not, write to the Free
|
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
02111-1307 USA. */
|
|
|
|
#ifndef _LINUX_MQUEUE_H
|
|
#define _LINUX_MQUEUE_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#define MQ_PRIO_MAX 32768
|
|
/* per-uid limit of kernel memory used by mqueue, in bytes */
|
|
#define MQ_BYTES_MAX 819200
|
|
|
|
struct mq_attr {
|
|
__kernel_long_t mq_flags; /* message queue flags */
|
|
__kernel_long_t mq_maxmsg; /* maximum number of messages */
|
|
__kernel_long_t mq_msgsize; /* maximum message size */
|
|
__kernel_long_t mq_curmsgs; /* number of messages currently queued */
|
|
__kernel_long_t __reserved[4]; /* ignored for input, zeroed for output */
|
|
};
|
|
|
|
/*
|
|
* SIGEV_THREAD implementation:
|
|
* SIGEV_THREAD must be implemented in user space. If SIGEV_THREAD is passed
|
|
* to mq_notify, then
|
|
* - sigev_signo must be the file descriptor of an AF_NETLINK socket. It's not
|
|
* necessary that the socket is bound.
|
|
* - sigev_value.sival_ptr must point to a cookie that is NOTIFY_COOKIE_LEN
|
|
* bytes long.
|
|
* If the notification is triggered, then the cookie is sent to the netlink
|
|
* socket. The last byte of the cookie is replaced with the NOTIFY_?? codes:
|
|
* NOTIFY_WOKENUP if the notification got triggered, NOTIFY_REMOVED if it was
|
|
* removed, either due to a close() on the message queue fd or due to a
|
|
* mq_notify() that removed the notification.
|
|
*/
|
|
#define NOTIFY_NONE 0
|
|
#define NOTIFY_WOKENUP 1
|
|
#define NOTIFY_REMOVED 2
|
|
|
|
#define NOTIFY_COOKIE_LEN 32
|
|
|
|
#endif
|