xref: /qemu/include/hw/block/flash.h (revision 3e82ddaa8db260a232dbbbf488d8ac7851d124c5)
1 #ifndef HW_FLASH_H
2 #define HW_FLASH_H
3 
4 /* NOR flash devices */
5 
6 #include "exec/hwaddr.h"
7 #include "qom/object.h"
8 
9 /* pflash_cfi01.c */
10 
11 #define TYPE_PFLASH_CFI01 "cfi.pflash01"
12 OBJECT_DECLARE_SIMPLE_TYPE(PFlashCFI01, PFLASH_CFI01)
13 
14 
15 PFlashCFI01 *pflash_cfi01_register(hwaddr base,
16                                    const char *name,
17                                    hwaddr size,
18                                    BlockBackend *blk,
19                                    uint32_t sector_len,
20                                    int width,
21                                    uint16_t id0, uint16_t id1,
22                                    uint16_t id2, uint16_t id3,
23                                    int be);
24 BlockBackend *pflash_cfi01_get_blk(PFlashCFI01 *fl);
25 MemoryRegion *pflash_cfi01_get_memory(PFlashCFI01 *fl);
26 void pflash_cfi01_legacy_drive(PFlashCFI01 *dev, DriveInfo *dinfo);
27 
28 /* pflash_cfi02.c */
29 
30 #define TYPE_PFLASH_CFI02 "cfi.pflash02"
31 OBJECT_DECLARE_SIMPLE_TYPE(PFlashCFI02, PFLASH_CFI02)
32 
33 
34 PFlashCFI02 *pflash_cfi02_register(hwaddr base,
35                                    const char *name,
36                                    hwaddr size,
37                                    BlockBackend *blk,
38                                    uint32_t sector_len,
39                                    int nb_mappings,
40                                    int width,
41                                    uint16_t id0, uint16_t id1,
42                                    uint16_t id2, uint16_t id3,
43                                    uint16_t unlock_addr0,
44                                    uint16_t unlock_addr1,
45                                    int be);
46 
47 /* m25p80.c */
48 
49 #define TYPE_M25P80 "m25p80-generic"
50 
51 BlockBackend *m25p80_get_blk(DeviceState *dev);
52 
53 #endif
54