/* * Copyright (c) 2000-2001, Boris Popov * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by Boris Popov. * 4. Neither the name of the author nor the names of any co-contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $FreeBSD: src/sys/netsmb/smb_subr.h,v 1.1.2.1 2001/05/22 08:32:34 bp Exp $ * $DragonFly: src/sys/netproto/smb/smb_subr.h,v 1.11 2005/02/17 14:00:09 joerg Exp $ */ #ifndef _NETSMB_SMB_SUBR_H_ #define _NETSMB_SMB_SUBR_H_ #ifndef _KERNEL #error "This file shouldn't be included from userland programs" #endif #ifdef MALLOC_DECLARE MALLOC_DECLARE(M_SMBTEMP); #endif /* * For compatibility with 5.x */ #define PDROP PUSRFLAG1 /* OR'd with pri to stop re-entry of interlock mutex */ #define SMBERROR(format, args...) printf("%s: "format, __func__ ,## args) #define SMBPANIC(format, args...) printf("%s: "format, __func__ ,## args) #ifdef SMB_SOCKET_DEBUG #define SMBSDEBUG(format, args...) printf("%s: "format, __func__ ,## args) #else #define SMBSDEBUG(format, args...) #endif #ifdef SMB_IOD_DEBUG #define SMBIODEBUG(format, args...) printf("%s: "format, __func__ ,## args) #else #define SMBIODEBUG(format, args...) #endif #ifdef SMB_SOCKETDATA_DEBUG void m_dumpm(struct mbuf *m); #else #define m_dumpm(m) #endif #define SMB_SIGMASK(set) \ (SIGISMEMBER(set, SIGINT) || SIGISMEMBER(set, SIGTERM) || \ SIGISMEMBER(set, SIGHUP) || SIGISMEMBER(set, SIGKILL) || \ SIGISMEMBER(set, SIGQUIT)) #define smb_suser(cred) suser_cred(cred, 0) #include #define lockdestroy(lock) #define smb_slock lwkt_token #define smb_ilock lwkt_tokref #define smb_sl_init(tok, desc) lwkt_token_init(tok) #define smb_sl_destroy(tok) #define smb_sl_lock(ilock, tok) lwkt_gettoken(ilock, tok) #define smb_sl_unlock(ilock) lwkt_reltoken(ilock) #define SMB_STRFREE(p) do { if (p) smb_strfree(p); } while(0) /* * The simple try/catch/finally interface. * With GCC it is possible to allow more than one try/finally block per * function, but we'll avoid it to maintain portability. */ #define itry { \ __label__ _finlab, _catchlab; \ int _tval; \ #define icatch(var) \ goto _finlab; \ (void)&&_catchlab; \ _catchlab: \ var = _tval; #define ifinally (void)&&_finlab; \ _finlab: #define iendtry } #define inocatch \ goto _finlab; \ (void)&&_catchlab; \ _catchlab: \ #define ithrow(t) do { \ if ((_tval = (int)(t)) != 0) \ goto _catchlab; \ } while (0) #define ierror(t,e) do { \ if (t) { \ _tval = e; \ goto _catchlab; \ } \ } while (0) typedef u_int16_t smb_unichar; typedef smb_unichar *smb_uniptr; /* * Crediantials of user/process being processing in the connection procedures */ struct smb_cred { struct thread * scr_td; struct ucred * scr_cred; }; extern smb_unichar smb_unieol; struct mbchain; struct proc; struct thread; struct lwkt_tokref; struct lwkt_rwlock; struct smb_vc; struct smb_rq; void smb_makescred(struct smb_cred *scred, struct thread *td, struct ucred *cred); int smb_proc_intr(struct thread *td); char *smb_strdup(const char *s); void *smb_memdup(const void *umem, int len); char *smb_strdupin(char *s, int maxlen); void *smb_memdupin(void *umem, int len); void smb_strtouni(u_int16_t *dst, const char *src); void smb_strfree(char *s); void smb_memfree(void *s); void *smb_zmalloc(unsigned long size, struct malloc_type *type, int flags); int smb_encrypt(const u_char *apwd, u_char *C8, u_char *RN); int smb_ntencrypt(const u_char *apwd, u_char *C8, u_char *RN); int smb_maperror(int eclass, int eno); int smb_put_dmem(struct mbchain *mbp, struct smb_vc *vcp, const char *src, int len, int caseopt); int smb_put_dstring(struct mbchain *mbp, struct smb_vc *vcp, const char *src, int caseopt); int smb_put_string(struct smb_rq *rqp, const char *src); int smb_put_asunistring(struct smb_rq *rqp, const char *src); /* * Compatibilty with 5.x functions */ int kthread_create2(void (*func)(void *), void *arg, struct proc **newpp, int flags, const char *fmt, ...); void kthread_exit2(void); int smb_sleep(void *chan, struct lwkt_tokref *ilock, int slpflags, const char *wmesg, int timo); #endif /* !_NETSMB_SMB_SUBR_H_ */