]> git.baikalelectronics.ru Git - kernel.git/commit
error-injection: Add injectable error types
authorMasami Hiramatsu <mhiramat@kernel.org>
Fri, 12 Jan 2018 17:55:33 +0000 (02:55 +0900)
committerAlexei Starovoitov <ast@kernel.org>
Sat, 13 Jan 2018 01:33:38 +0000 (17:33 -0800)
commit24e0d282a2bfc32b3cd2b738418f057426651636
tree6784344ffd1b031664899d9272aa0005f4584420
parent1e7a1dd547ec366930890c26987d3105c20896cc
error-injection: Add injectable error types

Add injectable error types for each error-injectable function.

One motivation of error injection test is to find software flaws,
mistakes or mis-handlings of expectable errors. If we find such
flaws by the test, that is a program bug, so we need to fix it.

But if the tester miss input the error (e.g. just return success
code without processing anything), it causes unexpected behavior
even if the caller is correctly programmed to handle any errors.
That is not what we want to test by error injection.

To clarify what type of errors the caller must expect for each
injectable function, this introduces injectable error types:

 - EI_ETYPE_NULL : means the function will return NULL if it
    fails. No ERR_PTR, just a NULL.
 - EI_ETYPE_ERRNO : means the function will return -ERRNO
    if it fails.
 - EI_ETYPE_ERRNO_NULL : means the function will return -ERRNO
       (ERR_PTR) or NULL.

ALLOW_ERROR_INJECTION() macro is expanded to get one of
NULL, ERRNO, ERRNO_NULL to record the error type for
each function. e.g.

 ALLOW_ERROR_INJECTION(open_ctree, ERRNO)

This error types are shown in debugfs as below.

  ====
  / # cat /sys/kernel/debug/error_injection/list
  open_ctree [btrfs] ERRNO
  io_ctl_init [btrfs] ERRNO
  ====

Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
Reviewed-by: Josef Bacik <jbacik@fb.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
fs/btrfs/disk-io.c
fs/btrfs/free-space-cache.c
include/asm-generic/error-injection.h
include/asm-generic/vmlinux.lds.h
include/linux/error-injection.h
include/linux/module.h
lib/error-inject.c