lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <c0c7b4cde76c9b15aad9fa213dcaeb75295763fd.camel@redhat.com>
Date:   Fri, 22 Jan 2021 14:52:56 -0500
From:   "Ewan D. Milne" <emilne@...hat.com>
To:     Martin Kepplinger <martin.kepplinger@...i.sm>, jejb@...ux.ibm.com,
        martin.petersen@...cle.com
Cc:     dgilbert@...erlog.com, bvanassche@....org,
        linux-scsi@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH] scsi_logging: print cdb into new line after opcode

On Fri, 2021-01-22 at 09:39 +0100, Martin Kepplinger wrote:
> The current log message results in a line like the following where
> the first byte is duplicated, giving a wrong impression:
> 
> sd 0:0:0:0: [sda] tag#0 CDB: opcode=0x28 28 00 00 00 60 40 00 00 01
> 00
> 
> Print the cdb into a new line in any case, not only when cmd_len is
> greater than 16. The above example error will then read:
> 
> sd 0:0:0:0: [sda] tag#0 CDB: opcode=0x28
> 28 00 01 c0 09 00 00 00 08 00
> 
> Signed-off-by: Martin Kepplinger <martin.kepplinger@...i.sm>
> ---
>  drivers/scsi/scsi_logging.c | 6 +++---
>  1 file changed, 3 insertions(+), 3 deletions(-)
> 
> diff --git a/drivers/scsi/scsi_logging.c
> b/drivers/scsi/scsi_logging.c
> index 8ea44c6595ef..0081d3936f83 100644
> --- a/drivers/scsi/scsi_logging.c
> +++ b/drivers/scsi/scsi_logging.c
> @@ -200,10 +200,11 @@ void scsi_print_command(struct scsi_cmnd *cmd)
>  	if (off >= logbuf_len)
>  		goto out_printk;
>  
> +	/* Print opcode in one line and use separate lines for CDB */
> +	off += scnprintf(logbuf + off, logbuf_len - off, "\n");
> +
>  	/* print out all bytes in cdb */
>  	if (cmd->cmd_len > 16) {
> -		/* Print opcode in one line and use separate lines for
> CDB */
> -		off += scnprintf(logbuf + off, logbuf_len - off, "\n");
>  		dev_printk(KERN_INFO, &cmd->device->sdev_gendev, "%s",
> logbuf);
>  		for (k = 0; k < cmd->cmd_len; k += 16) {
>  			size_t linelen = min(cmd->cmd_len - k, 16);
> @@ -224,7 +225,6 @@ void scsi_print_command(struct scsi_cmnd *cmd)
>  		goto out;
>  	}
>  	if (!WARN_ON(off > logbuf_len - 49)) {
> -		off += scnprintf(logbuf + off, logbuf_len - off, " ");
>  		hex_dump_to_buffer(cmd->cmnd, cmd->cmd_len, 16, 1,
>  				   logbuf + off, logbuf_len - off,
>  				   false);

I'd rather we not change this.

-Ewan


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ