License cleanup: add SPDX GPL-2.0 license identifier to files with no license
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>
2017-11-01 14:07:57 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2009-03-19 19:34:09 +00:00
|
|
|
/* Included from asm/pgtable-*.h only ! */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Some bits are only used on some cpu families... Make sure that all
|
|
|
|
* the undefined gets a sensible default
|
|
|
|
*/
|
|
|
|
#ifndef _PAGE_HASHPTE
|
|
|
|
#define _PAGE_HASHPTE 0
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_HWWRITE
|
|
|
|
#define _PAGE_HWWRITE 0
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_EXEC
|
|
|
|
#define _PAGE_EXEC 0
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_ENDIAN
|
|
|
|
#define _PAGE_ENDIAN 0
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_COHERENT
|
|
|
|
#define _PAGE_COHERENT 0
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_WRITETHRU
|
|
|
|
#define _PAGE_WRITETHRU 0
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_4K_PFN
|
|
|
|
#define _PAGE_4K_PFN 0
|
|
|
|
#endif
|
2009-07-28 01:59:34 +00:00
|
|
|
#ifndef _PAGE_SAO
|
|
|
|
#define _PAGE_SAO 0
|
|
|
|
#endif
|
2009-03-19 19:34:09 +00:00
|
|
|
#ifndef _PAGE_PSIZE
|
|
|
|
#define _PAGE_PSIZE 0
|
|
|
|
#endif
|
2015-01-19 16:04:38 +00:00
|
|
|
/* _PAGE_RO and _PAGE_RW shall not be defined at the same time */
|
|
|
|
#ifndef _PAGE_RO
|
|
|
|
#define _PAGE_RO 0
|
|
|
|
#else
|
|
|
|
#define _PAGE_RW 0
|
|
|
|
#endif
|
2015-12-01 03:36:54 +00:00
|
|
|
|
|
|
|
#ifndef _PAGE_PTE
|
|
|
|
#define _PAGE_PTE 0
|
|
|
|
#endif
|
2018-01-12 12:45:27 +00:00
|
|
|
/* At least one of _PAGE_PRIVILEGED or _PAGE_USER must be defined */
|
|
|
|
#ifndef _PAGE_PRIVILEGED
|
|
|
|
#define _PAGE_PRIVILEGED 0
|
|
|
|
#else
|
|
|
|
#ifndef _PAGE_USER
|
|
|
|
#define _PAGE_USER 0
|
|
|
|
#endif
|
|
|
|
#endif
|
2018-01-12 12:45:29 +00:00
|
|
|
#ifndef _PAGE_NA
|
|
|
|
#define _PAGE_NA 0
|
|
|
|
#endif
|
2018-01-12 12:45:31 +00:00
|
|
|
#ifndef _PAGE_HUGE
|
|
|
|
#define _PAGE_HUGE 0
|
|
|
|
#endif
|
2015-12-01 03:36:54 +00:00
|
|
|
|
2009-03-19 19:34:09 +00:00
|
|
|
#ifndef _PMD_PRESENT_MASK
|
|
|
|
#define _PMD_PRESENT_MASK _PMD_PRESENT
|
|
|
|
#endif
|
|
|
|
#ifndef _PMD_SIZE
|
|
|
|
#define _PMD_SIZE 0
|
|
|
|
#define PMD_PAGE_SIZE(pmd) bad_call_to_PMD_PAGE_SIZE()
|
|
|
|
#endif
|
2018-01-12 12:45:31 +00:00
|
|
|
#ifndef _PMD_USER
|
|
|
|
#define _PMD_USER 0
|
|
|
|
#endif
|
2009-03-19 19:34:09 +00:00
|
|
|
#ifndef _PAGE_KERNEL_RO
|
2018-01-12 12:45:27 +00:00
|
|
|
#define _PAGE_KERNEL_RO (_PAGE_PRIVILEGED | _PAGE_RO)
|
2009-08-18 19:00:34 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_KERNEL_ROX
|
2018-01-12 12:45:27 +00:00
|
|
|
#define _PAGE_KERNEL_ROX (_PAGE_PRIVILEGED | _PAGE_RO | _PAGE_EXEC)
|
2009-03-19 19:34:09 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_KERNEL_RW
|
2018-01-12 12:45:27 +00:00
|
|
|
#define _PAGE_KERNEL_RW (_PAGE_PRIVILEGED | _PAGE_DIRTY | _PAGE_RW | \
|
|
|
|
_PAGE_HWWRITE)
|
2009-08-18 19:00:34 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_KERNEL_RWX
|
2018-01-12 12:45:27 +00:00
|
|
|
#define _PAGE_KERNEL_RWX (_PAGE_PRIVILEGED | _PAGE_DIRTY | _PAGE_RW | \
|
|
|
|
_PAGE_HWWRITE | _PAGE_EXEC)
|
2009-03-19 19:34:09 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _PAGE_HPTEFLAGS
|
|
|
|
#define _PAGE_HPTEFLAGS _PAGE_HASHPTE
|
|
|
|
#endif
|
|
|
|
#ifndef _PTE_NONE_MASK
|
|
|
|
#define _PTE_NONE_MASK _PAGE_HPTEFLAGS
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Make sure we get a link error if PMD_PAGE_SIZE is ever called on a
|
|
|
|
* kernel without large page PMD support
|
|
|
|
*/
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
extern unsigned long bad_call_to_PMD_PAGE_SIZE(void);
|
2016-04-29 13:25:32 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Don't just check for any non zero bits in __PAGE_USER, since for book3e
|
|
|
|
* and PTE_64BIT, PAGE_KERNEL_X contains _PAGE_BAP_SR which is also in
|
|
|
|
* _PAGE_USER. Need to explicitly match _PAGE_BAP_UR bit in that case too.
|
|
|
|
*/
|
|
|
|
static inline bool pte_user(pte_t pte)
|
|
|
|
{
|
2018-01-12 12:45:27 +00:00
|
|
|
return (pte_val(pte) & (_PAGE_USER | _PAGE_PRIVILEGED)) == _PAGE_USER;
|
2016-04-29 13:25:32 +00:00
|
|
|
}
|
2009-03-19 19:34:09 +00:00
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
|
|
|
|
/* Location of the PFN in the PTE. Most 32-bit platforms use the same
|
|
|
|
* as _PAGE_SHIFT here (ie, naturally aligned).
|
|
|
|
* Platform who don't just pre-define the value so we don't override it here
|
|
|
|
*/
|
|
|
|
#ifndef PTE_RPN_SHIFT
|
|
|
|
#define PTE_RPN_SHIFT (PAGE_SHIFT)
|
|
|
|
#endif
|
|
|
|
|
2016-06-01 06:34:37 +00:00
|
|
|
/* The mask covered by the RPN must be a ULL on 32-bit platforms with
|
2009-03-19 19:34:09 +00:00
|
|
|
* 64-bit PTEs
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_PPC32) && defined(CONFIG_PTE_64BIT)
|
|
|
|
#define PTE_RPN_MASK (~((1ULL<<PTE_RPN_SHIFT)-1))
|
|
|
|
#else
|
|
|
|
#define PTE_RPN_MASK (~((1UL<<PTE_RPN_SHIFT)-1))
|
|
|
|
#endif
|
|
|
|
|
2011-03-31 01:57:33 +00:00
|
|
|
/* _PAGE_CHG_MASK masks of bits that are to be preserved across
|
2009-03-19 19:34:09 +00:00
|
|
|
* pgprot changes
|
|
|
|
*/
|
|
|
|
#define _PAGE_CHG_MASK (PTE_RPN_MASK | _PAGE_HPTEFLAGS | _PAGE_DIRTY | \
|
|
|
|
_PAGE_ACCESSED | _PAGE_SPECIAL)
|
|
|
|
|
|
|
|
/* Mask of bits returned by pte_pgprot() */
|
|
|
|
#define PAGE_PROT_BITS (_PAGE_GUARDED | _PAGE_COHERENT | _PAGE_NO_CACHE | \
|
|
|
|
_PAGE_WRITETHRU | _PAGE_ENDIAN | _PAGE_4K_PFN | \
|
2018-01-12 12:45:29 +00:00
|
|
|
_PAGE_USER | _PAGE_ACCESSED | _PAGE_RO | _PAGE_NA | \
|
2018-01-12 12:45:27 +00:00
|
|
|
_PAGE_PRIVILEGED | \
|
2009-08-18 19:00:34 +00:00
|
|
|
_PAGE_RW | _PAGE_HWWRITE | _PAGE_DIRTY | _PAGE_EXEC)
|
2009-03-19 19:34:09 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* We define 2 sets of base prot bits, one for basic pages (ie,
|
|
|
|
* cacheable kernel and user pages) and one for non cacheable
|
|
|
|
* pages. We always set _PAGE_COHERENT when SMP is enabled or
|
|
|
|
* the processor might need it for DMA coherency.
|
|
|
|
*/
|
|
|
|
#define _PAGE_BASE_NC (_PAGE_PRESENT | _PAGE_ACCESSED | _PAGE_PSIZE)
|
2015-07-18 19:24:58 +00:00
|
|
|
#if defined(CONFIG_SMP) || defined(CONFIG_PPC_STD_MMU) || \
|
|
|
|
defined(CONFIG_PPC_E500MC)
|
2009-03-19 19:34:09 +00:00
|
|
|
#define _PAGE_BASE (_PAGE_BASE_NC | _PAGE_COHERENT)
|
|
|
|
#else
|
|
|
|
#define _PAGE_BASE (_PAGE_BASE_NC)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Permission masks used to generate the __P and __S table,
|
|
|
|
*
|
|
|
|
* Note:__pgprot is defined in arch/powerpc/include/asm/page.h
|
|
|
|
*
|
|
|
|
* Write permissions imply read permissions for now (we could make write-only
|
|
|
|
* pages on BookE but we don't bother for now). Execute permission control is
|
|
|
|
* possible on platforms that define _PAGE_EXEC
|
|
|
|
*
|
|
|
|
* Note due to the way vm flags are laid out, the bits are XWR
|
|
|
|
*/
|
2018-01-12 12:45:29 +00:00
|
|
|
#define PAGE_NONE __pgprot(_PAGE_BASE | _PAGE_NA)
|
2009-03-19 19:34:09 +00:00
|
|
|
#define PAGE_SHARED __pgprot(_PAGE_BASE | _PAGE_USER | _PAGE_RW)
|
2015-01-19 16:04:38 +00:00
|
|
|
#define PAGE_SHARED_X __pgprot(_PAGE_BASE | _PAGE_USER | _PAGE_RW | \
|
|
|
|
_PAGE_EXEC)
|
|
|
|
#define PAGE_COPY __pgprot(_PAGE_BASE | _PAGE_USER | _PAGE_RO)
|
|
|
|
#define PAGE_COPY_X __pgprot(_PAGE_BASE | _PAGE_USER | _PAGE_RO | \
|
|
|
|
_PAGE_EXEC)
|
|
|
|
#define PAGE_READONLY __pgprot(_PAGE_BASE | _PAGE_USER | _PAGE_RO)
|
|
|
|
#define PAGE_READONLY_X __pgprot(_PAGE_BASE | _PAGE_USER | _PAGE_RO | \
|
|
|
|
_PAGE_EXEC)
|
2009-03-19 19:34:09 +00:00
|
|
|
|
|
|
|
#define __P000 PAGE_NONE
|
|
|
|
#define __P001 PAGE_READONLY
|
|
|
|
#define __P010 PAGE_COPY
|
|
|
|
#define __P011 PAGE_COPY
|
|
|
|
#define __P100 PAGE_READONLY_X
|
|
|
|
#define __P101 PAGE_READONLY_X
|
|
|
|
#define __P110 PAGE_COPY_X
|
|
|
|
#define __P111 PAGE_COPY_X
|
|
|
|
|
|
|
|
#define __S000 PAGE_NONE
|
|
|
|
#define __S001 PAGE_READONLY
|
|
|
|
#define __S010 PAGE_SHARED
|
|
|
|
#define __S011 PAGE_SHARED
|
|
|
|
#define __S100 PAGE_READONLY_X
|
|
|
|
#define __S101 PAGE_READONLY_X
|
|
|
|
#define __S110 PAGE_SHARED_X
|
|
|
|
#define __S111 PAGE_SHARED_X
|
|
|
|
|
|
|
|
/* Permission masks used for kernel mappings */
|
|
|
|
#define PAGE_KERNEL __pgprot(_PAGE_BASE | _PAGE_KERNEL_RW)
|
|
|
|
#define PAGE_KERNEL_NC __pgprot(_PAGE_BASE_NC | _PAGE_KERNEL_RW | \
|
|
|
|
_PAGE_NO_CACHE)
|
|
|
|
#define PAGE_KERNEL_NCG __pgprot(_PAGE_BASE_NC | _PAGE_KERNEL_RW | \
|
|
|
|
_PAGE_NO_CACHE | _PAGE_GUARDED)
|
2009-08-18 19:00:34 +00:00
|
|
|
#define PAGE_KERNEL_X __pgprot(_PAGE_BASE | _PAGE_KERNEL_RWX)
|
2009-03-19 19:34:09 +00:00
|
|
|
#define PAGE_KERNEL_RO __pgprot(_PAGE_BASE | _PAGE_KERNEL_RO)
|
2009-08-18 19:00:34 +00:00
|
|
|
#define PAGE_KERNEL_ROX __pgprot(_PAGE_BASE | _PAGE_KERNEL_ROX)
|
2009-03-19 19:34:09 +00:00
|
|
|
|
|
|
|
/* Protection used for kernel text. We want the debuggers to be able to
|
|
|
|
* set breakpoints anywhere, so don't write protect the kernel text
|
|
|
|
* on platforms where such control is possible.
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_KGDB) || defined(CONFIG_XMON) || defined(CONFIG_BDI_SWITCH) ||\
|
2011-04-14 23:49:53 +00:00
|
|
|
defined(CONFIG_KPROBES) || defined(CONFIG_DYNAMIC_FTRACE)
|
2009-03-19 19:34:09 +00:00
|
|
|
#define PAGE_KERNEL_TEXT PAGE_KERNEL_X
|
|
|
|
#else
|
|
|
|
#define PAGE_KERNEL_TEXT PAGE_KERNEL_ROX
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Make modules code happy. We don't set RO yet */
|
|
|
|
#define PAGE_KERNEL_EXEC PAGE_KERNEL_X
|
|
|
|
|
|
|
|
/* Advertise special mapping type for AGP */
|
|
|
|
#define PAGE_AGP (PAGE_KERNEL_NC)
|
|
|
|
#define HAVE_PAGE_AGP
|
|
|
|
|
|
|
|
/* Advertise support for _PAGE_SPECIAL */
|
|
|
|
#define __HAVE_ARCH_PTE_SPECIAL
|
|
|
|
|
2016-04-29 13:25:30 +00:00
|
|
|
#ifndef _PAGE_READ
|
|
|
|
/* if not defined, we should not find _PAGE_WRITE too */
|
|
|
|
#define _PAGE_READ 0
|
|
|
|
#define _PAGE_WRITE _PAGE_RW
|
|
|
|
#endif
|
2016-04-29 13:25:45 +00:00
|
|
|
|
|
|
|
#ifndef H_PAGE_4K_PFN
|
|
|
|
#define H_PAGE_4K_PFN 0
|
|
|
|
#endif
|