Commit df414b33 authored by Matias Bjørling's avatar Matias Bjørling Committed by Jens Axboe

lightnvm: add is_cached entry to struct ppa_addr

A target requires a method to identify PPAs that are either cached in
memory or on disk. This can efficiently be maintained within the PPA.
The target host-side translation table can then lookup a PPA and know
from the PPA if it is cached or on disk. In the case it is cached, it is
the responsibility of the target to maintain this cache.
Signed-off-by: default avatarMatias Bjørling <m@bjorling.me>
Signed-off-by: default avatarJens Axboe <axboe@fb.com>
parent 04a8aa17
...@@ -18,7 +18,7 @@ enum { ...@@ -18,7 +18,7 @@ enum {
#define NVM_SEC_BITS (8) #define NVM_SEC_BITS (8)
#define NVM_PL_BITS (8) #define NVM_PL_BITS (8)
#define NVM_LUN_BITS (8) #define NVM_LUN_BITS (8)
#define NVM_CH_BITS (8) #define NVM_CH_BITS (7)
struct ppa_addr { struct ppa_addr {
/* Generic structure for all addresses */ /* Generic structure for all addresses */
...@@ -30,8 +30,14 @@ struct ppa_addr { ...@@ -30,8 +30,14 @@ struct ppa_addr {
u64 pl : NVM_PL_BITS; u64 pl : NVM_PL_BITS;
u64 lun : NVM_LUN_BITS; u64 lun : NVM_LUN_BITS;
u64 ch : NVM_CH_BITS; u64 ch : NVM_CH_BITS;
u64 reserved : 1;
} g; } g;
struct {
u64 line : 63;
u64 is_cached : 1;
} c;
u64 ppa; u64 ppa;
}; };
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment