r24106: Pass fnum instead of buf/offset into get_rpc_pipe_p
authorVolker Lendecke <vlendec@samba.org>
Tue, 31 Jul 2007 13:14:07 +0000 (13:14 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 17:29:07 +0000 (12:29 -0500)
(This used to be commit eb353412c60fc21a31530d9678505470ffbf11ce)

source3/rpc_server/srv_pipe_hnd.c
source3/smbd/pipes.c
source3/smbd/trans2.c

index 52518fc714b115e1c1f56aa0cda3a4167b0f584b..5dd28af8ab51bf5cc2b0bcb6f8a0964c0bc10191 100644 (file)
@@ -1246,10 +1246,8 @@ static BOOL close_internal_rpc_pipe_hnd(void *np_conn)
  Find an rpc pipe given a pipe handle in a buffer and an offset.
 ****************************************************************************/
 
-smb_np_struct *get_rpc_pipe_p(const char *buf, int where)
+smb_np_struct *get_rpc_pipe_p(uint16 pnum)
 {
-       int pnum = SVAL(buf,where);
-
        if (chain_p) {
                return chain_p;
        }
index a4ac807377a3d61d45650e744ad53b26e16e8587..24e0f47001377fbcf6220d70cd4e8ff649002207 100644 (file)
@@ -140,7 +140,7 @@ void reply_open_pipe_and_X(connection_struct *conn, struct smb_request *req)
 
 int reply_pipe_write(char *inbuf,char *outbuf,int length,int dum_bufsize)
 {
-       smb_np_struct *p = get_rpc_pipe_p(inbuf,smb_vwv0);
+       smb_np_struct *p = get_rpc_pipe_p(SVAL(inbuf,smb_vwv0));
        uint16 vuid = SVAL(inbuf,smb_uid);
        size_t numtowrite = SVAL(inbuf,smb_vwv1);
        int nwritten;
@@ -185,7 +185,7 @@ int reply_pipe_write(char *inbuf,char *outbuf,int length,int dum_bufsize)
 
 int reply_pipe_write_and_X(char *inbuf,char *outbuf,int length,int bufsize)
 {
-       smb_np_struct *p = get_rpc_pipe_p(inbuf,smb_vwv2);
+       smb_np_struct *p = get_rpc_pipe_p(SVAL(inbuf,smb_vwv2));
        uint16 vuid = SVAL(inbuf,smb_uid);
        size_t numtowrite = SVAL(inbuf,smb_vwv10);
        int nwritten = -1;
@@ -247,7 +247,7 @@ int reply_pipe_write_and_X(char *inbuf,char *outbuf,int length,int bufsize)
 
 int reply_pipe_read_and_X(char *inbuf,char *outbuf,int length,int bufsize)
 {
-       smb_np_struct *p = get_rpc_pipe_p(inbuf,smb_vwv2);
+       smb_np_struct *p = get_rpc_pipe_p(SVAL(inbuf,smb_vwv2));
        int smb_maxcnt = SVAL(inbuf,smb_vwv5);
        int smb_mincnt = SVAL(inbuf,smb_vwv6);
        int nread = -1;
@@ -292,7 +292,7 @@ int reply_pipe_read_and_X(char *inbuf,char *outbuf,int length,int bufsize)
 
 void reply_pipe_close(connection_struct *conn, struct smb_request *req)
 {
-       smb_np_struct *p = get_rpc_pipe_p((char *)req->inbuf,smb_vwv0);
+       smb_np_struct *p = get_rpc_pipe_p(SVAL(req->inbuf,smb_vwv0));
 
        if (!p) {
                reply_doserror(req, ERRDOS, ERRbadfid);
index d455a12fa112f8f12585bd1850c9b6fc57113b38..77a13ad18623e6a3b1d7426ff5d5991f52ddb9ca 100644 (file)
@@ -3244,7 +3244,7 @@ static int call_trans2qpipeinfo(connection_struct *conn, char *inbuf, char *outb
                return ERROR_NT(NT_STATUS_INVALID_PARAMETER);
        }
 
-       p_pipe = get_rpc_pipe_p(params,0);
+       p_pipe = get_rpc_pipe_p(SVAL(params,0));
        if (p_pipe == NULL) {
                return ERROR_NT(NT_STATUS_INVALID_HANDLE);
        }