mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 dccc96abfb
			
		
	
	
		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 */
 |