next up previous contents index
Next: System Calls Up: Linux Kernel Module Programming Previous: Talking to Device Files

     
Startup Parameters

In many of the previous examples, we had to hard-wire something into the kernel module, such as the file name for /proc files or the major device number for the device so we can have ioctl's to it. This goes against the grain of the Unix, and Linux, philosophy which is to write flexible program the user can customize.  

The way to tell a program, or a kernel module, something it needs before it can start working is by command line parameters. In the case of kernel modules, we don't get argc and argv -- instead, we get something better. We can define global variables in the kernel module and insmod will fill them for us.    

In this kernel module, we define two of them: str1 and str2. All you need to do is compile the kernel module and then run insmod str1=xxx str2=yyy. When init_module is called, str1 will point to the string `xxx' and str2 to the string `yyy'.  

Warning: There is no type checking on these arguments6.1. If the first character of str1 or str2 is a digit the kernel will fill the variable with the value of the integer, rather than a pointer to the string. If a real life situation you have to check for this.

ex param.c   

 
/* param.c 
 * 
 * Receive command line parameters at module installation
 */

/* Copyright (C) 1998 by Ori Pomerantz */



/* The necessary header files */

/* Standard in kernel modules */
#include <linux/kernel.h>   /* We're doing kernel work */
#include <linux/module.h>   /* Specifically, a module */

/* Deal with CONFIG_MODVERSIONS */
#if CONFIG_MODVERSIONS==1
#define MODVERSIONS
#include <linux/modversions.h>
#endif        

#include <stdio.h>  /* I need NULL */

char *str1, *str2;


/* Initialize the module - show the parameters */
int init_module()
{
  if (str1 == NULL || str2 == NULL)
    printk("Next time, do insmod param str1=<something> str2=<something>\n");
  else
    printk("Strings:%s and %s\n", str1, str2);

  return 0;
}


/* Cleanup */
void cleanup_module()
{
}


next up previous contents index
Next: System Calls Up: Linux Kernel Module Programming Previous: Talking to Device Files
Ori Pomerantz
1999-03-20