forked from Minki/linux
dccc96abfb
The data structure used for log messages is so large that it can cause a
boot failure. Since allocations from that data structure can fail anyway,
use kmalloc() / kfree() instead of that data structure.
See also https://bugzilla.kernel.org/show_bug.cgi?id=204119.
See also commit ded85c193a
("scsi: Implement per-cpu logging buffer") # v4.0.
Reported-by: Jan Palus <jpalus@fastmail.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Hannes Reinecke <hare@suse.com>
Cc: Johannes Thumshirn <jthumshirn@suse.de>
Cc: Ming Lei <ming.lei@redhat.com>
Cc: Jan Palus <jpalus@fastmail.com>
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
88 lines
2.1 KiB
C
88 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _SCSI_SCSI_DBG_H
|
|
#define _SCSI_SCSI_DBG_H
|
|
|
|
struct scsi_cmnd;
|
|
struct scsi_device;
|
|
struct scsi_sense_hdr;
|
|
|
|
extern void scsi_print_command(struct scsi_cmnd *);
|
|
extern size_t __scsi_format_command(char *, size_t,
|
|
const unsigned char *, size_t);
|
|
extern void scsi_print_sense_hdr(const struct scsi_device *, const char *,
|
|
const struct scsi_sense_hdr *);
|
|
extern void scsi_print_sense(const struct scsi_cmnd *);
|
|
extern void __scsi_print_sense(const struct scsi_device *, const char *name,
|
|
const unsigned char *sense_buffer,
|
|
int sense_len);
|
|
extern void scsi_print_result(const struct scsi_cmnd *, const char *, int);
|
|
|
|
#ifdef CONFIG_SCSI_CONSTANTS
|
|
extern bool scsi_opcode_sa_name(int, int, const char **, const char **);
|
|
extern const char *scsi_sense_key_string(unsigned char);
|
|
extern const char *scsi_extd_sense_format(unsigned char, unsigned char,
|
|
const char **);
|
|
extern const char *scsi_mlreturn_string(int);
|
|
extern const char *scsi_hostbyte_string(int);
|
|
extern const char *scsi_driverbyte_string(int);
|
|
#else
|
|
static inline bool
|
|
scsi_opcode_sa_name(int cmd, int sa,
|
|
const char **cdb_name, const char **sa_name)
|
|
{
|
|
*cdb_name = NULL;
|
|
switch (cmd) {
|
|
case VARIABLE_LENGTH_CMD:
|
|
case MAINTENANCE_IN:
|
|
case MAINTENANCE_OUT:
|
|
case PERSISTENT_RESERVE_IN:
|
|
case PERSISTENT_RESERVE_OUT:
|
|
case SERVICE_ACTION_IN_12:
|
|
case SERVICE_ACTION_OUT_12:
|
|
case SERVICE_ACTION_BIDIRECTIONAL:
|
|
case SERVICE_ACTION_IN_16:
|
|
case SERVICE_ACTION_OUT_16:
|
|
case EXTENDED_COPY:
|
|
case RECEIVE_COPY_RESULTS:
|
|
*sa_name = NULL;
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
|
|
static inline const char *
|
|
scsi_sense_key_string(unsigned char key)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
static inline const char *
|
|
scsi_extd_sense_format(unsigned char asc, unsigned char ascq, const char **fmt)
|
|
{
|
|
*fmt = NULL;
|
|
return NULL;
|
|
}
|
|
|
|
static inline const char *
|
|
scsi_mlreturn_string(int result)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
static inline const char *
|
|
scsi_hostbyte_string(int result)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
static inline const char *
|
|
scsi_driverbyte_string(int result)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* _SCSI_SCSI_DBG_H */
|