Symbol: btt
arch/s390/kernel/traps.c
255
enum bug_trap_type btt;
arch/s390/kernel/traps.c
261
btt = report_bug_entry((struct bug_entry *)regs->gprs[2], regs);
arch/s390/kernel/traps.c
263
btt = report_bug(regs->psw.addr - (regs->int_code >> 16), regs);
arch/s390/kernel/traps.c
265
switch (btt) {
drivers/nvdimm/btt.c
1019
static int btt_meta_init(struct btt *btt)
drivers/nvdimm/btt.c
1024
mutex_lock(&btt->init_lock);
drivers/nvdimm/btt.c
1025
list_for_each_entry(arena, &btt->arena_list, list) {
drivers/nvdimm/btt.c
1043
btt->init_state = INIT_READY;
drivers/nvdimm/btt.c
1046
mutex_unlock(&btt->init_lock);
drivers/nvdimm/btt.c
1050
static u32 btt_meta_size(struct btt *btt)
drivers/nvdimm/btt.c
1052
return btt->lbasize - btt->sector_size;
drivers/nvdimm/btt.c
1062
static int lba_to_arena(struct btt *btt, sector_t sector, __u32 *premap,
drivers/nvdimm/btt.c
1066
__u64 lba = div_u64(sector << SECTOR_SHIFT, btt->sector_size);
drivers/nvdimm/btt.c
1068
list_for_each_entry(arena_list, &btt->arena_list, list) {
drivers/nvdimm/btt.c
1135
static int btt_rw_integrity(struct btt *btt, struct bio_integrity_payload *bip,
drivers/nvdimm/btt.c
1138
unsigned int len = btt_meta_size(btt);
drivers/nvdimm/btt.c
1145
meta_nsoff = to_namespace_offset(arena, postmap) + btt->sector_size;
drivers/nvdimm/btt.c
1182
static int btt_rw_integrity(struct btt *btt, struct bio_integrity_payload *bip,
drivers/nvdimm/btt.c
1189
static int btt_read_pg(struct btt *btt, struct bio_integrity_payload *bip,
drivers/nvdimm/btt.c
1201
lane = nd_region_acquire_lane(btt->nd_region);
drivers/nvdimm/btt.c
1203
ret = lba_to_arena(btt, sector, &premap, &arena);
drivers/nvdimm/btt.c
1207
cur_len = min(btt->sector_size, len);
drivers/nvdimm/btt.c
1265
ret = btt_rw_integrity(btt, bip, arena, postmap, READ);
drivers/nvdimm/btt.c
1271
nd_region_release_lane(btt->nd_region, lane);
drivers/nvdimm/btt.c
1275
sector += btt->sector_size >> SECTOR_SHIFT;
drivers/nvdimm/btt.c
1283
nd_region_release_lane(btt->nd_region, lane);
drivers/nvdimm/btt.c
1292
static bool btt_is_badblock(struct btt *btt, struct arena_info *arena,
drivers/nvdimm/btt.c
1299
return is_bad_pmem(btt->phys_bb, phys_sector, arena->internal_lbasize);
drivers/nvdimm/btt.c
1302
static int btt_write_pg(struct btt *btt, struct bio_integrity_payload *bip,
drivers/nvdimm/btt.c
1317
lane = nd_region_acquire_lane(btt->nd_region);
drivers/nvdimm/btt.c
1319
ret = lba_to_arena(btt, sector, &premap, &arena);
drivers/nvdimm/btt.c
1322
cur_len = min(btt->sector_size, len);
drivers/nvdimm/btt.c
1329
if (btt_is_badblock(btt, arena, arena->freelist[lane].block))
drivers/nvdimm/btt.c
1334
nd_region_release_lane(btt->nd_region, lane);
drivers/nvdimm/btt.c
1362
ret = btt_rw_integrity(btt, bip, arena, new_postmap,
drivers/nvdimm/btt.c
1395
nd_region_release_lane(btt->nd_region, lane);
drivers/nvdimm/btt.c
1405
sector += btt->sector_size >> SECTOR_SHIFT;
drivers/nvdimm/btt.c
1413
nd_region_release_lane(btt->nd_region, lane);
drivers/nvdimm/btt.c
1417
static int btt_do_bvec(struct btt *btt, struct bio_integrity_payload *bip,
drivers/nvdimm/btt.c
1424
ret = btt_read_pg(btt, bip, page, off, sector, len);
drivers/nvdimm/btt.c
1428
ret = btt_write_pg(btt, bip, sector, page, off, len);
drivers/nvdimm/btt.c
1437
struct btt *btt = bio->bi_bdev->bd_disk->private_data;
drivers/nvdimm/btt.c
1453
if (len > PAGE_SIZE || len < btt->sector_size ||
drivers/nvdimm/btt.c
1454
len % btt->sector_size) {
drivers/nvdimm/btt.c
1455
dev_err_ratelimited(&btt->nd_btt->dev,
drivers/nvdimm/btt.c
1461
err = btt_do_bvec(btt, bip, bvec.bv_page, len, bvec.bv_offset,
drivers/nvdimm/btt.c
1464
dev_err(&btt->nd_btt->dev,
drivers/nvdimm/btt.c
1494
static int btt_blk_init(struct btt *btt)
drivers/nvdimm/btt.c
1496
struct nd_btt *nd_btt = btt->nd_btt;
drivers/nvdimm/btt.c
1499
.logical_block_size = btt->sector_size,
drivers/nvdimm/btt.c
1506
if (btt_meta_size(btt) && IS_ENABLED(CONFIG_BLK_DEV_INTEGRITY)) {
drivers/nvdimm/btt.c
1507
lim.integrity.metadata_size = btt_meta_size(btt);
drivers/nvdimm/btt.c
1508
lim.integrity.tag_size = btt_meta_size(btt);
drivers/nvdimm/btt.c
1511
btt->btt_disk = blk_alloc_disk(&lim, NUMA_NO_NODE);
drivers/nvdimm/btt.c
1512
if (IS_ERR(btt->btt_disk))
drivers/nvdimm/btt.c
1513
return PTR_ERR(btt->btt_disk);
drivers/nvdimm/btt.c
1515
nvdimm_namespace_disk_name(ndns, btt->btt_disk->disk_name);
drivers/nvdimm/btt.c
1516
btt->btt_disk->first_minor = 0;
drivers/nvdimm/btt.c
1517
btt->btt_disk->fops = &btt_fops;
drivers/nvdimm/btt.c
1518
btt->btt_disk->private_data = btt;
drivers/nvdimm/btt.c
1520
set_capacity(btt->btt_disk, btt->nlba * btt->sector_size >> 9);
drivers/nvdimm/btt.c
1521
rc = device_add_disk(&btt->nd_btt->dev, btt->btt_disk, NULL);
drivers/nvdimm/btt.c
1525
btt->nd_btt->size = btt->nlba * (u64)btt->sector_size;
drivers/nvdimm/btt.c
1526
nvdimm_check_and_set_ro(btt->btt_disk);
drivers/nvdimm/btt.c
1531
put_disk(btt->btt_disk);
drivers/nvdimm/btt.c
1535
static void btt_blk_cleanup(struct btt *btt)
drivers/nvdimm/btt.c
1537
del_gendisk(btt->btt_disk);
drivers/nvdimm/btt.c
1538
put_disk(btt->btt_disk);
drivers/nvdimm/btt.c
1558
static struct btt *btt_init(struct nd_btt *nd_btt, unsigned long long rawsize,
drivers/nvdimm/btt.c
1563
struct btt *btt;
drivers/nvdimm/btt.c
1567
btt = devm_kzalloc(dev, sizeof(struct btt), GFP_KERNEL);
drivers/nvdimm/btt.c
1568
if (!btt)
drivers/nvdimm/btt.c
1571
btt->nd_btt = nd_btt;
drivers/nvdimm/btt.c
1572
btt->rawsize = rawsize;
drivers/nvdimm/btt.c
1573
btt->lbasize = lbasize;
drivers/nvdimm/btt.c
1574
btt->sector_size = ((lbasize >= 4096) ? 4096 : 512);
drivers/nvdimm/btt.c
1575
INIT_LIST_HEAD(&btt->arena_list);
drivers/nvdimm/btt.c
1576
mutex_init(&btt->init_lock);
drivers/nvdimm/btt.c
1577
btt->nd_region = nd_region;
drivers/nvdimm/btt.c
1579
btt->phys_bb = &nsio->bb;
drivers/nvdimm/btt.c
1581
ret = discover_arenas(btt);
drivers/nvdimm/btt.c
1587
if (btt->init_state != INIT_READY && nd_region->ro) {
drivers/nvdimm/btt.c
1591
} else if (btt->init_state != INIT_READY) {
drivers/nvdimm/btt.c
1592
btt->num_arenas = (rawsize / ARENA_MAX_SIZE) +
drivers/nvdimm/btt.c
1595
btt->num_arenas, rawsize);
drivers/nvdimm/btt.c
1597
ret = create_arenas(btt);
drivers/nvdimm/btt.c
1603
ret = btt_meta_init(btt);
drivers/nvdimm/btt.c
1610
ret = btt_blk_init(btt);
drivers/nvdimm/btt.c
1616
btt_debugfs_init(btt);
drivers/nvdimm/btt.c
1618
return btt;
drivers/nvdimm/btt.c
1630
static void btt_fini(struct btt *btt)
drivers/nvdimm/btt.c
1632
if (btt) {
drivers/nvdimm/btt.c
1633
btt_blk_cleanup(btt);
drivers/nvdimm/btt.c
1634
free_arenas(btt);
drivers/nvdimm/btt.c
1635
debugfs_remove_recursive(btt->debugfs_dir);
drivers/nvdimm/btt.c
1644
struct btt *btt;
drivers/nvdimm/btt.c
1678
btt = btt_init(nd_btt, rawsize, nd_btt->lbasize, nd_btt->uuid,
drivers/nvdimm/btt.c
1680
if (!btt)
drivers/nvdimm/btt.c
1682
nd_btt->btt = btt;
drivers/nvdimm/btt.c
1690
struct btt *btt = nd_btt->btt;
drivers/nvdimm/btt.c
1692
btt_fini(btt);
drivers/nvdimm/btt.c
1693
nd_btt->btt = NULL;
drivers/nvdimm/btt.c
257
static void btt_debugfs_init(struct btt *btt)
drivers/nvdimm/btt.c
262
btt->debugfs_dir = debugfs_create_dir(dev_name(&btt->nd_btt->dev),
drivers/nvdimm/btt.c
264
if (IS_ERR_OR_NULL(btt->debugfs_dir))
drivers/nvdimm/btt.c
267
list_for_each_entry(arena, &btt->arena_list, list) {
drivers/nvdimm/btt.c
268
arena_debugfs_init(arena, btt->debugfs_dir, i);
drivers/nvdimm/btt.c
745
static struct arena_info *alloc_arena(struct btt *btt, size_t size,
drivers/nvdimm/btt.c
755
arena->nd_btt = btt->nd_btt;
drivers/nvdimm/btt.c
756
arena->sector_size = btt->sector_size;
drivers/nvdimm/btt.c
764
arena->external_lbasize = btt->lbasize;
drivers/nvdimm/btt.c
768
arena->version_major = btt->nd_btt->version_major;
drivers/nvdimm/btt.c
769
arena->version_minor = btt->nd_btt->version_minor;
drivers/nvdimm/btt.c
802
static void free_arenas(struct btt *btt)
drivers/nvdimm/btt.c
806
list_for_each_entry_safe(arena, next, &btt->arena_list, list) {
drivers/nvdimm/btt.c
846
static int discover_arenas(struct btt *btt)
drivers/nvdimm/btt.c
850
size_t remaining = btt->rawsize;
drivers/nvdimm/btt.c
861
arena = alloc_arena(btt, 0, 0, 0);
drivers/nvdimm/btt.c
870
if (!nd_btt_arena_is_valid(btt->nd_btt, super)) {
drivers/nvdimm/btt.c
871
if (remaining == btt->rawsize) {
drivers/nvdimm/btt.c
872
btt->init_state = INIT_NOTFOUND;
drivers/nvdimm/btt.c
905
list_add_tail(&arena->list, &btt->arena_list);
drivers/nvdimm/btt.c
915
btt->num_arenas = num_arenas;
drivers/nvdimm/btt.c
916
btt->nlba = cur_nlba;
drivers/nvdimm/btt.c
917
btt->init_state = INIT_READY;
drivers/nvdimm/btt.c
923
free_arenas(btt);
drivers/nvdimm/btt.c
927
static int create_arenas(struct btt *btt)
drivers/nvdimm/btt.c
929
size_t remaining = btt->rawsize;
drivers/nvdimm/btt.c
940
arena = alloc_arena(btt, arena_size, btt->nlba, cur_off);
drivers/nvdimm/btt.c
942
free_arenas(btt);
drivers/nvdimm/btt.c
945
btt->nlba += arena->external_nlba;
drivers/nvdimm/btt.c
951
list_add_tail(&arena->list, &btt->arena_list);
drivers/nvdimm/nd.h
447
struct btt;
drivers/nvdimm/nd.h
451
struct btt *btt;
drivers/nvdimm/pmem.c
723
struct btt *btt = nd_btt->btt;
drivers/nvdimm/pmem.c
725
nvdimm_check_and_set_ro(btt->btt_disk);
drivers/scsi/aic7xxx/aic79xx.h
1021
uint8_t *btt;