Fix bug #4512 - we were returning a volume label greater than
authorjra <jra@0c0555d6-39d7-0310-84fc-f1cc0bd64818>
Mon, 16 Apr 2007 19:10:16 +0000 (19:10 +0000)
committerjra <jra@0c0555d6-39d7-0310-84fc-f1cc0bd64818>
Mon, 16 Apr 2007 19:10:16 +0000 (19:10 +0000)
32 unicode chars. Windows XP doesn't like that :-).
Jeremy

git-svn-id: svn+ssh://svn.samba.org/data/svn/samba/branches/SAMBA_3_0@22266 0c0555d6-39d7-0310-84fc-f1cc0bd64818

source/include/smb.h
source/param/loadparm.c
source/smbd/connection.c
source/smbd/trans2.c

index 8f54ed7b84a90b140dbeaed05b4180a65f302a2e..a9c57f77f2507117f75b2d4addd2cbdb2254a7e3 100644 (file)
@@ -878,7 +878,7 @@ struct connections_data {
        int cnum;
        uid_t uid;
        gid_t gid;
-       char name[24];
+       char servicename[FSTRING_LEN];
        char addr[24];
        char machine[FSTRING_LEN];
        time_t start;
index a049b2d47ada1afe5a62dd6cb0f87883a9b88625..ea434e476896acf79e9d781678258f5f1796116b 100644 (file)
@@ -5299,15 +5299,22 @@ struct share_params *snum2params_static(int snum)
  A useful volume label function. 
 ********************************************************************/
 
-char *volume_label(int snum)
+const char *volume_label(int snum)
 {
-       char *ret = lp_volume(snum);
-       if (!*ret)
-               return lp_servicename(snum);
-       return (ret);
+       char *ret;
+       const char *label = lp_volume(snum);
+       if (!*label) {
+               label = lp_servicename(snum);
+       }
+               
+       /* This returns a 33 byte guarenteed null terminated string. */
+       ret = talloc_strndup(main_loop_talloc_get(), label, 32);
+       if (!ret) {
+               return "";
+       }               
+       return ret;
 }
 
-
 /*******************************************************************
  Set the server type we will announce as via nmbd.
 ********************************************************************/
index 7e53a29b0445177f17b8a279d3f3add9b983bdd6..5c31a5460ba92c8b88c826dfe5f74e6b8def4dea 100644 (file)
@@ -108,13 +108,13 @@ static int count_fn( TDB_CONTEXT *the_tdb, TDB_DATA kbuf, TDB_DATA dbuf, void *u
 
        if (cs->Clear && !process_exists(crec.pid) && (errno == ESRCH)) {
                DEBUG(2,("pid %s doesn't exist - deleting connections %d [%s]\n",
-                       procid_str_static(&crec.pid), crec.cnum, crec.name));
+                       procid_str_static(&crec.pid), crec.cnum, crec.servicename));
                if (tdb_delete(the_tdb, kbuf) != 0)
                        DEBUG(0,("count_fn: tdb_delete failed with error %s\n", tdb_errorstr(tdb) ));
                return 0;
        }
 
-       if (strequal(crec.name, cs->name))
+       if (strequal(crec.servicename, cs->name))
                cs->curr_connections++;
 
        return 0;
@@ -191,8 +191,8 @@ BOOL claim_connection(connection_struct *conn, const char *name,int max_connecti
        if (conn) {
                crec.uid = conn->uid;
                crec.gid = conn->gid;
-               safe_strcpy(crec.name,
-                           lp_servicename(SNUM(conn)),sizeof(crec.name)-1);
+               safe_strcpy(crec.servicename,
+                           lp_servicename(SNUM(conn)),sizeof(crec.servicename)-1);
        }
        crec.start = time(NULL);
        crec.bcast_msg_flags = msg_flags;
index 04969784c04b5a058a487219bd6d3f6cec99797f..8f1226c66607145a177fd132c88891e9f5fca70b 100644 (file)
@@ -2247,7 +2247,7 @@ static int call_trans2qfsinfo(connection_struct *conn, char *inbuf, char *outbuf
        uint16 info_level;
        int data_len, len;
        SMB_STRUCT_STAT st;
-       char *vname = volume_label(SNUM(conn));
+       const char *vname = volume_label(SNUM(conn));
        int snum = SNUM(conn);
        char *fstype = lp_fstype(SNUM(conn));
        int quota_flag = 0;
@@ -2368,9 +2368,11 @@ cBytesSector=%u, cUnitTotal=%u, cUnitAvail=%d\n", (unsigned int)st.st_dev, (unsi
                        SIVAL(pdata,8,str_checksum(lp_servicename(snum)) ^ 
                                (str_checksum(get_local_machine_name())<<16));
 
+                       /* Max label len is 32 characters. */
                        len = srvstr_push(outbuf, pdata+18, vname, -1, STR_UNICODE);
                        SIVAL(pdata,12,len);
                        data_len = 18+len;
+
                        DEBUG(5,("call_trans2qfsinfo : SMB_QUERY_FS_VOLUME_INFO namelen = %d, vol=%s serv=%s\n", 
                                (int)strlen(vname),vname, lp_servicename(snum)));
                        break;