mirror of
				https://kernel.googlesource.com/pub/scm/linux/kernel/git/stable/linux-stable.git
				synced 2025-10-30 22:47:06 +10:00 
			
		
		
		
	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>
		
			
				
	
	
		
			327 lines
		
	
	
		
			9.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			327 lines
		
	
	
		
			9.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  *	Declarations of X.25 Packet Layer type objects.
 | |
|  *
 | |
|  * 	History
 | |
|  *	nov/17/96	Jonathan Naylor	  Initial version.		
 | |
|  *	mar/20/00	Daniela Squassoni Disabling/enabling of facilities 
 | |
|  *					  negotiation.
 | |
|  */
 | |
| 
 | |
| #ifndef _X25_H
 | |
| #define _X25_H 
 | |
| #include <linux/x25.h>
 | |
| #include <linux/slab.h>
 | |
| #include <linux/refcount.h>
 | |
| #include <net/sock.h>
 | |
| 
 | |
| #define	X25_ADDR_LEN			16
 | |
| 
 | |
| #define	X25_MAX_L2_LEN			18	/* 802.2 LLC */
 | |
| 
 | |
| #define	X25_STD_MIN_LEN			3
 | |
| #define	X25_EXT_MIN_LEN			4
 | |
| 
 | |
| #define	X25_GFI_SEQ_MASK		0x30
 | |
| #define	X25_GFI_STDSEQ			0x10
 | |
| #define	X25_GFI_EXTSEQ			0x20
 | |
| 
 | |
| #define	X25_Q_BIT			0x80
 | |
| #define	X25_D_BIT			0x40
 | |
| #define	X25_STD_M_BIT			0x10
 | |
| #define	X25_EXT_M_BIT			0x01
 | |
| 
 | |
| #define	X25_CALL_REQUEST		0x0B
 | |
| #define	X25_CALL_ACCEPTED		0x0F
 | |
| #define	X25_CLEAR_REQUEST		0x13
 | |
| #define	X25_CLEAR_CONFIRMATION		0x17
 | |
| #define	X25_DATA			0x00
 | |
| #define	X25_INTERRUPT			0x23
 | |
| #define	X25_INTERRUPT_CONFIRMATION	0x27
 | |
| #define	X25_RR				0x01
 | |
| #define	X25_RNR				0x05
 | |
| #define	X25_REJ				0x09
 | |
| #define	X25_RESET_REQUEST		0x1B
 | |
| #define	X25_RESET_CONFIRMATION		0x1F
 | |
| #define	X25_REGISTRATION_REQUEST	0xF3
 | |
| #define	X25_REGISTRATION_CONFIRMATION	0xF7
 | |
| #define	X25_RESTART_REQUEST		0xFB
 | |
| #define	X25_RESTART_CONFIRMATION	0xFF
 | |
| #define	X25_DIAGNOSTIC			0xF1
 | |
| #define	X25_ILLEGAL			0xFD
 | |
| 
 | |
| /* Define the various conditions that may exist */
 | |
| 
 | |
| #define	X25_COND_ACK_PENDING	0x01
 | |
| #define	X25_COND_OWN_RX_BUSY	0x02
 | |
| #define	X25_COND_PEER_RX_BUSY	0x04
 | |
| 
 | |
| /* Define Link State constants. */
 | |
| enum {
 | |
| 	X25_STATE_0,		/* Ready */
 | |
| 	X25_STATE_1,		/* Awaiting Call Accepted */
 | |
| 	X25_STATE_2,		/* Awaiting Clear Confirmation */
 | |
| 	X25_STATE_3,		/* Data Transfer */
 | |
| 	X25_STATE_4		/* Awaiting Reset Confirmation */
 | |
| };
 | |
| 
 | |
| enum {
 | |
| 	X25_LINK_STATE_0,
 | |
| 	X25_LINK_STATE_1,
 | |
| 	X25_LINK_STATE_2,
 | |
| 	X25_LINK_STATE_3
 | |
| };
 | |
| 
 | |
| #define X25_DEFAULT_T20		(180 * HZ)		/* Default T20 value */
 | |
| #define X25_DEFAULT_T21		(200 * HZ)		/* Default T21 value */
 | |
| #define X25_DEFAULT_T22		(180 * HZ)		/* Default T22 value */
 | |
| #define	X25_DEFAULT_T23		(180 * HZ)		/* Default T23 value */
 | |
| #define	X25_DEFAULT_T2		(3   * HZ)		/* Default ack holdback value */
 | |
| 
 | |
| #define	X25_DEFAULT_WINDOW_SIZE	2			/* Default Window Size	*/
 | |
| #define	X25_DEFAULT_PACKET_SIZE	X25_PS128		/* Default Packet Size */
 | |
| #define	X25_DEFAULT_THROUGHPUT	0x0A			/* Deafult Throughput */
 | |
| #define	X25_DEFAULT_REVERSE	0x00			/* Default Reverse Charging */
 | |
| 
 | |
| #define X25_SMODULUS 		8
 | |
| #define	X25_EMODULUS		128
 | |
| 
 | |
| /*
 | |
|  *	X.25 Facilities constants.
 | |
|  */
 | |
| 
 | |
| #define	X25_FAC_CLASS_MASK	0xC0
 | |
| 
 | |
| #define	X25_FAC_CLASS_A		0x00
 | |
| #define	X25_FAC_CLASS_B		0x40
 | |
| #define	X25_FAC_CLASS_C		0x80
 | |
| #define	X25_FAC_CLASS_D		0xC0
 | |
| 
 | |
| #define	X25_FAC_REVERSE		0x01			/* also fast select */
 | |
| #define	X25_FAC_THROUGHPUT	0x02
 | |
| #define	X25_FAC_PACKET_SIZE	0x42
 | |
| #define	X25_FAC_WINDOW_SIZE	0x43
 | |
| 
 | |
| #define X25_MAX_FAC_LEN 	60
 | |
| #define	X25_MAX_CUD_LEN		128
 | |
| 
 | |
| #define X25_FAC_CALLING_AE 	0xCB
 | |
| #define X25_FAC_CALLED_AE 	0xC9
 | |
| 
 | |
| #define X25_MARKER 		0x00
 | |
| #define X25_DTE_SERVICES 	0x0F
 | |
| #define X25_MAX_AE_LEN 		40			/* Max num of semi-octets in AE - OSI Nw */
 | |
| #define X25_MAX_DTE_FACIL_LEN	21			/* Max length of DTE facility params */
 | |
| 
 | |
| /* Bitset in x25_sock->flags for misc flags */
 | |
| #define X25_Q_BIT_FLAG		0
 | |
| #define X25_INTERRUPT_FLAG	1
 | |
| #define X25_ACCPT_APPRV_FLAG	2
 | |
| 
 | |
| /**
 | |
|  *	struct x25_route - x25 routing entry
 | |
|  *	@node - entry in x25_list_lock
 | |
|  *	@address - Start of address range
 | |
|  *	@sigdigits - Number of sig digits
 | |
|  *	@dev - More than one for MLP
 | |
|  *	@refcnt - reference counter
 | |
|  */
 | |
| struct x25_route {
 | |
| 	struct list_head	node;		
 | |
| 	struct x25_address	address;
 | |
| 	unsigned int		sigdigits;
 | |
| 	struct net_device	*dev;
 | |
| 	refcount_t		refcnt;
 | |
| };
 | |
| 
 | |
| struct x25_neigh {
 | |
| 	struct list_head	node;
 | |
| 	struct net_device	*dev;
 | |
| 	unsigned int		state;
 | |
| 	unsigned int		extended;
 | |
| 	struct sk_buff_head	queue;
 | |
| 	unsigned long		t20;
 | |
| 	struct timer_list	t20timer;
 | |
| 	unsigned long		global_facil_mask;
 | |
| 	refcount_t		refcnt;
 | |
| };
 | |
| 
 | |
| struct x25_sock {
 | |
| 	struct sock		sk;
 | |
| 	struct x25_address	source_addr, dest_addr;
 | |
| 	struct x25_neigh	*neighbour;
 | |
| 	unsigned int		lci, cudmatchlength;
 | |
| 	unsigned char		state, condition;
 | |
| 	unsigned short		vs, vr, va, vl;
 | |
| 	unsigned long		t2, t21, t22, t23;
 | |
| 	unsigned short		fraglen;
 | |
| 	unsigned long		flags;
 | |
| 	struct sk_buff_head	ack_queue;
 | |
| 	struct sk_buff_head	fragment_queue;
 | |
| 	struct sk_buff_head	interrupt_in_queue;
 | |
| 	struct sk_buff_head	interrupt_out_queue;
 | |
| 	struct timer_list	timer;
 | |
| 	struct x25_causediag	causediag;
 | |
| 	struct x25_facilities	facilities;
 | |
| 	struct x25_dte_facilities dte_facilities;
 | |
| 	struct x25_calluserdata	calluserdata;
 | |
| 	unsigned long 		vc_facil_mask;	/* inc_call facilities mask */
 | |
| };
 | |
| 
 | |
| struct x25_forward {
 | |
| 	struct list_head	node;
 | |
| 	unsigned int		lci;
 | |
| 	struct net_device	*dev1;
 | |
| 	struct net_device	*dev2;
 | |
| 	atomic_t		refcnt;
 | |
| };
 | |
| 
 | |
| static inline struct x25_sock *x25_sk(const struct sock *sk)
 | |
| {
 | |
| 	return (struct x25_sock *)sk;
 | |
| }
 | |
| 
 | |
| /* af_x25.c */
 | |
| extern int  sysctl_x25_restart_request_timeout;
 | |
| extern int  sysctl_x25_call_request_timeout;
 | |
| extern int  sysctl_x25_reset_request_timeout;
 | |
| extern int  sysctl_x25_clear_request_timeout;
 | |
| extern int  sysctl_x25_ack_holdback_timeout;
 | |
| extern int  sysctl_x25_forward;
 | |
| 
 | |
| int x25_parse_address_block(struct sk_buff *skb,
 | |
| 			    struct x25_address *called_addr,
 | |
| 			    struct x25_address *calling_addr);
 | |
| 
 | |
| int x25_addr_ntoa(unsigned char *, struct x25_address *, struct x25_address *);
 | |
| int x25_addr_aton(unsigned char *, struct x25_address *, struct x25_address *);
 | |
| struct sock *x25_find_socket(unsigned int, struct x25_neigh *);
 | |
| void x25_destroy_socket_from_timer(struct sock *);
 | |
| int x25_rx_call_request(struct sk_buff *, struct x25_neigh *, unsigned int);
 | |
| void x25_kill_by_neigh(struct x25_neigh *);
 | |
| 
 | |
| /* x25_dev.c */
 | |
| void x25_send_frame(struct sk_buff *, struct x25_neigh *);
 | |
| int x25_lapb_receive_frame(struct sk_buff *, struct net_device *,
 | |
| 			   struct packet_type *, struct net_device *);
 | |
| void x25_establish_link(struct x25_neigh *);
 | |
| void x25_terminate_link(struct x25_neigh *);
 | |
| 
 | |
| /* x25_facilities.c */
 | |
| int x25_parse_facilities(struct sk_buff *, struct x25_facilities *,
 | |
| 			 struct x25_dte_facilities *, unsigned long *);
 | |
| int x25_create_facilities(unsigned char *, struct x25_facilities *,
 | |
| 			  struct x25_dte_facilities *, unsigned long);
 | |
| int x25_negotiate_facilities(struct sk_buff *, struct sock *,
 | |
| 			     struct x25_facilities *,
 | |
| 			     struct x25_dte_facilities *);
 | |
| void x25_limit_facilities(struct x25_facilities *, struct x25_neigh *);
 | |
| 
 | |
| /* x25_forward.c */
 | |
| void x25_clear_forward_by_lci(unsigned int lci);
 | |
| void x25_clear_forward_by_dev(struct net_device *);
 | |
| int x25_forward_data(int, struct x25_neigh *, struct sk_buff *);
 | |
| int x25_forward_call(struct x25_address *, struct x25_neigh *, struct sk_buff *,
 | |
| 		     int);
 | |
| 
 | |
| /* x25_in.c */
 | |
| int x25_process_rx_frame(struct sock *, struct sk_buff *);
 | |
| int x25_backlog_rcv(struct sock *, struct sk_buff *);
 | |
| 
 | |
| /* x25_link.c */
 | |
| void x25_link_control(struct sk_buff *, struct x25_neigh *, unsigned short);
 | |
| void x25_link_device_up(struct net_device *);
 | |
| void x25_link_device_down(struct net_device *);
 | |
| void x25_link_established(struct x25_neigh *);
 | |
| void x25_link_terminated(struct x25_neigh *);
 | |
| void x25_transmit_clear_request(struct x25_neigh *, unsigned int,
 | |
| 				unsigned char);
 | |
| void x25_transmit_link(struct sk_buff *, struct x25_neigh *);
 | |
| int x25_subscr_ioctl(unsigned int, void __user *);
 | |
| struct x25_neigh *x25_get_neigh(struct net_device *);
 | |
| void x25_link_free(void);
 | |
| 
 | |
| /* x25_neigh.c */
 | |
| static __inline__ void x25_neigh_hold(struct x25_neigh *nb)
 | |
| {
 | |
| 	refcount_inc(&nb->refcnt);
 | |
| }
 | |
| 
 | |
| static __inline__ void x25_neigh_put(struct x25_neigh *nb)
 | |
| {
 | |
| 	if (refcount_dec_and_test(&nb->refcnt))
 | |
| 		kfree(nb);
 | |
| }
 | |
| 
 | |
| /* x25_out.c */
 | |
| int x25_output(struct sock *, struct sk_buff *);
 | |
| void x25_kick(struct sock *);
 | |
| void x25_enquiry_response(struct sock *);
 | |
| 
 | |
| /* x25_route.c */
 | |
| struct x25_route *x25_get_route(struct x25_address *addr);
 | |
| struct net_device *x25_dev_get(char *);
 | |
| void x25_route_device_down(struct net_device *dev);
 | |
| int x25_route_ioctl(unsigned int, void __user *);
 | |
| void x25_route_free(void);
 | |
| 
 | |
| static __inline__ void x25_route_hold(struct x25_route *rt)
 | |
| {
 | |
| 	refcount_inc(&rt->refcnt);
 | |
| }
 | |
| 
 | |
| static __inline__ void x25_route_put(struct x25_route *rt)
 | |
| {
 | |
| 	if (refcount_dec_and_test(&rt->refcnt))
 | |
| 		kfree(rt);
 | |
| }
 | |
| 
 | |
| /* x25_subr.c */
 | |
| void x25_clear_queues(struct sock *);
 | |
| void x25_frames_acked(struct sock *, unsigned short);
 | |
| void x25_requeue_frames(struct sock *);
 | |
| int x25_validate_nr(struct sock *, unsigned short);
 | |
| void x25_write_internal(struct sock *, int);
 | |
| int x25_decode(struct sock *, struct sk_buff *, int *, int *, int *, int *,
 | |
| 	       int *);
 | |
| void x25_disconnect(struct sock *, int, unsigned char, unsigned char);
 | |
| 
 | |
| /* x25_timer.c */
 | |
| void x25_init_timers(struct sock *sk);
 | |
| void x25_start_heartbeat(struct sock *);
 | |
| void x25_start_t2timer(struct sock *);
 | |
| void x25_start_t21timer(struct sock *);
 | |
| void x25_start_t22timer(struct sock *);
 | |
| void x25_start_t23timer(struct sock *);
 | |
| void x25_stop_heartbeat(struct sock *);
 | |
| void x25_stop_timer(struct sock *);
 | |
| unsigned long x25_display_timer(struct sock *);
 | |
| void x25_check_rbuf(struct sock *);
 | |
| 
 | |
| /* sysctl_net_x25.c */
 | |
| #ifdef CONFIG_SYSCTL
 | |
| int x25_register_sysctl(void);
 | |
| void x25_unregister_sysctl(void);
 | |
| #else
 | |
| static inline int x25_register_sysctl(void) { return 0; };
 | |
| static inline void x25_unregister_sysctl(void) {};
 | |
| #endif /* CONFIG_SYSCTL */
 | |
| 
 | |
| struct x25_skb_cb {
 | |
| 	unsigned int flags;
 | |
| };
 | |
| #define X25_SKB_CB(s) ((struct x25_skb_cb *) ((s)->cb))
 | |
| 
 | |
| extern struct hlist_head x25_list;
 | |
| extern rwlock_t x25_list_lock;
 | |
| extern struct list_head x25_route_list;
 | |
| extern rwlock_t x25_route_list_lock;
 | |
| extern struct list_head x25_forward_list;
 | |
| extern rwlock_t x25_forward_list_lock;
 | |
| extern struct list_head x25_neigh_list;
 | |
| extern rwlock_t x25_neigh_list_lock;
 | |
| 
 | |
| int x25_proc_init(void);
 | |
| void x25_proc_exit(void);
 | |
| #endif
 |