__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
// SPDX-License-Identifier: GPL-2.0-only
///Find conditions where if and else branch are functionally
// identical.
//
// There can be false positives in cases where the positional
// information is used (as with lockdep) or where the identity
// is a placeholder for not yet handled cases.
// Unfortunately there also seems to be a tendency to use
// the last if else/else as a "default behavior" - which some
// might consider a legitimate coding pattern. From discussion
// on kernelnewbies though it seems that this is not really an
// accepted pattern and if at all it would need to be commented
//
// In the Linux kernel it does not seem to actually report
// false positives except for those that were documented as
// being intentional.
// the two known cases are:
// arch/sh/kernel/traps_64.c:read_opcode()
// } else if ((pc & 1) == 0) {
// /* SHcompact */
// /* TODO : provide handling for this. We don't really support
// user-mode SHcompact yet, and for a kernel fault, this would
// have to come from a module built for SHcompact. */
// return -EFAULT;
// } else {
// /* misaligned */
// return -EFAULT;
// }
// fs/kernfs/file.c:kernfs_fop_open()
// * Both paths of the branch look the same. They're supposed to
// * look that way and give @of->mutex different static lockdep keys.
// */
// if (has_mmap)
// mutex_init(&of->mutex);
// else
// mutex_init(&of->mutex);
//
// All other cases look like bugs or at least lack of documentation
//
// Confidence: Moderate
// Copyright: (C) 2016 Nicholas Mc Guire, OSADL.
// Comments:
// Options: --no-includes --include-headers
virtual org
virtual report
@cond@
statement S1;
position p;
@@
* if@p (...) S1 else S1
@script:python depends on org@
p << cond.p;
@@
cocci.print_main("WARNING: possible condition with no effect (if == else)",p)
@script:python depends on report@
p << cond.p;
@@
coccilib.report.print_report(p[0],"WARNING: possible condition with no effect (if == else)")
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| add_namespace.cocci | File | 837 B | 0644 |
|
| array_size.cocci | File | 1.69 KB | 0644 |
|
| array_size_dup.cocci | File | 4.78 KB | 0644 |
|
| badty.cocci | File | 1.69 KB | 0644 |
|
| boolconv.cocci | File | 1.47 KB | 0644 |
|
| cond_no_effect.cocci | File | 2.07 KB | 0644 |
|
| cstptr.cocci | File | 873 B | 0644 |
|
| do_div.cocci | File | 3.48 KB | 0644 |
|
| doubleinit.cocci | File | 1.4 KB | 0644 |
|
| excluded_middle.cocci | File | 677 B | 0644 |
|
| flexible_array.cocci | File | 1.78 KB | 0644 |
|
| ifcol.cocci | File | 1.25 KB | 0644 |
|
| irqf_oneshot.cocci | File | 1.96 KB | 0644 |
|
| minmax.cocci | File | 3.19 KB | 0644 |
|
| newline_in_nl_msg.cocci | File | 1.63 KB | 0644 |
|
| noderef.cocci | File | 1.21 KB | 0644 |
|
| of_table.cocci | File | 1.33 KB | 0644 |
|
| orplus.cocci | File | 1.05 KB | 0644 |
|
| returnvar.cocci | File | 1.28 KB | 0644 |
|
| secs_to_jiffies.cocci | File | 452 B | 0644 |
|
| semicolon.cocci | File | 1.09 KB | 0644 |
|
| struct_size.cocci | File | 1.58 KB | 0644 |
|
| swap.cocci | File | 1.48 KB | 0644 |
|
| test_addr.cocci | File | 699 B | 0644 |
|
| uninitialized_var.cocci | File | 1.59 KB | 0644 |
|
| warn.cocci | File | 1.67 KB | 0644 |
|