1f08c3bdfSopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 2f08c3bdfSopenharmony_ci/* 3f08c3bdfSopenharmony_ci * Copyright (c) Wipro Technologies Ltd, 2002. All Rights Reserved. 4f08c3bdfSopenharmony_ci * Copyright (c) 2018 Xiao Yang <yangx.jy@cn.fujitsu.com> 5f08c3bdfSopenharmony_ci */ 6f08c3bdfSopenharmony_ci 7f08c3bdfSopenharmony_ci/* 8f08c3bdfSopenharmony_ci * AUTHOR: Madhu T L <madhu.tarikere@wipro.com> 9f08c3bdfSopenharmony_ci * 10f08c3bdfSopenharmony_ci * DESCRIPTION 11f08c3bdfSopenharmony_ci * Verify that, delete_module(2) returns -1 and sets errno to EWOULDBLOCK, 12f08c3bdfSopenharmony_ci * if tried to remove a module while other modules depend on this module. 13f08c3bdfSopenharmony_ci */ 14f08c3bdfSopenharmony_ci 15f08c3bdfSopenharmony_ci#include <errno.h> 16f08c3bdfSopenharmony_ci#include "tst_test.h" 17f08c3bdfSopenharmony_ci#include "tst_module.h" 18f08c3bdfSopenharmony_ci#include "lapi/syscalls.h" 19f08c3bdfSopenharmony_ci 20f08c3bdfSopenharmony_ci#define DUMMY_MOD "dummy_del_mod" 21f08c3bdfSopenharmony_ci#define DUMMY_MOD_KO "dummy_del_mod.ko" 22f08c3bdfSopenharmony_ci#define DUMMY_MOD_DEP_KO "dummy_del_mod_dep.ko" 23f08c3bdfSopenharmony_ci 24f08c3bdfSopenharmony_cistatic int dummy_mod_loaded; 25f08c3bdfSopenharmony_cistatic int dummy_mod_dep_loaded; 26f08c3bdfSopenharmony_ci 27f08c3bdfSopenharmony_cistatic void do_delete_module(void) 28f08c3bdfSopenharmony_ci{ 29f08c3bdfSopenharmony_ci TEST(tst_syscall(__NR_delete_module, DUMMY_MOD, 0)); 30f08c3bdfSopenharmony_ci if (TST_RET < 0) { 31f08c3bdfSopenharmony_ci if (TST_ERR == EWOULDBLOCK) { 32f08c3bdfSopenharmony_ci tst_res(TPASS | TTERRNO, 33f08c3bdfSopenharmony_ci "delete_module() failed as expected"); 34f08c3bdfSopenharmony_ci } else { 35f08c3bdfSopenharmony_ci tst_res(TFAIL | TTERRNO, "delete_module() failed " 36f08c3bdfSopenharmony_ci "unexpectedly; expected: %s", 37f08c3bdfSopenharmony_ci tst_strerrno(EWOULDBLOCK)); 38f08c3bdfSopenharmony_ci } 39f08c3bdfSopenharmony_ci } else { 40f08c3bdfSopenharmony_ci tst_res(TFAIL, "delete_module() succeeded unexpectedly"); 41f08c3bdfSopenharmony_ci dummy_mod_loaded = 0; 42f08c3bdfSopenharmony_ci /* 43f08c3bdfSopenharmony_ci * insmod DUMMY_MOD_KO again in case running 44f08c3bdfSopenharmony_ci * with -i option 45f08c3bdfSopenharmony_ci */ 46f08c3bdfSopenharmony_ci tst_module_load(DUMMY_MOD_KO, NULL); 47f08c3bdfSopenharmony_ci dummy_mod_loaded = 1; 48f08c3bdfSopenharmony_ci } 49f08c3bdfSopenharmony_ci} 50f08c3bdfSopenharmony_ci 51f08c3bdfSopenharmony_cistatic void setup(void) 52f08c3bdfSopenharmony_ci{ 53f08c3bdfSopenharmony_ci /* Load first kernel module */ 54f08c3bdfSopenharmony_ci tst_module_load(DUMMY_MOD_KO, NULL); 55f08c3bdfSopenharmony_ci dummy_mod_loaded = 1; 56f08c3bdfSopenharmony_ci 57f08c3bdfSopenharmony_ci /* Load dependant kernel module */ 58f08c3bdfSopenharmony_ci tst_module_load(DUMMY_MOD_DEP_KO, NULL); 59f08c3bdfSopenharmony_ci dummy_mod_dep_loaded = 1; 60f08c3bdfSopenharmony_ci} 61f08c3bdfSopenharmony_ci 62f08c3bdfSopenharmony_cistatic void cleanup(void) 63f08c3bdfSopenharmony_ci{ 64f08c3bdfSopenharmony_ci /* Unload dependent kernel module */ 65f08c3bdfSopenharmony_ci if (dummy_mod_dep_loaded == 1) 66f08c3bdfSopenharmony_ci tst_module_unload(DUMMY_MOD_DEP_KO); 67f08c3bdfSopenharmony_ci 68f08c3bdfSopenharmony_ci /* Unload first kernel module */ 69f08c3bdfSopenharmony_ci if (dummy_mod_loaded == 1) 70f08c3bdfSopenharmony_ci tst_module_unload(DUMMY_MOD_KO); 71f08c3bdfSopenharmony_ci} 72f08c3bdfSopenharmony_ci 73f08c3bdfSopenharmony_cistatic struct tst_test test = { 74f08c3bdfSopenharmony_ci .needs_root = 1, 75f08c3bdfSopenharmony_ci /* lockdown and SecureBoot requires signed modules */ 76f08c3bdfSopenharmony_ci .skip_in_lockdown = 1, 77f08c3bdfSopenharmony_ci .skip_in_secureboot = 1, 78f08c3bdfSopenharmony_ci .setup = setup, 79f08c3bdfSopenharmony_ci .cleanup = cleanup, 80f08c3bdfSopenharmony_ci .test_all = do_delete_module, 81f08c3bdfSopenharmony_ci}; 82