16
0
Files
kernel-livepatch-SLE16_Upda…/livepatch_main.c
Nicolai Stange 17b1baf4c3 Live patch for a number of CVEs and other issues
Signed-off-by: Nicolai Stange <nstange@suse.de>
2026-01-20 16:29:17 +01:00

284 lines
7.3 KiB
C

/*
* livepatch_main.c - kernel live patch main infrastructure
*
* Copyright (c) 2014 SUSE
* Author: Miroslav Benes <mbenes@suse.cz>
*
* 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/>.
*/
#include <linux/livepatch.h>
#include <linux/module.h>
#include <linux/types.h>
#include "uname_patch/livepatch_uname.h"
/* Auto expanded KLP_PATCHES_INCLUDES: */
#include "bsc1246019/livepatch_bsc1246019.h"
#include "bsc1248301/livepatch_bsc1248301.h"
#include "bsc1248400/livepatch_bsc1248400.h"
#include "bsc1248631/livepatch_bsc1248631.h"
#include "bsc1248670/livepatch_bsc1248670.h"
#include "bsc1248672/livepatch_bsc1248672.h"
#include "bsc1249207/livepatch_bsc1249207.h"
#include "bsc1249208/livepatch_bsc1249208.h"
#include "bsc1249241/livepatch_bsc1249241.h"
#include "bsc1249537/livepatch_bsc1249537.h"
#include "bsc1250192/livepatch_bsc1250192.h"
#include "bsc1251956/livepatch_bsc1251956.h"
#include "bsc1251982/livepatch_bsc1251982.h"
#include "bsc1253437/livepatch_bsc1253437.h"
#include "bsc1254196/livepatch_bsc1254196.h"
static struct klp_object objs[] = {
/* Auto expanded KLP_PATCHES_OBJS: */
{
.name = NULL,
.funcs = (struct klp_func[]) {
{
.old_name = __stringify(KLP_SYSCALL_SYM(newuname)),
.new_func = KLP_SYSCALL_SYM(klp_newuname),
},
#ifdef KLP_ARCH_HAS_SYSCALL_COMPAT_STUBS
{
.old_name = __stringify(KLP_SYSCALL_COMPAT_STUB_SYM(newuname)),
.new_func = KLP_SYSCALL_COMPAT_STUB_SYM(klp_newuname),
},
#endif
{ .old_name = __stringify(lock_vma_under_rcu), .new_func = klpp_lock_vma_under_rcu, },
{ .old_name = __stringify(ipv6_gso_segment), .new_func = klpp_ipv6_gso_segment, },
{ .old_name = __stringify(fib6_add), .new_func = klpp_fib6_add, },
{ .old_name = __stringify(fib6_del), .new_func = klpp_fib6_del, },
{ .old_name = __stringify(rt6_nlmsg_size), .new_func = klpp_rt6_nlmsg_size, },
#if IS_ENABLED(CONFIG_PPC_FTRACE_OUT_OF_LINE)
{ .old_name = __stringify(module_finalize_ftrace), .new_func = klpp_module_finalize_ftrace, },
#endif
{ .old_name = __stringify(io_link_skb), .new_func = klpp_io_link_skb, },
{ }
}
},
{
.name = "af_packet",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(packet_set_ring), .new_func = klpp_packet_set_ring, },
{ }
}
},
#if IS_ENABLED(CONFIG_ICE)
{
.name = "ice",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(ice_copy_and_init_pkg), .new_func = klpp_ice_copy_and_init_pkg, },
{ }
}
},
#endif
{
.name = "nfsd",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(__fh_verify), .new_func = klpp___fh_verify, },
{ }
}
},
{
.name = "sch_cake",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(cake_enqueue), .new_func = klpp_cake_enqueue, },
{ }
}
},
{
.name = "sch_choke",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(choke_enqueue), .new_func = klpp_choke_enqueue, },
{ }
}
},
{
.name = "sctp",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(sctp_unpack_cookie), .new_func = klpp_sctp_unpack_cookie, },
{ .old_name = __stringify(sctp_sf_authenticate), .new_func = klpp_sctp_sf_authenticate, },
{ }
}
},
{
.name = "tls",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(bpf_exec_tx_verdict), .new_func = klpp_bpf_exec_tx_verdict, },
{ .old_name = __stringify(tls_rx_rec_wait), .new_func = klpp_tls_rx_rec_wait, },
{ .old_name = __stringify(tls_sw_recvmsg), .new_func = klpp_tls_sw_recvmsg, },
{ }
}
},
{
.name = "vsock",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(__vsock_bind), .new_func = klpp___vsock_bind, },
{ }
}
},
{
.name = "xfrm_interface",
.funcs = (struct klp_func[]) {
{ .old_name = __stringify(xfrmi_changelink), .new_func = klpp_xfrmi_changelink, },
{ }
}
},
{ }
};
static struct klp_patch patch = {
.mod = THIS_MODULE,
.objs = objs,
.replace = true,
};
static int __init klp_patch_init(void)
{
int retval;
pr_info("livepatch: initializing\n");
/* Auto expanded KLP_PATCHES_INIT_CALLS: */
retval = livepatch_bsc1246019_init();
if (retval)
goto err_bsc1246019;
retval = livepatch_bsc1248301_init();
if (retval)
goto err_bsc1248301;
retval = livepatch_bsc1248400_init();
if (retval)
goto err_bsc1248400;
retval = livepatch_bsc1248631_init();
if (retval)
goto err_bsc1248631;
retval = livepatch_bsc1248670_init();
if (retval)
goto err_bsc1248670;
retval = livepatch_bsc1248672_init();
if (retval)
goto err_bsc1248672;
retval = livepatch_bsc1249207_init();
if (retval)
goto err_bsc1249207;
retval = livepatch_bsc1249208_init();
if (retval)
goto err_bsc1249208;
retval = livepatch_bsc1249241_init();
if (retval)
goto err_bsc1249241;
retval = livepatch_bsc1249537_init();
if (retval)
goto err_bsc1249537;
retval = livepatch_bsc1250192_init();
if (retval)
goto err_bsc1250192;
retval = livepatch_bsc1251956_init();
if (retval)
goto err_bsc1251956;
retval = livepatch_bsc1251982_init();
if (retval)
goto err_bsc1251982;
retval = livepatch_bsc1253437_init();
if (retval)
goto err_bsc1253437;
retval = livepatch_bsc1254196_init();
if (retval)
goto err_bsc1254196;
retval = klp_enable_patch(&patch);
if (!retval)
return retval;
/* Auto expanded KLP_PATCHES_INIT_ERR_HANDLERS: */
livepatch_bsc1254196_cleanup();
err_bsc1254196:
livepatch_bsc1253437_cleanup();
err_bsc1253437:
livepatch_bsc1251982_cleanup();
err_bsc1251982:
livepatch_bsc1251956_cleanup();
err_bsc1251956:
livepatch_bsc1250192_cleanup();
err_bsc1250192:
livepatch_bsc1249537_cleanup();
err_bsc1249537:
livepatch_bsc1249241_cleanup();
err_bsc1249241:
livepatch_bsc1249208_cleanup();
err_bsc1249208:
livepatch_bsc1249207_cleanup();
err_bsc1249207:
livepatch_bsc1248672_cleanup();
err_bsc1248672:
livepatch_bsc1248670_cleanup();
err_bsc1248670:
livepatch_bsc1248631_cleanup();
err_bsc1248631:
livepatch_bsc1248400_cleanup();
err_bsc1248400:
livepatch_bsc1248301_cleanup();
err_bsc1248301:
livepatch_bsc1246019_cleanup();
err_bsc1246019:
return retval;
}
static void __exit klp_patch_cleanup(void)
{
pr_info("livepatch: removed\n");
/* Auto expanded KLP_PATCHES_CLEANUP_CALLS: */
livepatch_bsc1246019_cleanup();
livepatch_bsc1248301_cleanup();
livepatch_bsc1248400_cleanup();
livepatch_bsc1248631_cleanup();
livepatch_bsc1248670_cleanup();
livepatch_bsc1248672_cleanup();
livepatch_bsc1249207_cleanup();
livepatch_bsc1249208_cleanup();
livepatch_bsc1249241_cleanup();
livepatch_bsc1249537_cleanup();
livepatch_bsc1250192_cleanup();
livepatch_bsc1251956_cleanup();
livepatch_bsc1251982_cleanup();
livepatch_bsc1253437_cleanup();
livepatch_bsc1254196_cleanup();
}
module_init(klp_patch_init);
module_exit(klp_patch_cleanup);
MODULE_LICENSE("GPL");
MODULE_INFO(livepatch, "Y");
MODULE_INFO(klpgitrev, "b76639e2355b2b473e2253b5bbbef0343286daea");