[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v8 02/13] m25p80: Add support for SST READ ID 0x
From: |
Philippe Mathieu-Daudé |
Subject: |
Re: [Qemu-devel] [PATCH v8 02/13] m25p80: Add support for SST READ ID 0x90/0xAB commands |
Date: |
Sat, 25 Nov 2017 21:45:08 -0300 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 |
Hi Francisco,
On 11/24/2017 06:29 PM, Francisco Iglesias wrote:
> Add support for SST READ ID 0x90/0xAB commands for reading out the flash
> manufacuter ID and device ID.
>
> Signed-off-by: Francisco Iglesias <address@hidden>
> Acked-by: Alistair Francis <address@hidden>
> Acked-by: Marcin Krzemiński <address@hidden>
> ---
> hw/block/m25p80.c | 23 +++++++++++++++++++++++
> 1 file changed, 23 insertions(+)
>
> diff --git a/hw/block/m25p80.c b/hw/block/m25p80.c
> index d50acc1..9d20120 100644
> --- a/hw/block/m25p80.c
> +++ b/hw/block/m25p80.c
> @@ -355,6 +355,8 @@ typedef enum {
> DPP = 0xa2,
> QPP = 0x32,
> QPP_4 = 0x34,
> + RDID_90 = 0x90,
> + RDID_AB = 0xab,
>
> ERASE_4K = 0x20,
> ERASE4_4K = 0x21,
> @@ -405,6 +407,7 @@ typedef enum {
> MAN_MACRONIX,
> MAN_NUMONYX,
> MAN_WINBOND,
> + MAN_SST,
> MAN_GENERIC,
> } Manufacturer;
>
> @@ -476,6 +479,8 @@ static inline Manufacturer get_man(Flash *s)
> return MAN_SPANSION;
> case 0xC2:
> return MAN_MACRONIX;
> + case 0xBF:
> + return MAN_SST;
> default:
> return MAN_GENERIC;
> }
> @@ -711,6 +716,22 @@ static void complete_collecting_data(Flash *s)
> case WEVCR:
> s->enh_volatile_cfg = s->data[0];
> break;
> + case RDID_90:
> + case RDID_AB:
> + if (get_man(s) == MAN_SST && s->cur_addr <= 1) {
What about reporting if guest access this address when not an SST flash?
if (get_man(s) == MAN_SST) {
if (s->cur_addr <= 1) {
> + if (s->cur_addr) {
> + s->data[0] = s->pi->id[2];
> + s->data[1] = s->pi->id[0];
> + } else {
> + s->data[0] = s->pi->id[0];
> + s->data[1] = s->pi->id[2];
> + }
> + s->pos = 0;
> + s->len = 2;
> + s->data_read_loop = true;
> + s->state = STATE_READING_DATA;
} else {
// LOG_UNIMP?
}
} else {
qemu_log_mask(LOG_GUEST_ERROR, ...);
> + }
> + break;
> default:
> break;
> }
> @@ -926,6 +947,8 @@ static void decode_new_cmd(Flash *s, uint32_t value)
> case PP4:
> case PP4_4:
> case DIE_ERASE:
> + case RDID_90:
> + case RDID_AB:
> s->needed_bytes = get_addr_length(s);
> s->pos = 0;
> s->len = 0;
Regards,
Phil.
- [Qemu-devel] [PATCH v8 00/13] Add support for the ZynqMP Generic QSPI, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 01/13] m25p80: Add support for continuous read out of RDSR and READ_FSR, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 02/13] m25p80: Add support for SST READ ID 0x90/0xAB commands, Francisco Iglesias, 2017/11/24
- Re: [Qemu-devel] [PATCH v8 02/13] m25p80: Add support for SST READ ID 0x90/0xAB commands,
Philippe Mathieu-Daudé <=
- [Qemu-devel] [PATCH v8 03/13] m25p80: Add support for BRRD/BRWR and BULK_ERASE (0x60), Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 04/13] m25p80: Add support for n25q512a11 and n25q512a13, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 05/13] xilinx_spips: Move FlashCMD, XilinxQSPIPS and XilinxSPIPSClass, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 08/13] xilinx_spips: Make tx/rx_data_bytes more generic and reusable, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 06/13] xilinx_spips: Update striping to be big-endian bit order, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 09/13] xilinx_spips: Add support for zero pumping, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 07/13] xilinx_spips: Add support for RX discard and RX drain, Francisco Iglesias, 2017/11/24
- [Qemu-devel] [PATCH v8 10/13] xilinx_spips: Add support for 4 byte addresses in the LQSPI, Francisco Iglesias, 2017/11/24