/*
* Copyright (c) 2018 Michael Moese <mmoese@suse.de>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/* Usage example
*
* ...
* #include "tst_test.h"
* #include "tst_taint.h"
* ..
* void setup(void)
* {
* ...
* tst_taint_init(TST_TAINT_W | TST_TAINT_D));
* ...
* }
*
* void run(void)
* {
* ...
* . test code here
* ...
* if (tst_taint_check() != 0)
* tst_res(TFAIL, "kernel has issues");
* else
* tst_res(TPASS, "kernel seems to be fine");
* }
*
*
*
* The above code checks, if the kernel issued a warning (TST_TAINT_W)
* or even died (TST_TAINT_D) during test execution.
* If these are set after running a test case, we most likely
* triggered a kernel bug.
*/
#ifndef TST_TAINTED_H__
#define TST_TAINTED_H__
/*
* This are all 17 flags that are present in kernel 4.15
* see kernel/panic.c in kernel sources
*
* Not all of them are valid in all kernel versions.
*/
#define TST_TAINT_G (1 << 0) /* a module with non-GPL license loaded */
#define TST_TAINT_F (1 << 1) /* a module was force-loaded */
#define TST_TAINT_S (1 << 2) /* SMP with Non-SMP kernel */
#define TST_TAINT_R (1 << 3) /* module force unloaded */
#define TST_TAINT_M (1 << 4) /* machine check error occurred */
#define TST_TAINT_B (1 << 5) /* page-release function found bad page */
#define TST_TAINT_U (1 << 6) /* user requested taint flag */
#define TST_TAINT_D (1 << 7) /* kernel died recently - OOPS or BUG */
#define TST_TAINT_A (1 << 8) /* ACPI table has been overwritten */
#define TST_TAINT_W (1 << 9) /* a warning has been issued by kernel */
#define TST_TAINT_C (1 << 10) /* driver from drivers/staging was loaded */
#define TST_TAINT_I (1 << 11) /* working around BIOS/Firmware bug */
#define TST_TAINT_O (1 << 12) /* out of tree module loaded */
#define TST_TAINT_E (1 << 13) /* unsigned module was loaded */
#define TST_TAINT_L (1 << 14) /* A soft lock-up has previously occurred */
#define TST_TAINT_K (1 << 15) /* kernel has been live-patched */
#define TST_TAINT_X (1 << 16) /* auxiliary taint, for distro's use */
/*
* Initialize and prepare support for checking tainted kernel.
*
* supply the mask of TAINT-flags you want to check, for example
* (TST_TAINT_W | TST_TAINT_D) when you want to check if the kernel issued
* a warning or even reported it died.
*
* This function tests if the requested flags are supported on the
* locally running kernel. In case the tainted-flags are already set by
* the kernel, there is no reason to continue and TCONF is generated.
*
* The mask must not be zero.
*/
void tst_taint_init(unsigned int mask);
/*
* check if the tainted flags handed to tst_taint_init() are still not set
* during or after running the test.
* Calling this function is only allowed after tst_taint_init() was called,
* otherwise TBROK will be generated.
*
* returns 0 or a bitmask of the flags that currently tainted the kernel.
*/
unsigned int tst_taint_check(void);
#endif /* TST_TAINTED_H__ */