2008-12-02 20:15:34 -08:00
/*
* Unix SMB / CIFS implementation .
* Support for OneFS
*
* Copyright ( C ) Steven Danneman , 2008
*
* 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 3 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/>.
*/
# ifndef _ONEFS_H
# define _ONEFS_H
2008-12-08 16:57:58 -08:00
/*
* vfs interface handlers
*/
2009-01-26 20:14:32 -08:00
SMB_STRUCT_DIR * onefs_opendir ( struct vfs_handle_struct * handle ,
const char * fname , const char * mask ,
uint32 attributes ) ;
SMB_STRUCT_DIRENT * onefs_readdir ( struct vfs_handle_struct * handle ,
SMB_STRUCT_DIR * dirp , SMB_STRUCT_STAT * sbuf ) ;
void onefs_seekdir ( struct vfs_handle_struct * handle , SMB_STRUCT_DIR * dirp ,
long offset ) ;
long onefs_telldir ( struct vfs_handle_struct * handle , SMB_STRUCT_DIR * dirp ) ;
void onefs_rewinddir ( struct vfs_handle_struct * handle , SMB_STRUCT_DIR * dirp ) ;
int onefs_closedir ( struct vfs_handle_struct * handle , SMB_STRUCT_DIR * dir ) ;
void onefs_init_search_op ( struct vfs_handle_struct * handle ,
SMB_STRUCT_DIR * dirp ) ;
2008-12-08 16:57:58 -08:00
NTSTATUS onefs_create_file ( vfs_handle_struct * handle ,
struct smb_request * req ,
uint16_t root_dir_fid ,
2009-06-15 12:13:31 -07:00
struct smb_filename * smb_fname ,
2008-12-08 16:57:58 -08:00
uint32_t access_mask ,
uint32_t share_access ,
uint32_t create_disposition ,
uint32_t create_options ,
uint32_t file_attributes ,
uint32_t oplock_request ,
uint64_t allocation_size ,
struct security_descriptor * sd ,
struct ea_list * ea_list ,
files_struct * * result ,
2009-06-15 12:13:31 -07:00
int * pinfo ) ;
2008-12-08 16:57:58 -08:00
2008-12-12 14:32:48 -08:00
int onefs_close ( vfs_handle_struct * handle , struct files_struct * fsp ) ;
2009-06-30 17:04:38 -07:00
int onefs_rename ( vfs_handle_struct * handle ,
const struct smb_filename * smb_fname_src ,
const struct smb_filename * smb_fname_dst ) ;
2008-12-12 14:32:48 -08:00
2009-06-25 11:20:36 -07:00
int onefs_stat ( vfs_handle_struct * handle , struct smb_filename * smb_fname ) ;
2008-12-12 14:32:48 -08:00
int onefs_fstat ( vfs_handle_struct * handle , struct files_struct * fsp ,
SMB_STRUCT_STAT * sbuf ) ;
2009-06-25 11:20:36 -07:00
int onefs_lstat ( vfs_handle_struct * handle , struct smb_filename * smb_fname ) ;
2008-12-12 14:32:48 -08:00
2009-07-06 15:44:09 -07:00
int onefs_unlink ( vfs_handle_struct * handle ,
const struct smb_filename * smb_fname ) ;
2008-12-12 14:32:48 -08:00
NTSTATUS onefs_streaminfo ( vfs_handle_struct * handle ,
struct files_struct * fsp ,
const char * fname ,
TALLOC_CTX * mem_ctx ,
unsigned int * num_streams ,
struct stream_struct * * streams ) ;
2009-07-06 15:44:09 -07:00
int onefs_vtimes_streams ( vfs_handle_struct * handle ,
const struct smb_filename * smb_fname ,
2009-01-23 16:55:18 -08:00
int flags , struct timespec times [ 3 ] ) ;
OneFS implementation of BRL VFS ops:
* Much of the beginning should look familiar, as I re-used the OneFS oplock
callback record concept. This was necessary to keep our own state around - it
really only consists of a lock state, per asynchronous lock that is currently
unsatisfied. The onefs_cbrl_callback_records map to BLRs by the id.
* There are 4 states an async lock can be in. NONE means there is no async
currently out for the lock, as opposed to ASYNC. DONE means we've locked
*every* lock (keep in mind a request can ask for multiple locks at a time.)
ERROR is an error.
* onefs_cbrl_async_success: The lock_num is incremented, and the state changed,
so that when process_blocking_lock_queue is run, we will try the *next* lock,
rather than the same one again.
* onefs_brl_lock_windows() has some complicated logic:
* We do a no-op if we're passed a BLR and the matching state is ASYNC --
this means Samba is trying to get the same lock twice, and we just need
to wait longer, so we return an error.
* PENDING lock calls happen when the lock is being queued on the BLQ -- we
do async in this case.
* We also do async in the case that we're passed a BLR, but the lock is not
pending. This is an async lock being probed by process_blocking_lock_queue.
* We do a sync lock for any normal first request of a lock.
* Failure is returned, but it doesn't go to the client unless the lock has
actually timed out.
2009-02-09 21:54:51 -08:00
NTSTATUS onefs_brl_lock_windows ( vfs_handle_struct * handle ,
struct byte_range_lock * br_lck ,
struct lock_struct * plock ,
bool blocking_lock ,
struct blocking_lock_record * blr ) ;
bool onefs_brl_unlock_windows ( vfs_handle_struct * handle ,
struct messaging_context * msg_ctx ,
struct byte_range_lock * br_lck ,
const struct lock_struct * plock ) ;
bool onefs_brl_cancel_windows ( vfs_handle_struct * handle ,
struct byte_range_lock * br_lck ,
struct lock_struct * plock ,
struct blocking_lock_record * blr ) ;
2009-03-13 14:21:40 -07:00
bool onefs_strict_lock ( vfs_handle_struct * handle ,
files_struct * fsp ,
struct lock_struct * plock ) ;
void onefs_strict_unlock ( vfs_handle_struct * handle ,
files_struct * fsp ,
struct lock_struct * plock ) ;
2009-02-20 13:25:17 -08:00
NTSTATUS onefs_notify_watch ( vfs_handle_struct * vfs_handle ,
struct sys_notify_context * ctx ,
struct notify_entry * e ,
void ( * callback ) ( struct sys_notify_context * ctx ,
void * private_data ,
struct notify_event * ev ) ,
void * private_data ,
void * handle_p ) ;
2008-12-08 16:57:58 -08:00
NTSTATUS onefs_fget_nt_acl ( vfs_handle_struct * handle , files_struct * fsp ,
2010-05-18 10:29:34 +02:00
uint32 security_info , struct security_descriptor * * ppdesc ) ;
2008-12-08 16:57:58 -08:00
NTSTATUS onefs_get_nt_acl ( vfs_handle_struct * handle , const char * name ,
2010-05-18 10:29:34 +02:00
uint32 security_info , struct security_descriptor * * ppdesc ) ;
2008-12-08 16:57:58 -08:00
NTSTATUS onefs_fset_nt_acl ( vfs_handle_struct * handle , files_struct * fsp ,
2010-05-18 10:29:34 +02:00
uint32 security_info_sent ,
const struct security_descriptor * psd ) ;
OneFS implementation of BRL VFS ops:
* Much of the beginning should look familiar, as I re-used the OneFS oplock
callback record concept. This was necessary to keep our own state around - it
really only consists of a lock state, per asynchronous lock that is currently
unsatisfied. The onefs_cbrl_callback_records map to BLRs by the id.
* There are 4 states an async lock can be in. NONE means there is no async
currently out for the lock, as opposed to ASYNC. DONE means we've locked
*every* lock (keep in mind a request can ask for multiple locks at a time.)
ERROR is an error.
* onefs_cbrl_async_success: The lock_num is incremented, and the state changed,
so that when process_blocking_lock_queue is run, we will try the *next* lock,
rather than the same one again.
* onefs_brl_lock_windows() has some complicated logic:
* We do a no-op if we're passed a BLR and the matching state is ASYNC --
this means Samba is trying to get the same lock twice, and we just need
to wait longer, so we return an error.
* PENDING lock calls happen when the lock is being queued on the BLQ -- we
do async in this case.
* We also do async in the case that we're passed a BLR, but the lock is not
pending. This is an async lock being probed by process_blocking_lock_queue.
* We do a sync lock for any normal first request of a lock.
* Failure is returned, but it doesn't go to the client unless the lock has
actually timed out.
2009-02-09 21:54:51 -08:00
2008-12-08 16:57:58 -08:00
/*
* Utility functions
*/
2009-02-27 14:47:47 -08:00
struct ifs_security_descriptor ;
2010-05-18 10:29:34 +02:00
NTSTATUS onefs_samba_sd_to_sd ( uint32_t security_info_sent ,
const struct security_descriptor * psd ,
2009-05-12 17:38:10 -07:00
struct ifs_security_descriptor * sd , int snum ,
uint32_t * security_info_effective ) ;
2008-12-08 16:57:58 -08:00
2009-06-25 11:20:36 -07:00
NTSTATUS onefs_stream_prep_smb_fname ( TALLOC_CTX * ctx ,
const struct smb_filename * smb_fname_in ,
struct smb_filename * * smb_fname_out ) ;
2009-02-18 17:36:25 -08:00
int onefs_rdp_add_dir_state ( connection_struct * conn , SMB_STRUCT_DIR * dirp ) ;
2008-12-08 16:57:58 -08:00
/*
* System Interfaces
*/
int onefs_sys_create_file ( connection_struct * conn ,
int base_fd ,
const char * path ,
uint32_t access_mask ,
uint32_t open_access_mask ,
uint32_t share_access ,
uint32_t create_options ,
int flags ,
mode_t mode ,
int oplock_request ,
uint64_t id ,
struct security_descriptor * sd ,
uint32_t ntfs_flags ,
int * granted_oplock ) ;
2009-02-20 13:27:39 -08:00
ssize_t onefs_sys_sendfile ( connection_struct * conn , int tofd , int fromfd ,
const DATA_BLOB * header , SMB_OFF_T offset ,
size_t count ) ;
2009-02-13 21:36:42 -08:00
ssize_t onefs_sys_recvfile ( int fromfd , int tofd , SMB_OFF_T offset ,
size_t count ) ;
2009-05-28 14:11:43 -07:00
void init_stat_ex_from_onefs_stat ( struct stat_ex * dst , const struct stat * src ) ;
int onefs_sys_stat ( const char * fname , SMB_STRUCT_STAT * sbuf ) ;
int onefs_sys_fstat ( int fd , SMB_STRUCT_STAT * sbuf ) ;
int onefs_sys_fstat_at ( int base_fd , const char * fname , SMB_STRUCT_STAT * sbuf ,
int flags ) ;
int onefs_sys_lstat ( const char * fname , SMB_STRUCT_STAT * sbuf ) ;
2008-12-02 20:15:34 -08:00
# endif /* _ONEFS_H */