Lines Matching full:pg
693 struct ceph_pg_mapping *pg; in alloc_pg_mapping() local
695 pg = kmalloc(sizeof(*pg) + payload_len, GFP_NOIO); in alloc_pg_mapping()
696 if (!pg) in alloc_pg_mapping()
699 RB_CLEAR_NODE(&pg->node); in alloc_pg_mapping()
700 return pg; in alloc_pg_mapping()
703 static void free_pg_mapping(struct ceph_pg_mapping *pg) in free_pg_mapping() argument
705 WARN_ON(!RB_EMPTY_NODE(&pg->node)); in free_pg_mapping()
707 kfree(pg); in free_pg_mapping()
718 * rbtree of pg pool info in DEFINE_RB_FUNCS2()
1136 struct ceph_pg_mapping *pg = in ceph_osdmap_destroy() local
1139 erase_pg_mapping(&map->pg_temp, pg); in ceph_osdmap_destroy()
1140 free_pg_mapping(pg); in ceph_osdmap_destroy()
1143 struct ceph_pg_mapping *pg = in ceph_osdmap_destroy() local
1146 erase_pg_mapping(&map->primary_temp, pg); in ceph_osdmap_destroy()
1147 free_pg_mapping(pg); in ceph_osdmap_destroy()
1150 struct ceph_pg_mapping *pg = in ceph_osdmap_destroy() local
1153 rb_erase(&pg->node, &map->pg_upmap); in ceph_osdmap_destroy()
1154 kfree(pg); in ceph_osdmap_destroy()
1157 struct ceph_pg_mapping *pg = in ceph_osdmap_destroy() local
1160 rb_erase(&pg->node, &map->pg_upmap_items); in ceph_osdmap_destroy()
1161 kfree(pg); in ceph_osdmap_destroy()
1383 struct ceph_pg_mapping *pg;
1391 pg = lookup_pg_mapping(mapping_root, &pgid);
1392 if (pg) {
1394 erase_pg_mapping(mapping_root, pg);
1395 free_pg_mapping(pg);
1399 pg = fn(p, end, incremental);
1400 if (IS_ERR(pg))
1401 return PTR_ERR(pg);
1403 if (pg) {
1404 pg->pgid = pgid; /* struct */
1405 insert_pg_mapping(mapping_root, pg);
1419 struct ceph_pg_mapping *pg; in __decode_pg_temp() local
1425 if (len > (SIZE_MAX - sizeof(*pg)) / sizeof(u32)) in __decode_pg_temp()
1429 pg = alloc_pg_mapping(len * sizeof(u32)); in __decode_pg_temp()
1430 if (!pg) in __decode_pg_temp()
1433 pg->pg_temp.len = len; in __decode_pg_temp()
1435 pg->pg_temp.osds[i] = ceph_decode_32(p); in __decode_pg_temp()
1437 return pg; in __decode_pg_temp()
1458 struct ceph_pg_mapping *pg; in __decode_primary_temp() local
1465 pg = alloc_pg_mapping(0); in __decode_primary_temp()
1466 if (!pg) in __decode_primary_temp()
1469 pg->primary_temp.osd = osd; in __decode_primary_temp()
1470 return pg; in __decode_primary_temp()
1604 struct ceph_pg_mapping *pg; in __decode_pg_upmap_items() local
1608 if (len > (SIZE_MAX - sizeof(*pg)) / (2 * sizeof(u32))) in __decode_pg_upmap_items()
1612 pg = alloc_pg_mapping(2 * len * sizeof(u32)); in __decode_pg_upmap_items()
1613 if (!pg) in __decode_pg_upmap_items()
1616 pg->pg_upmap_items.len = len; in __decode_pg_upmap_items()
1618 pg->pg_upmap_items.from_to[i][0] = ceph_decode_32(p); in __decode_pg_upmap_items()
1619 pg->pg_upmap_items.from_to[i][1] = ceph_decode_32(p); in __decode_pg_upmap_items()
1622 return pg; in __decode_pg_upmap_items()
2353 * Map an object into a PG.
2409 * Map a raw PG (full precision ps) into an actual PG.
2421 * Map a raw PG (full precision ps) into a placement ps (placement
2509 * Calculate raw set (CRUSH output) for given PG and filter out
2561 struct ceph_pg_mapping *pg; in apply_upmap() local
2564 pg = lookup_pg_mapping(&osdmap->pg_upmap, pgid); in apply_upmap()
2565 if (pg) { in apply_upmap()
2567 for (i = 0; i < pg->pg_upmap.len; i++) { in apply_upmap()
2568 int osd = pg->pg_upmap.osds[i]; in apply_upmap()
2577 for (i = 0; i < pg->pg_upmap.len; i++) in apply_upmap()
2578 raw->osds[i] = pg->pg_upmap.osds[i]; in apply_upmap()
2579 raw->size = pg->pg_upmap.len; in apply_upmap()
2583 pg = lookup_pg_mapping(&osdmap->pg_upmap_items, pgid); in apply_upmap()
2584 if (pg) { in apply_upmap()
2589 for (i = 0; i < pg->pg_upmap_items.len; i++) { in apply_upmap()
2590 int from = pg->pg_upmap_items.from_to[i][0]; in apply_upmap()
2591 int to = pg->pg_upmap_items.from_to[i][1]; in apply_upmap()
2687 * Pick the primary. Feed both the seed (for the pg) and the in apply_primary_affinity()
2728 * Get pg_temp and primary_temp mappings for given PG.
2730 * Note that a PG may have none, only pg_temp, only primary_temp or
2740 struct ceph_pg_mapping *pg; in get_temp_osds() local
2746 pg = lookup_pg_mapping(&osdmap->pg_temp, pgid); in get_temp_osds()
2747 if (pg) { in get_temp_osds()
2748 for (i = 0; i < pg->pg_temp.len; i++) { in get_temp_osds()
2749 if (ceph_osd_is_down(osdmap, pg->pg_temp.osds[i])) { in get_temp_osds()
2755 temp->osds[temp->size++] = pg->pg_temp.osds[i]; in get_temp_osds()
2769 pg = lookup_pg_mapping(&osdmap->primary_temp, pgid); in get_temp_osds()
2770 if (pg) in get_temp_osds()
2771 temp->primary = pg->primary_temp.osd; in get_temp_osds()
2775 * Map a PG to its acting set as well as its up set.
2838 * Return acting primary for given PG, or -1 if none.