Simon Glass | 4c92a4d | 2022-09-21 16:21:36 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
| 2 | /* |
| 3 | * Emulation of enough SCSI commands to find and read from a unit |
| 4 | * |
| 5 | * Copyright 2022 Google LLC |
| 6 | * Written by Simon Glass <sjg@chromium.org> |
| 7 | * |
| 8 | * implementations of SCSI functions required so that CONFIG_SCSI can be enabled |
| 9 | * for sandbox |
| 10 | */ |
| 11 | |
| 12 | #ifndef __scsi_emul_h |
| 13 | #define __scsi_emul_h |
| 14 | |
| 15 | /** |
| 16 | * struct scsi_emul_info - information for emulating a SCSI device |
| 17 | * |
Simon Glass | 37884f0 | 2022-09-21 16:21:38 +0200 | [diff] [blame] | 18 | * @vendor: Vendor name |
| 19 | * @product: Product name |
Simon Glass | d0962c9 | 2022-09-21 16:21:39 +0200 | [diff] [blame] | 20 | * @block_size: Block size of device in bytes (normally 512) |
Simon Glass | 4313c3e | 2022-09-21 16:21:40 +0200 | [diff] [blame] | 21 | * @file_size: Size of the backing file for this emulator, in bytes |
Simon Glass | 4d3b00d | 2022-09-21 16:21:45 +0200 | [diff] [blame] | 22 | * @seek_block: Seek position for file (block number) |
Simon Glass | 37884f0 | 2022-09-21 16:21:38 +0200 | [diff] [blame] | 23 | * |
Simon Glass | 4c92a4d | 2022-09-21 16:21:36 +0200 | [diff] [blame] | 24 | * @phase: Current SCSI phase |
| 25 | * @buff_used: Number of bytes ready to transfer back to host |
| 26 | * @read_len: Number of bytes of data left in the current read command |
| 27 | * @alloc_len: Allocation length from the last incoming command |
| 28 | * @transfer_len: Transfer length from CBW header |
Simon Glass | 293c43f | 2022-09-21 16:21:37 +0200 | [diff] [blame] | 29 | * @buff: Data buffer for outgoing data |
Simon Glass | 4c92a4d | 2022-09-21 16:21:36 +0200 | [diff] [blame] | 30 | */ |
| 31 | struct scsi_emul_info { |
Simon Glass | 293c43f | 2022-09-21 16:21:37 +0200 | [diff] [blame] | 32 | /* provided by the caller: */ |
| 33 | void *buff; |
Simon Glass | 37884f0 | 2022-09-21 16:21:38 +0200 | [diff] [blame] | 34 | const char *vendor; |
| 35 | const char *product; |
Simon Glass | d0962c9 | 2022-09-21 16:21:39 +0200 | [diff] [blame] | 36 | int block_size; |
Simon Glass | 4313c3e | 2022-09-21 16:21:40 +0200 | [diff] [blame] | 37 | loff_t file_size; |
Simon Glass | 4d3b00d | 2022-09-21 16:21:45 +0200 | [diff] [blame] | 38 | int seek_block; |
Simon Glass | 293c43f | 2022-09-21 16:21:37 +0200 | [diff] [blame] | 39 | |
| 40 | /* state maintained by the emulator: */ |
Simon Glass | 4c92a4d | 2022-09-21 16:21:36 +0200 | [diff] [blame] | 41 | enum scsi_cmd_phase phase; |
| 42 | int buff_used; |
| 43 | int read_len; |
Simon Glass | 31b4f9e | 2022-10-20 18:22:55 -0600 | [diff] [blame] | 44 | int write_len; |
Simon Glass | 4d3b00d | 2022-09-21 16:21:45 +0200 | [diff] [blame] | 45 | uint seek_pos; |
Simon Glass | 4c92a4d | 2022-09-21 16:21:36 +0200 | [diff] [blame] | 46 | int alloc_len; |
| 47 | uint transfer_len; |
| 48 | }; |
| 49 | |
Simon Glass | 31b4f9e | 2022-10-20 18:22:55 -0600 | [diff] [blame] | 50 | /** |
| 51 | * Return value from sb_scsi_emul_command() indicates that a read or write is |
| 52 | * being started |
| 53 | */ |
| 54 | enum { |
| 55 | SCSI_EMUL_DO_READ = 1, |
| 56 | SCSI_EMUL_DO_WRITE = 2, |
| 57 | }; |
Simon Glass | 4d3b00d | 2022-09-21 16:21:45 +0200 | [diff] [blame] | 58 | |
| 59 | /** |
| 60 | * sb_scsi_emul_command() - Process a SCSI command |
| 61 | * |
| 62 | * This sets up the response in info->buff and updates various other values |
| 63 | * in info. |
| 64 | * |
| 65 | * If SCSI_EMUL_DO_READ is returned then the caller should set up so that the |
| 66 | * backing file can be read, or return an error status if there is no file. |
| 67 | * |
| 68 | * @info: Emulation information |
| 69 | * @req: Request to process |
| 70 | * @len: Length of request in bytes |
Simon Glass | 31b4f9e | 2022-10-20 18:22:55 -0600 | [diff] [blame] | 71 | * @return SCSI_EMUL_DO_READ if a read has started, SCSI_EMUL_DO_WRITE if a |
| 72 | * write has started, 0 if some other operation has started, -ve if there |
| 73 | * was an error |
Simon Glass | 4d3b00d | 2022-09-21 16:21:45 +0200 | [diff] [blame] | 74 | */ |
| 75 | int sb_scsi_emul_command(struct scsi_emul_info *info, |
| 76 | const struct scsi_cmd *req, int len); |
| 77 | |
Simon Glass | 4c92a4d | 2022-09-21 16:21:36 +0200 | [diff] [blame] | 78 | #endif |