On Fri, 28 Oct 2011 23:54:15 +0400
Pavel Shilovsky <[email protected]> wrote:

> From: Steve French <[email protected]>
> 
> Convert the debug routines in cifs_debug.c to recognize
> smb2 sessions and not try to dump invalid information on
> pending requests.  Check the socket type to see if
> smb2.  Move the printing of cifs specific debug information
> to a helper routine to make it clearer which type
> of information we are printing.
> 
> cifs and smb2 both use the struct TCP_Server_Info to include information about
> the tcp socket connection to the server.  The list of pending requests
> is one of the "per-socket" pieces of information. smb2 and cifs
> "mid" queue entries (multiplexed network requests, the active requests
> on the wire) differ. smb2 has async support in the protocol,
> as well as operation compounding and larger sizes (than cifs) for
> various fields related to pending requests) so it is important
> not to try to use the pending_mid_q for smb2 tcp sessions
> as if it were a pending cifs request.  Most usage of the
> pending_mid_q is safe because it is in either cifs or smb2
> specific code, but this patch fixes the dumping of debug
> data so we don't dump cifs debug data for an smb2 session.
> 
> Signed-off-by: Steve French <[email protected]>
> Signed-off-by: Pavel Shilovsky <[email protected]>
> ---
>  fs/cifs/cifs_debug.c |  179 
> +++++++++++++++++++++++++++-----------------------
>  1 files changed, 98 insertions(+), 81 deletions(-)
> 
> diff --git a/fs/cifs/cifs_debug.c b/fs/cifs/cifs_debug.c
> index 8ccdb15..add9975 100644
> --- a/fs/cifs/cifs_debug.c
> +++ b/fs/cifs/cifs_debug.c
> @@ -72,7 +72,7 @@ void cifs_dump_mids(struct TCP_Server_Info *server)
>       struct list_head *tmp;
>       struct mid_q_entry *mid_entry;
>  
> -     if (server == NULL)
> +     if ((server == NULL) || (server->is_smb2))
>               return;
>  

This looks like a cargo-cult check. When on earth would the server ever
be NULL here? I think you can just get rid of the NULL check here.

>       cERROR(1, "Dump pending requests:");
> @@ -105,16 +105,105 @@ void cifs_dump_mids(struct TCP_Server_Info *server)
>  #endif /* CONFIG_CIFS_DEBUG2 */
>  
>  #ifdef CONFIG_PROC_FS
> -static int cifs_debug_data_proc_show(struct seq_file *m, void *v)
> +
> +static void dump_smb2_debug_info(int i, struct seq_file *m,
> +                             struct TCP_Server_Info *server)
>  {
> -     struct list_head *tmp1, *tmp2, *tmp3;
> +     seq_printf(m, "dumping debug information for smb2 not supported yet\n");
> +}
> +
> +static void dump_cifs_debug_info(int i, struct seq_file *m,
> +                             struct TCP_Server_Info *server)
> +{
> +     struct list_head *tmp2, *tmp3;
>       struct mid_q_entry *mid_entry;
> -     struct TCP_Server_Info *server;
>       struct cifs_ses *ses;
>       struct cifs_tcon *tcon;
> -     int i, j;
> +     int j;
>       __u32 dev_type;
>  
> +
> +     list_for_each(tmp2, &server->smb_ses_list) {
> +             ses = list_entry(tmp2, struct cifs_ses, smb_ses_list);
> +             if ((ses->serverDomain == NULL) || (ses->serverOS == NULL) ||
> +                     (ses->serverNOS == NULL)) {
                                ^^^^^^^
                        No need for the extra parenthesis around each of these.

> +                     seq_printf(m, "\n%d) entry for %s not fully "
> +                                "displayed\n\t", i, ses->serverName);
> +             } else {
> +                     seq_printf(m,
> +                             "\n%d) Name: %s  Domain: %s Uses: %d OS:"
> +                             " %s\n\tNOS: %s\tCapability: 0x%x\n\tSMB"
> +                             " session status: %d\t",
> +                             i, ses->serverName, ses->serverDomain,
> +                             ses->ses_count, ses->serverOS, ses->serverNOS,
> +                             ses->capabilities, ses->status);
> +             }
> +             seq_printf(m, "TCP status: %d\n\tLocal Users To "
> +                           "Server: %d SecMode: 0x%x Req On Wire: %d",
> +                             server->tcpStatus, server->srv_count,
> +                             server->sec_mode,
> +                             atomic_read(&server->inFlight));
> +
> +#ifdef CONFIG_CIFS_STATS2
> +             seq_printf(m, " In Send: %d In MaxReq Wait: %d",
> +                             atomic_read(&server->in_send),
> +                             atomic_read(&server->num_waiters));
> +#endif
> +
> +             seq_puts(m, "\n\tShares:");
> +             j = 0;
> +             list_for_each(tmp3, &ses->tcon_list) {
> +                     tcon = list_entry(tmp3, struct cifs_tcon, tcon_list);
> +                     ++j;
> +                     dev_type = le32_to_cpu(tcon->fsDevInfo.DeviceType);
> +                     seq_printf(m, "\n\t%d) %s Mounts: %d ", j,
> +                                tcon->treeName, tcon->tc_count);
> +                     if (tcon->nativeFileSystem) {
> +                             seq_printf(m, "Type: %s ",
> +                                        tcon->nativeFileSystem);
> +                     }
> +                     seq_printf(m, "DevInfo: 0x%x Attributes: 0x%x"
> +                             "\nPathComponentMax: %d Status: 0x%d",
> +                             le32_to_cpu(
> +                                      tcon->fsDevInfo.DeviceCharacteristics),
> +                             le32_to_cpu(tcon->fsAttrInfo.Attributes),
> +                             le32_to_cpu(
> +                                tcon->fsAttrInfo.MaxPathNameComponentLength),
> +                             tcon->tidStatus);
> +                     if (dev_type == FILE_DEVICE_DISK)
> +                             seq_puts(m, " type: DISK ");
> +                     else if (dev_type == FILE_DEVICE_CD_ROM)
> +                             seq_puts(m, " type: CDROM ");
> +                     else
> +                             seq_printf(m, " type: %d ", dev_type);
> +

The above would be better as:

        seq_puts(m, "type: ");
        switch(dev_type) {
                ...
        }

> +                     if (tcon->need_reconnect)
> +                             seq_puts(m, "\tDISCONNECTED ");
> +                     seq_putc(m, '\n');
> +             }
> +
> +             seq_puts(m, "\n\tMIDs:\n");
> +
> +             spin_lock(&GlobalMid_Lock);
> +             list_for_each(tmp3, &server->pending_mid_q) {
> +                     mid_entry = list_entry(tmp3, struct mid_q_entry, qhead);
> +                     seq_printf(m, "\tState: %d com: %d pid:"
> +                                     " %d cbdata: %p mid %d\n",
> +                                     mid_entry->midState,
> +                                     (int)mid_entry->command, mid_entry->pid,
> +                                     mid_entry->callback_data,
> +                                     mid_entry->mid);
> +             }
> +             spin_unlock(&GlobalMid_Lock);
> +     }
> +}
> +
> +static int cifs_debug_data_proc_show(struct seq_file *m, void *v)
> +{
> +     struct list_head *tmp1;
> +     struct TCP_Server_Info *server;
> +     int i;
> +
>       seq_puts(m,
>                   "Display Internal CIFS Data Structures for Debugging\n"
>                   "---------------------------------------------------\n");
> @@ -151,82 +240,10 @@ static int cifs_debug_data_proc_show(struct seq_file 
> *m, void *v)
>               server = list_entry(tmp1, struct TCP_Server_Info,
>                                   tcp_ses_list);
>               i++;
> -             list_for_each(tmp2, &server->smb_ses_list) {
> -                     ses = list_entry(tmp2, struct cifs_ses,
> -                                      smb_ses_list);
> -                     if ((ses->serverDomain == NULL) ||
> -                             (ses->serverOS == NULL) ||
> -                             (ses->serverNOS == NULL)) {
> -                             seq_printf(m, "\n%d) entry for %s not fully "
> -                                        "displayed\n\t", i, ses->serverName);
> -                     } else {
> -                             seq_printf(m,
> -                                 "\n%d) Name: %s  Domain: %s Uses: %d OS:"
> -                                 " %s\n\tNOS: %s\tCapability: 0x%x\n\tSMB"
> -                                 " session status: %d\t",
> -                             i, ses->serverName, ses->serverDomain,
> -                             ses->ses_count, ses->serverOS, ses->serverNOS,
> -                             ses->capabilities, ses->status);
> -                     }
> -                     seq_printf(m, "TCP status: %d\n\tLocal Users To "
> -                                "Server: %d SecMode: 0x%x Req On Wire: %d",
> -                                server->tcpStatus, server->srv_count,
> -                                server->sec_mode,
> -                                atomic_read(&server->inFlight));
> -
> -#ifdef CONFIG_CIFS_STATS2
> -                     seq_printf(m, " In Send: %d In MaxReq Wait: %d",
> -                             atomic_read(&server->in_send),
> -                             atomic_read(&server->num_waiters));
> -#endif
> -
> -                     seq_puts(m, "\n\tShares:");
> -                     j = 0;
> -                     list_for_each(tmp3, &ses->tcon_list) {
> -                             tcon = list_entry(tmp3, struct cifs_tcon,
> -                                               tcon_list);
> -                             ++j;
> -                             dev_type = 
> le32_to_cpu(tcon->fsDevInfo.DeviceType);
> -                             seq_printf(m, "\n\t%d) %s Mounts: %d ", j,
> -                                        tcon->treeName, tcon->tc_count);
> -                             if (tcon->nativeFileSystem) {
> -                                     seq_printf(m, "Type: %s ",
> -                                                tcon->nativeFileSystem);
> -                             }
> -                             seq_printf(m, "DevInfo: 0x%x Attributes: 0x%x"
> -                                     "\nPathComponentMax: %d Status: 0x%d",
> -                                     
> le32_to_cpu(tcon->fsDevInfo.DeviceCharacteristics),
> -                                     
> le32_to_cpu(tcon->fsAttrInfo.Attributes),
> -                                     
> le32_to_cpu(tcon->fsAttrInfo.MaxPathNameComponentLength),
> -                                     tcon->tidStatus);
> -                             if (dev_type == FILE_DEVICE_DISK)
> -                                     seq_puts(m, " type: DISK ");
> -                             else if (dev_type == FILE_DEVICE_CD_ROM)
> -                                     seq_puts(m, " type: CDROM ");
> -                             else
> -                                     seq_printf(m, " type: %d ", dev_type);
> -
> -                             if (tcon->need_reconnect)
> -                                     seq_puts(m, "\tDISCONNECTED ");
> -                             seq_putc(m, '\n');
> -                     }
> -
> -                     seq_puts(m, "\n\tMIDs:\n");
> -
> -                     spin_lock(&GlobalMid_Lock);
> -                     list_for_each(tmp3, &server->pending_mid_q) {
> -                             mid_entry = list_entry(tmp3, struct mid_q_entry,
> -                                     qhead);
> -                             seq_printf(m, "\tState: %d com: %d pid:"
> -                                             " %d cbdata: %p mid %d\n",
> -                                             mid_entry->midState,
> -                                             (int)mid_entry->command,
> -                                             mid_entry->pid,
> -                                             mid_entry->callback_data,
> -                                             mid_entry->mid);
> -                     }
> -                     spin_unlock(&GlobalMid_Lock);
> -             }
> +             if (server->is_smb2)
> +                     dump_smb2_debug_info(i, m, server);
> +             else
> +                     dump_cifs_debug_info(i, m, server);
>       }
>       spin_unlock(&cifs_tcp_ses_lock);
>       seq_putc(m, '\n');


-- 
Jeff Layton <[email protected]>
--
To unsubscribe from this list: send the line "unsubscribe linux-cifs" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to