2006-12-07 07:37:15 +03:00
/*
* Interface between ext4 and JBD
*/
2008-04-30 02:13:32 +04:00
# include "ext4_jbd2.h"
2006-12-07 07:37:15 +03:00
int __ext4_journal_get_undo_access ( const char * where , handle_t * handle ,
struct buffer_head * bh )
{
2009-01-07 08:06:22 +03:00
int err = 0 ;
if ( ext4_handle_valid ( handle ) ) {
err = jbd2_journal_get_undo_access ( handle , bh ) ;
if ( err )
ext4_journal_abort_handle ( where , __func__ , bh ,
handle , err ) ;
}
2006-12-07 07:37:15 +03:00
return err ;
}
int __ext4_journal_get_write_access ( const char * where , handle_t * handle ,
struct buffer_head * bh )
{
2009-01-07 08:06:22 +03:00
int err = 0 ;
if ( ext4_handle_valid ( handle ) ) {
err = jbd2_journal_get_write_access ( handle , bh ) ;
if ( err )
ext4_journal_abort_handle ( where , __func__ , bh ,
handle , err ) ;
}
2006-12-07 07:37:15 +03:00
return err ;
}
int __ext4_journal_forget ( const char * where , handle_t * handle ,
struct buffer_head * bh )
{
2009-01-07 08:06:22 +03:00
int err = 0 ;
if ( ext4_handle_valid ( handle ) ) {
err = jbd2_journal_forget ( handle , bh ) ;
if ( err )
ext4_journal_abort_handle ( where , __func__ , bh ,
handle , err ) ;
}
2009-07-13 17:07:20 +04:00
else
brelse ( bh ) ;
2006-12-07 07:37:15 +03:00
return err ;
}
int __ext4_journal_revoke ( const char * where , handle_t * handle ,
ext4_fsblk_t blocknr , struct buffer_head * bh )
{
2009-01-07 08:06:22 +03:00
int err = 0 ;
if ( ext4_handle_valid ( handle ) ) {
err = jbd2_journal_revoke ( handle , blocknr , bh ) ;
if ( err )
ext4_journal_abort_handle ( where , __func__ , bh ,
handle , err ) ;
}
2009-07-13 17:07:20 +04:00
else
brelse ( bh ) ;
2006-12-07 07:37:15 +03:00
return err ;
}
int __ext4_journal_get_create_access ( const char * where ,
handle_t * handle , struct buffer_head * bh )
{
2009-01-07 08:06:22 +03:00
int err = 0 ;
if ( ext4_handle_valid ( handle ) ) {
err = jbd2_journal_get_create_access ( handle , bh ) ;
if ( err )
ext4_journal_abort_handle ( where , __func__ , bh ,
handle , err ) ;
}
2006-12-07 07:37:15 +03:00
return err ;
}
2009-01-07 08:06:22 +03:00
int __ext4_handle_dirty_metadata ( const char * where , handle_t * handle ,
struct inode * inode , struct buffer_head * bh )
2006-12-07 07:37:15 +03:00
{
2009-01-07 08:06:22 +03:00
int err = 0 ;
if ( ext4_handle_valid ( handle ) ) {
err = jbd2_journal_dirty_metadata ( handle , bh ) ;
if ( err )
ext4_journal_abort_handle ( where , __func__ , bh ,
handle , err ) ;
} else {
mark_buffer_dirty ( bh ) ;
if ( inode & & inode_needs_sync ( inode ) ) {
sync_dirty_buffer ( bh ) ;
if ( buffer_req ( bh ) & & ! buffer_uptodate ( bh ) ) {
ext4_error ( inode - > i_sb , __func__ ,
" IO error syncing inode, "
" inode=%lu, block=%llu " ,
inode - > i_ino ,
( unsigned long long ) bh - > b_blocknr ) ;
err = - EIO ;
}
}
}
2006-12-07 07:37:15 +03:00
return err ;
}