|
@@ -487,6 +487,25 @@ static inline struct ppa_addr dev_to_generic_addr(struct nvm_dev *dev,
|
|
return l;
|
|
return l;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static inline u64 dev_to_chunk_addr(struct nvm_dev *dev, void *addrf,
|
|
|
|
+ struct ppa_addr p)
|
|
|
|
+{
|
|
|
|
+ struct nvm_geo *geo = &dev->geo;
|
|
|
|
+ u64 caddr;
|
|
|
|
+
|
|
|
|
+ if (geo->version == NVM_OCSSD_SPEC_12) {
|
|
|
|
+ struct nvm_addrf_12 *ppaf = (struct nvm_addrf_12 *)addrf;
|
|
|
|
+
|
|
|
|
+ caddr = (u64)p.g.pg << ppaf->pg_offset;
|
|
|
|
+ caddr |= (u64)p.g.pl << ppaf->pln_offset;
|
|
|
|
+ caddr |= (u64)p.g.sec << ppaf->sec_offset;
|
|
|
|
+ } else {
|
|
|
|
+ caddr = p.m.sec;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return caddr;
|
|
|
|
+}
|
|
|
|
+
|
|
typedef blk_qc_t (nvm_tgt_make_rq_fn)(struct request_queue *, struct bio *);
|
|
typedef blk_qc_t (nvm_tgt_make_rq_fn)(struct request_queue *, struct bio *);
|
|
typedef sector_t (nvm_tgt_capacity_fn)(void *);
|
|
typedef sector_t (nvm_tgt_capacity_fn)(void *);
|
|
typedef void *(nvm_tgt_init_fn)(struct nvm_tgt_dev *, struct gendisk *,
|
|
typedef void *(nvm_tgt_init_fn)(struct nvm_tgt_dev *, struct gendisk *,
|