Skip to content
Snippets Groups Projects
Select Git revision
  • f1f0f330b1d0ac1bcc38d7c84d439f4fde341a9c
  • master default
  • b4/phy-realtek-clock-fix
  • b4/rk3576-rock4d-phy-timings
  • b4/dw-wdt-fix-initial-timeout
  • radxa-v6.1-vendor-kernel
  • b4/fusb302-race-condition-fix
  • b4/rk3576-rock4d-phy-handling-fixes
  • b4/rk3588-evb1-hdmi-rx
  • b4/rk3576-fix-fspi-pmdomain
  • b4/usbc-for-rock5bp
  • b4/rock5bp-for-upstream
  • rockchip-devel
  • rk3588-test
  • rk3588-test-vendor-cam
  • lf-6.6.y_6.6.23-2.0.0_var01-panfrost
  • rk3588-linked-clk-gate-for-upstream
  • rk3588-gpu-pwr-domain-for-upstream
  • rk3588-rock5b-usbc-for-upstream
  • rk3588-evb1-for-upstream
  • imx95-upstream-with-vendor-display-stack
  • v5.17
  • v5.17-rc8
  • v5.17-rc7
  • v5.17-rc6
  • v5.17-rc5
  • v5.17-rc4
  • v5.17-rc3
  • v5.17-rc2
  • v5.17-rc1
  • v5.16
  • v5.16-rc8
  • v5.16-rc7
  • v5.16-rc6
  • v5.16-rc5
  • v5.16-rc4
  • v5.16-rc3
  • v5.16-rc2
  • v5.16-rc1
  • v5.15
  • v5.15-rc7
41 results

fips.c

Blame
  • fips.c 1.61 KiB
    /*
     * FIPS 200 support.
     *
     * Copyright (c) 2008 Neil Horman <nhorman@tuxdriver.com>
     *
     * 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.
     *
     */
    
    #include <linux/export.h>
    #include <linux/fips.h>
    #include <linux/init.h>
    #include <linux/module.h>
    #include <linux/kernel.h>
    #include <linux/sysctl.h>
    
    int fips_enabled;
    EXPORT_SYMBOL_GPL(fips_enabled);
    
    /* Process kernel command-line parameter at boot time. fips=0 or fips=1 */
    static int fips_enable(char *str)
    {
    	fips_enabled = !!simple_strtol(str, NULL, 0);
    	printk(KERN_INFO "fips mode: %s\n",
    		fips_enabled ? "enabled" : "disabled");
    	return 1;
    }
    
    __setup("fips=", fips_enable);
    
    static struct ctl_table crypto_sysctl_table[] = {
    	{
    		.procname       = "fips_enabled",
    		.data           = &fips_enabled,
    		.maxlen         = sizeof(int),
    		.mode           = 0444,
    		.proc_handler   = proc_dointvec
    	},
    	{}
    };
    
    static struct ctl_table crypto_dir_table[] = {
    	{
    		.procname       = "crypto",
    		.mode           = 0555,
    		.child          = crypto_sysctl_table
    	},
    	{}
    };
    
    static struct ctl_table_header *crypto_sysctls;
    
    static void crypto_proc_fips_init(void)
    {
    	crypto_sysctls = register_sysctl_table(crypto_dir_table);
    }
    
    static void crypto_proc_fips_exit(void)
    {
    	unregister_sysctl_table(crypto_sysctls);
    }
    
    static int __init fips_init(void)
    {
    	crypto_proc_fips_init();
    	return 0;
    }
    
    static void __exit fips_exit(void)
    {
    	crypto_proc_fips_exit();
    }
    
    module_init(fips_init);
    module_exit(fips_exit);