From: Hannes Reinecke <hare@suse.de>
To: emilne@redhat.com, "Elliott, Robert (Server Storage)" <Elliott@hp.com>
Cc: James Bottomley <jbottomley@parallels.com>,
Christoph Hellwig <hch@infradead.org>,
"linux-scsi@vger.kernel.org" <linux-scsi@vger.kernel.org>
Subject: Re: [PATCH 04/24] scsi: introduce sdev_prefix_printk()
Date: Mon, 06 Oct 2014 08:00:50 +0200 [thread overview]
Message-ID: <54323012.5020008@suse.de> (raw)
In-Reply-To: <1412353880.5241.136.camel@localhost.localdomain>
On 10/03/2014 06:31 PM, Ewan Milne wrote:
> On Thu, 2014-10-02 at 18:37 +0000, Elliott, Robert (Server Storage)
> wrote:
>>> -----Original Message-----
>>> From: Hannes Reinecke [mailto:hare@suse.de]
>> ...
>>> diff --git a/drivers/scsi/sd.h b/drivers/scsi/sd.h
>>> index 4c3ab83..c01dc89 100644
>>> --- a/drivers/scsi/sd.h
>>> +++ b/drivers/scsi/sd.h
>>> @@ -103,9 +103,10 @@ static inline struct scsi_disk *scsi_disk(struct gendisk
>>> *disk)
>>>
>>> #define sd_printk(prefix, sdsk, fmt, a...) \
>>> (sdsk)->disk ? \
>>> - sdev_printk(prefix, (sdsk)->device, "[%s] " fmt, \
>>> - (sdsk)->disk->disk_name, ##a) : \
>>> - sdev_printk(prefix, (sdsk)->device, fmt, ##a)
>>> + sdev_prefix_printk(prefix, (sdsk)->device, \
>>> + (sdsk)->disk->disk_name, fmt, ##a) : \
>>> + sdev_prefix_printk(prefix, (sdsk)->device, \
>>> + NULL, fmt, ##a)
>>>
>>> #define sd_first_printk(prefix, sdsk, fmt, a...) \
>>> do { \
>> ...
>>> diff --git a/include/scsi/scsi_device.h b/include/scsi/scsi_device.h
>>> index 27ecee7..0b18a09 100644
>>> --- a/include/scsi/scsi_device.h
>>> +++ b/include/scsi/scsi_device.h
>>> @@ -244,6 +244,15 @@ struct scsi_dh_data {
>>> #define sdev_dbg(sdev, fmt, a...) \
>>> dev_dbg(&(sdev)->sdev_gendev, fmt, ##a)
>>>
>>> +/*
>>> + * like scmd_printk, but the device name is passed in
>>> + * as a string pointer
>>> + */
>>> +#define sdev_prefix_printk(l, sdev, p, fmt, a...) \
>>> + (p) ? \
>>> + sdev_printk(l, sdev, "[%s] " fmt, p, ##a) : \
>>> + sdev_printk(l, sdev, fmt, ##a)
>>> +
>>> #define scmd_printk(prefix, scmd, fmt, a...) \
>>> (scmd)->request->rq_disk ? \
>>> sdev_printk(prefix, (scmd)->device, "[%s] " fmt, \
>>> --
>>> 1.8.5.2
>>
>> This triggers lots of compiler warnings with gcc 4.4.7 like:
>>
>> drivers/scsi/sd.c: In function 'sd_open':
>> drivers/scsi/sd.c:1179: warning: reading through null pointer (argument 4)
>> drivers/scsi/sd.c:1179: warning: format '%s' expects type 'char *', but argument 4 has type 'void *'
>>
>>
>> That is from:
>> SCSI_LOG_HLQUEUE(3, sd_printk(KERN_INFO, sdkp, "sd_open\n"));
>>
>> Since:
>> #define NULL ((void *)0)
>>
>> gcc probably doesn't realize the (p)? prevents the NULL (a void *)
>> from being passed to sdev_printk.
>>
>> Passing "" rather than NULL eliminates the compiler warnings.
>
> It eliminates the warnings, but unfortunately we then get log messages
> that look like:
>
> Oct 3 11:30:08 rhel-storage-01 kernel: sd 10:0:0:0: [sde] (null)FAILED Result: hostbyte=DID_OK driverbyte=DRIVER_SENSE
>
> ^^^^^^
>
> Changing it to (char *)NULL, like this:
>
> #define sd_printk(prefix, sdsk, fmt, a...) \
> (sdsk)->disk ? \
> sdev_prefix_printk(prefix, (sdsk)->device, \
> (sdsk)->disk->disk_name, fmt, ##a) : \
> sdev_prefix_printk(prefix, (sdsk)->device, \
> (char *)NULL, fmt, ##a)
>
> doesn't work either. The compiler gives an error:
>
> drivers/scsi/sd.c: In function 'sd_open':
> drivers/scsi/sd.c:1158:2: error: reading through null pointer (argument 4) [-Werror=format=]
> SCSI_LOG_HLQUEUE(3, sd_printk(KERN_INFO, sdkp, "sd_open\n"));
> ^
>
I've fixed it up in my next iteration of the patchset.
(By simply using 'sdev_printk' if the prefix argument is NULL ...)
Cheers,
Hannes
--
Dr. Hannes Reinecke zSeries & Storage
hare@suse.de +49 911 74053 688
SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg
GF: J. Hawn, J. Guild, F. Imendörffer, HRB 16746 (AG Nürnberg)
--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2014-10-06 6:00 UTC|newest]
Thread overview: 48+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-10-01 6:22 [PATCHv5 00/24] scsi logging update (the boring part) Hannes Reinecke
2014-10-01 6:22 ` [PATCH 01/24] Remove scsi_cmd_print_sense_hdr() Hannes Reinecke
2014-10-01 6:22 ` [PATCH 02/24] sd: Remove scsi_print_sense() in sd_done() Hannes Reinecke
2014-10-01 6:22 ` [PATCH 03/24] aha152x: Debug output update and whitespace cleanup Hannes Reinecke
2014-10-03 0:01 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 04/24] scsi: introduce sdev_prefix_printk() Hannes Reinecke
2014-10-02 18:37 ` Elliott, Robert (Server Storage)
2014-10-03 16:31 ` Ewan Milne
2014-10-06 6:00 ` Hannes Reinecke [this message]
2014-10-01 6:22 ` [PATCH 05/24] scsi: Use sdev as argument for sense code printing Hannes Reinecke
2014-10-03 0:32 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 06/24] acornscsi: use scsi_print_command() Hannes Reinecke
2014-10-01 6:22 ` [PATCH 07/24] fas216: Return DID_ERROR for incomplete data transfer Hannes Reinecke
2014-10-01 7:58 ` Christoph Hellwig
2014-10-01 6:22 ` [PATCH 08/24] fas216: Update logging messages Hannes Reinecke
2014-10-03 0:43 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 09/24] 53c700: remove scsi_print_sense() usage Hannes Reinecke
2014-10-01 6:22 ` [PATCH 10/24] scsi: stop decoding if scsi_normalize_sense() fails Hannes Reinecke
2014-10-01 6:22 ` [PATCH 11/24] scsi: do not decode sense extras Hannes Reinecke
2014-10-01 6:22 ` [PATCH 12/24] scsi: use 'bool' as return value for scsi_normalize_sense() Hannes Reinecke
2014-10-03 1:15 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 13/24] scsi: remove scsi_print_status() Hannes Reinecke
2014-10-01 6:22 ` [PATCH 14/24] Implement scsi_opcode_sa_name Hannes Reinecke
2014-10-03 1:26 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 15/24] scsi: merge print_opcode_name() Hannes Reinecke
2014-10-03 1:37 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 16/24] scsi: consolidate opcode lookup in scsi_opcode_sa_name() Hannes Reinecke
2014-10-03 1:44 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 17/24] scsi: remove last argument from print_opcode_name() Hannes Reinecke
2014-10-03 2:02 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 18/24] scsi: Remove scsi_print_command when calling abort Hannes Reinecke
2014-10-03 2:11 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 19/24] scsi: separate out scsi_(host|driver)byte_string() Hannes Reinecke
2014-10-01 6:22 ` [PATCH 20/24] sd: Cleanup logging Hannes Reinecke
2014-10-02 23:20 ` Elliott, Robert (Server Storage)
2014-10-03 2:23 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 21/24] scsi: simplify scsi_log_(send|completion) Hannes Reinecke
2014-10-03 2:32 ` Elliott, Robert (Server Storage)
2014-10-06 6:40 ` Hannes Reinecke
2014-10-01 6:22 ` [PATCH 22/24] scsi: fixup logging messages in scsi_error.c Hannes Reinecke
2014-10-02 19:02 ` Ewan Milne
2014-10-03 2:39 ` Elliott, Robert (Server Storage)
2014-10-01 6:22 ` [PATCH 23/24] scsi: use shost argument in scsi_eh_prt_fail_stats Hannes Reinecke
2014-10-01 6:23 ` [PATCH 24/24] scsi_error: document scsi_try_to_abort_cmd Hannes Reinecke
2014-10-01 7:59 ` Christoph Hellwig
2014-10-03 2:54 ` Elliott, Robert (Server Storage)
2014-10-02 18:53 ` [PATCHv5 00/24] scsi logging update (the boring part) Elliott, Robert (Server Storage)
2014-10-03 7:08 ` Hannes Reinecke
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=54323012.5020008@suse.de \
--to=hare@suse.de \
--cc=Elliott@hp.com \
--cc=emilne@redhat.com \
--cc=hch@infradead.org \
--cc=jbottomley@parallels.com \
--cc=linux-scsi@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).