b24413180f
Many source files in the tree are missing licensing information, which makes it harder for compliance tools to determine the correct license. By default all files without license information are under the default license of the kernel, which is GPL version 2. Update the files which contain no license information with the 'GPL-2.0' SPDX license identifier. The SPDX identifier is a legally binding shorthand, which can be used instead of the full boiler plate text. This patch is based on work done by Thomas Gleixner and Kate Stewart and Philippe Ombredanne. How this work was done: Patches were generated and checked against linux-4.14-rc6 for a subset of the use cases: - file had no licensing information it it. - file was a */uapi/* one with no licensing information in it, - file was a */uapi/* one with existing licensing information, Further patches will be generated in subsequent months to fix up cases where non-standard license headers were used, and references to license had to be inferred by heuristics based on keywords. The analysis to determine which SPDX License Identifier to be applied to a file was done in a spreadsheet of side by side results from of the output of two independent scanners (ScanCode & Windriver) producing SPDX tag:value files created by Philippe Ombredanne. Philippe prepared the base worksheet, and did an initial spot review of a few 1000 files. The 4.13 kernel was the starting point of the analysis with 60,537 files assessed. Kate Stewart did a file by file comparison of the scanner results in the spreadsheet to determine which SPDX license identifier(s) to be applied to the file. She confirmed any determination that was not immediately clear with lawyers working with the Linux Foundation. Criteria used to select files for SPDX license identifier tagging was: - Files considered eligible had to be source code files. - Make and config files were included as candidates if they contained >5 lines of source - File already had some variant of a license header in it (even if <5 lines). All documentation files were explicitly excluded. The following heuristics were used to determine which SPDX license identifiers to apply. - when both scanners couldn't find any license traces, file was considered to have no license information in it, and the top level COPYING file license applied. For non */uapi/* files that summary was: SPDX license identifier # files ---------------------------------------------------|------- GPL-2.0 11139 and resulted in the first patch in this series. If that file was a */uapi/* path one, it was "GPL-2.0 WITH Linux-syscall-note" otherwise it was "GPL-2.0". Results of that was: SPDX license identifier # files ---------------------------------------------------|------- GPL-2.0 WITH Linux-syscall-note 930 and resulted in the second patch in this series. - if a file had some form of licensing information in it, and was one of the */uapi/* ones, it was denoted with the Linux-syscall-note if any GPL family license was found in the file or had no licensing in it (per prior point). Results summary: SPDX license identifier # files ---------------------------------------------------|------ GPL-2.0 WITH Linux-syscall-note 270 GPL-2.0+ WITH Linux-syscall-note 169 ((GPL-2.0 WITH Linux-syscall-note) OR BSD-2-Clause) 21 ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) 17 LGPL-2.1+ WITH Linux-syscall-note 15 GPL-1.0+ WITH Linux-syscall-note 14 ((GPL-2.0+ WITH Linux-syscall-note) OR BSD-3-Clause) 5 LGPL-2.0+ WITH Linux-syscall-note 4 LGPL-2.1 WITH Linux-syscall-note 3 ((GPL-2.0 WITH Linux-syscall-note) OR MIT) 3 ((GPL-2.0 WITH Linux-syscall-note) AND MIT) 1 and that resulted in the third patch in this series. - when the two scanners agreed on the detected license(s), that became the concluded license(s). - when there was disagreement between the two scanners (one detected a license but the other didn't, or they both detected different licenses) a manual inspection of the file occurred. - In most cases a manual inspection of the information in the file resulted in a clear resolution of the license that should apply (and which scanner probably needed to revisit its heuristics). - When it was not immediately clear, the license identifier was confirmed with lawyers working with the Linux Foundation. - If there was any question as to the appropriate license identifier, the file was flagged for further research and to be revisited later in time. In total, over 70 hours of logged manual review was done on the spreadsheet to determine the SPDX license identifiers to apply to the source files by Kate, Philippe, Thomas and, in some cases, confirmation by lawyers working with the Linux Foundation. Kate also obtained a third independent scan of the 4.13 code base from FOSSology, and compared selected files where the other two scanners disagreed against that SPDX file, to see if there was new insights. The Windriver scanner is based on an older version of FOSSology in part, so they are related. Thomas did random spot checks in about 500 files from the spreadsheets for the uapi headers and agreed with SPDX license identifier in the files he inspected. For the non-uapi files Thomas did random spot checks in about 15000 files. In initial set of patches against 4.14-rc6, 3 files were found to have copy/paste license identifier errors, and have been fixed to reflect the correct identifier. Additionally Philippe spent 10 hours this week doing a detailed manual inspection and review of the 12,461 patched files from the initial patch version early this week with: - a full scancode scan run, collecting the matched texts, detected license ids and scores - reviewing anything where there was a license detected (about 500+ files) to ensure that the applied SPDX license was correct - reviewing anything where there was no detection but the patch license was not GPL-2.0 WITH Linux-syscall-note to ensure that the applied SPDX license was correct This produced a worksheet with 20 files needing minor correction. This worksheet was then exported into 3 different .csv files for the different types of files to be modified. These .csv files were then reviewed by Greg. Thomas wrote a script to parse the csv files and add the proper SPDX tag to the file, in the format that the file expected. This script was further refined by Greg based on the output to detect more types of files automatically and to distinguish between header and source .c files (which need different comment types.) Finally Greg ran the script using the .csv files to generate the patches. 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>
341 lines
7.5 KiB
C
341 lines
7.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*lcs.h*/
|
|
|
|
#include <linux/interrupt.h>
|
|
#include <linux/netdevice.h>
|
|
#include <linux/skbuff.h>
|
|
#include <linux/workqueue.h>
|
|
#include <asm/ccwdev.h>
|
|
|
|
#define LCS_DBF_TEXT(level, name, text) \
|
|
do { \
|
|
debug_text_event(lcs_dbf_##name, level, text); \
|
|
} while (0)
|
|
|
|
#define LCS_DBF_HEX(level,name,addr,len) \
|
|
do { \
|
|
debug_event(lcs_dbf_##name,level,(void*)(addr),len); \
|
|
} while (0)
|
|
|
|
#define LCS_DBF_TEXT_(level,name,text...) \
|
|
do { \
|
|
if (debug_level_enabled(lcs_dbf_##name, level)) { \
|
|
sprintf(debug_buffer, text); \
|
|
debug_text_event(lcs_dbf_##name, level, debug_buffer); \
|
|
} \
|
|
} while (0)
|
|
|
|
/**
|
|
* sysfs related stuff
|
|
*/
|
|
#define CARD_FROM_DEV(cdev) \
|
|
(struct lcs_card *) dev_get_drvdata( \
|
|
&((struct ccwgroup_device *)dev_get_drvdata(&cdev->dev))->dev);
|
|
|
|
/**
|
|
* Enum for classifying detected devices.
|
|
*/
|
|
enum lcs_channel_types {
|
|
/* Device is not a channel */
|
|
lcs_channel_type_none,
|
|
|
|
/* Device is a 2216 channel */
|
|
lcs_channel_type_parallel,
|
|
|
|
/* Device is a 2216 channel */
|
|
lcs_channel_type_2216,
|
|
|
|
/* Device is a OSA2 card */
|
|
lcs_channel_type_osa2
|
|
};
|
|
|
|
/**
|
|
* CCW commands used in this driver
|
|
*/
|
|
#define LCS_CCW_WRITE 0x01
|
|
#define LCS_CCW_READ 0x02
|
|
#define LCS_CCW_TRANSFER 0x08
|
|
|
|
/**
|
|
* LCS device status primitives
|
|
*/
|
|
#define LCS_CMD_STARTLAN 0x01
|
|
#define LCS_CMD_STOPLAN 0x02
|
|
#define LCS_CMD_LANSTAT 0x04
|
|
#define LCS_CMD_STARTUP 0x07
|
|
#define LCS_CMD_SHUTDOWN 0x08
|
|
#define LCS_CMD_QIPASSIST 0xb2
|
|
#define LCS_CMD_SETIPM 0xb4
|
|
#define LCS_CMD_DELIPM 0xb5
|
|
|
|
#define LCS_INITIATOR_TCPIP 0x00
|
|
#define LCS_INITIATOR_LGW 0x01
|
|
#define LCS_STD_CMD_SIZE 16
|
|
#define LCS_MULTICAST_CMD_SIZE 404
|
|
|
|
/**
|
|
* LCS IPASSIST MASKS,only used when multicast is switched on
|
|
*/
|
|
/* Not supported by LCS */
|
|
#define LCS_IPASS_ARP_PROCESSING 0x0001
|
|
#define LCS_IPASS_IN_CHECKSUM_SUPPORT 0x0002
|
|
#define LCS_IPASS_OUT_CHECKSUM_SUPPORT 0x0004
|
|
#define LCS_IPASS_IP_FRAG_REASSEMBLY 0x0008
|
|
#define LCS_IPASS_IP_FILTERING 0x0010
|
|
/* Supported by lcs 3172 */
|
|
#define LCS_IPASS_IPV6_SUPPORT 0x0020
|
|
#define LCS_IPASS_MULTICAST_SUPPORT 0x0040
|
|
|
|
/**
|
|
* LCS sense byte definitions
|
|
*/
|
|
#define LCS_SENSE_BYTE_0 0
|
|
#define LCS_SENSE_BYTE_1 1
|
|
#define LCS_SENSE_BYTE_2 2
|
|
#define LCS_SENSE_BYTE_3 3
|
|
#define LCS_SENSE_INTERFACE_DISCONNECT 0x01
|
|
#define LCS_SENSE_EQUIPMENT_CHECK 0x10
|
|
#define LCS_SENSE_BUS_OUT_CHECK 0x20
|
|
#define LCS_SENSE_INTERVENTION_REQUIRED 0x40
|
|
#define LCS_SENSE_CMD_REJECT 0x80
|
|
#define LCS_SENSE_RESETTING_EVENT 0x80
|
|
#define LCS_SENSE_DEVICE_ONLINE 0x20
|
|
|
|
/**
|
|
* LCS packet type definitions
|
|
*/
|
|
#define LCS_FRAME_TYPE_CONTROL 0
|
|
#define LCS_FRAME_TYPE_ENET 1
|
|
#define LCS_FRAME_TYPE_TR 2
|
|
#define LCS_FRAME_TYPE_FDDI 7
|
|
#define LCS_FRAME_TYPE_AUTO -1
|
|
|
|
/**
|
|
* some more definitions,we will sort them later
|
|
*/
|
|
#define LCS_ILLEGAL_OFFSET 0xffff
|
|
#define LCS_IOBUFFERSIZE 0x5000
|
|
#define LCS_NUM_BUFFS 32 /* needs to be power of 2 */
|
|
#define LCS_MAC_LENGTH 6
|
|
#define LCS_INVALID_PORT_NO -1
|
|
#define LCS_LANCMD_TIMEOUT_DEFAULT 5
|
|
|
|
/**
|
|
* Multicast state
|
|
*/
|
|
#define LCS_IPM_STATE_SET_REQUIRED 0
|
|
#define LCS_IPM_STATE_DEL_REQUIRED 1
|
|
#define LCS_IPM_STATE_ON_CARD 2
|
|
|
|
/**
|
|
* LCS IP Assist declarations
|
|
* seems to be only used for multicast
|
|
*/
|
|
#define LCS_IPASS_ARP_PROCESSING 0x0001
|
|
#define LCS_IPASS_INBOUND_CSUM_SUPP 0x0002
|
|
#define LCS_IPASS_OUTBOUND_CSUM_SUPP 0x0004
|
|
#define LCS_IPASS_IP_FRAG_REASSEMBLY 0x0008
|
|
#define LCS_IPASS_IP_FILTERING 0x0010
|
|
#define LCS_IPASS_IPV6_SUPPORT 0x0020
|
|
#define LCS_IPASS_MULTICAST_SUPPORT 0x0040
|
|
|
|
/**
|
|
* LCS Buffer states
|
|
*/
|
|
enum lcs_buffer_states {
|
|
LCS_BUF_STATE_EMPTY, /* buffer is empty */
|
|
LCS_BUF_STATE_LOCKED, /* buffer is locked, don't touch */
|
|
LCS_BUF_STATE_READY, /* buffer is ready for read/write */
|
|
LCS_BUF_STATE_PROCESSED,
|
|
};
|
|
|
|
/**
|
|
* LCS Channel State Machine declarations
|
|
*/
|
|
enum lcs_channel_states {
|
|
LCS_CH_STATE_INIT,
|
|
LCS_CH_STATE_HALTED,
|
|
LCS_CH_STATE_STOPPED,
|
|
LCS_CH_STATE_RUNNING,
|
|
LCS_CH_STATE_SUSPENDED,
|
|
LCS_CH_STATE_CLEARED,
|
|
LCS_CH_STATE_ERROR,
|
|
};
|
|
|
|
/**
|
|
* LCS device state machine
|
|
*/
|
|
enum lcs_dev_states {
|
|
DEV_STATE_DOWN,
|
|
DEV_STATE_UP,
|
|
DEV_STATE_RECOVER,
|
|
};
|
|
|
|
enum lcs_threads {
|
|
LCS_SET_MC_THREAD = 1,
|
|
LCS_RECOVERY_THREAD = 2,
|
|
};
|
|
|
|
/**
|
|
* LCS struct declarations
|
|
*/
|
|
struct lcs_header {
|
|
__u16 offset;
|
|
__u8 type;
|
|
__u8 slot;
|
|
} __attribute__ ((packed));
|
|
|
|
struct lcs_ip_mac_pair {
|
|
__be32 ip_addr;
|
|
__u8 mac_addr[LCS_MAC_LENGTH];
|
|
__u8 reserved[2];
|
|
} __attribute__ ((packed));
|
|
|
|
struct lcs_ipm_list {
|
|
struct list_head list;
|
|
struct lcs_ip_mac_pair ipm;
|
|
__u8 ipm_state;
|
|
};
|
|
|
|
struct lcs_cmd {
|
|
__u16 offset;
|
|
__u8 type;
|
|
__u8 slot;
|
|
__u8 cmd_code;
|
|
__u8 initiator;
|
|
__u16 sequence_no;
|
|
__u16 return_code;
|
|
union {
|
|
struct {
|
|
__u8 lan_type;
|
|
__u8 portno;
|
|
__u16 parameter_count;
|
|
__u8 operator_flags[3];
|
|
__u8 reserved[3];
|
|
} lcs_std_cmd;
|
|
struct {
|
|
__u16 unused1;
|
|
__u16 buff_size;
|
|
__u8 unused2[6];
|
|
} lcs_startup;
|
|
struct {
|
|
__u8 lan_type;
|
|
__u8 portno;
|
|
__u8 unused[10];
|
|
__u8 mac_addr[LCS_MAC_LENGTH];
|
|
__u32 num_packets_deblocked;
|
|
__u32 num_packets_blocked;
|
|
__u32 num_packets_tx_on_lan;
|
|
__u32 num_tx_errors_detected;
|
|
__u32 num_tx_packets_disgarded;
|
|
__u32 num_packets_rx_from_lan;
|
|
__u32 num_rx_errors_detected;
|
|
__u32 num_rx_discarded_nobuffs_avail;
|
|
__u32 num_rx_packets_too_large;
|
|
} lcs_lanstat_cmd;
|
|
#ifdef CONFIG_IP_MULTICAST
|
|
struct {
|
|
__u8 lan_type;
|
|
__u8 portno;
|
|
__u16 num_ip_pairs;
|
|
__u16 ip_assists_supported;
|
|
__u16 ip_assists_enabled;
|
|
__u16 version;
|
|
struct {
|
|
struct lcs_ip_mac_pair
|
|
ip_mac_pair[32];
|
|
__u32 response_data;
|
|
} lcs_ipass_ctlmsg __attribute ((packed));
|
|
} lcs_qipassist __attribute__ ((packed));
|
|
#endif /*CONFIG_IP_MULTICAST */
|
|
} cmd __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
/**
|
|
* Forward declarations.
|
|
*/
|
|
struct lcs_card;
|
|
struct lcs_channel;
|
|
|
|
/**
|
|
* Definition of an lcs buffer.
|
|
*/
|
|
struct lcs_buffer {
|
|
enum lcs_buffer_states state;
|
|
void *data;
|
|
int count;
|
|
/* Callback for completion notification. */
|
|
void (*callback)(struct lcs_channel *, struct lcs_buffer *);
|
|
};
|
|
|
|
struct lcs_reply {
|
|
struct list_head list;
|
|
__u16 sequence_no;
|
|
atomic_t refcnt;
|
|
/* Callback for completion notification. */
|
|
void (*callback)(struct lcs_card *, struct lcs_cmd *);
|
|
wait_queue_head_t wait_q;
|
|
struct lcs_card *card;
|
|
int received;
|
|
int rc;
|
|
};
|
|
|
|
/**
|
|
* Definition of an lcs channel
|
|
*/
|
|
struct lcs_channel {
|
|
enum lcs_channel_states state;
|
|
struct ccw_device *ccwdev;
|
|
struct ccw1 ccws[LCS_NUM_BUFFS + 1];
|
|
wait_queue_head_t wait_q;
|
|
struct tasklet_struct irq_tasklet;
|
|
struct lcs_buffer iob[LCS_NUM_BUFFS];
|
|
int io_idx;
|
|
int buf_idx;
|
|
};
|
|
|
|
|
|
/**
|
|
* definition of the lcs card
|
|
*/
|
|
struct lcs_card {
|
|
spinlock_t lock;
|
|
spinlock_t ipm_lock;
|
|
enum lcs_dev_states state;
|
|
struct net_device *dev;
|
|
struct net_device_stats stats;
|
|
__be16 (*lan_type_trans)(struct sk_buff *skb,
|
|
struct net_device *dev);
|
|
struct ccwgroup_device *gdev;
|
|
struct lcs_channel read;
|
|
struct lcs_channel write;
|
|
struct lcs_buffer *tx_buffer;
|
|
int tx_emitted;
|
|
struct list_head lancmd_waiters;
|
|
int lancmd_timeout;
|
|
|
|
struct work_struct kernel_thread_starter;
|
|
spinlock_t mask_lock;
|
|
unsigned long thread_start_mask;
|
|
unsigned long thread_running_mask;
|
|
unsigned long thread_allowed_mask;
|
|
wait_queue_head_t wait_q;
|
|
|
|
#ifdef CONFIG_IP_MULTICAST
|
|
struct list_head ipm_list;
|
|
#endif
|
|
__u8 mac[LCS_MAC_LENGTH];
|
|
__u16 ip_assists_supported;
|
|
__u16 ip_assists_enabled;
|
|
__s8 lan_type;
|
|
__u32 pkt_seq;
|
|
__u16 sequence_no;
|
|
__s16 portno;
|
|
/* Some info copied from probeinfo */
|
|
u8 device_forced;
|
|
u8 max_port_no;
|
|
u8 hint_port_no;
|
|
s16 port_protocol_no;
|
|
} __attribute__ ((aligned(8)));
|
|
|