2005-04-16 15:20:36 -07:00
/*
* Copyright ( C ) 2003 Christophe Saout < christophe @ saout . de >
*
* This file is released under the GPL .
*/
# include "dm.h"
# include <linux/module.h>
# include <linux/init.h>
# include <linux/bio.h>
2006-06-26 00:27:35 -07:00
# define DM_MSG_PREFIX "zero"
2005-04-16 15:20:36 -07:00
/*
* Construct a dummy mapping that only returns zeros
*/
static int zero_ctr ( struct dm_target * ti , unsigned int argc , char * * argv )
{
if ( argc ! = 0 ) {
2006-06-26 00:27:35 -07:00
ti - > error = " No arguments required " ;
2005-04-16 15:20:36 -07:00
return - EINVAL ;
}
return 0 ;
}
/*
* Return zeros only on reads
*/
static int zero_map ( struct dm_target * ti , struct bio * bio ,
union map_info * map_context )
{
switch ( bio_rw ( bio ) ) {
case READ :
zero_fill_bio ( bio ) ;
break ;
case READA :
/* readahead of null bytes only wastes buffer cache */
return - EIO ;
case WRITE :
/* writes get silently dropped */
break ;
}
bio_endio ( bio , bio - > bi_size , 0 ) ;
/* accepted bio, don't make new request */
return 0 ;
}
static struct target_type zero_target = {
. name = " zero " ,
. version = { 1 , 0 , 0 } ,
. module = THIS_MODULE ,
. ctr = zero_ctr ,
. map = zero_map ,
} ;
2005-05-05 16:16:09 -07:00
static int __init dm_zero_init ( void )
2005-04-16 15:20:36 -07:00
{
int r = dm_register_target ( & zero_target ) ;
if ( r < 0 )
2006-06-26 00:27:35 -07:00
DMERR ( " register failed %d " , r ) ;
2005-04-16 15:20:36 -07:00
return r ;
}
2005-05-05 16:16:09 -07:00
static void __exit dm_zero_exit ( void )
2005-04-16 15:20:36 -07:00
{
int r = dm_unregister_target ( & zero_target ) ;
if ( r < 0 )
2006-06-26 00:27:35 -07:00
DMERR ( " unregister failed %d " , r ) ;
2005-04-16 15:20:36 -07:00
}
module_init ( dm_zero_init )
module_exit ( dm_zero_exit )
MODULE_AUTHOR ( " Christophe Saout <christophe@saout.de> " ) ;
MODULE_DESCRIPTION ( DM_NAME " dummy target returning zeros " ) ;
MODULE_LICENSE ( " GPL " ) ;