Lines Matching refs:osdmap

2204 int ceph_object_locator_to_pg(struct ceph_osdmap *osdmap,  in ceph_object_locator_to_pg()  argument
2211 pi = ceph_pg_pool_by_id(osdmap, oloc->pool); in ceph_object_locator_to_pg()
2292 static void remove_nonexistent_osds(struct ceph_osdmap *osdmap, in remove_nonexistent_osds() argument
2303 if (!ceph_osd_exists(osdmap, set->osds[i])) { in remove_nonexistent_osds()
2314 if (!ceph_osd_exists(osdmap, set->osds[i])) in remove_nonexistent_osds()
2326 static void pg_to_raw_osds(struct ceph_osdmap *osdmap, in pg_to_raw_osds() argument
2340 ruleno = crush_find_rule(osdmap->crush, pi->crush_ruleset, pi->type, in pg_to_raw_osds()
2355 len = do_crush(osdmap, ruleno, pps, raw->osds, pi->size, in pg_to_raw_osds()
2356 osdmap->osd_weight, osdmap->max_osd, pi->id); in pg_to_raw_osds()
2365 remove_nonexistent_osds(osdmap, pi, raw); in pg_to_raw_osds()
2369 static void apply_upmap(struct ceph_osdmap *osdmap, in apply_upmap() argument
2376 pg = lookup_pg_mapping(&osdmap->pg_upmap, pgid); in apply_upmap()
2383 osd < osdmap->max_osd && in apply_upmap()
2384 osdmap->osd_weight[osd] == 0) { in apply_upmap()
2395 pg = lookup_pg_mapping(&osdmap->pg_upmap_items, pgid); in apply_upmap()
2418 to < osdmap->max_osd && in apply_upmap()
2419 osdmap->osd_weight[to] == 0)) { in apply_upmap()
2436 static void raw_to_up_osds(struct ceph_osdmap *osdmap, in raw_to_up_osds() argument
2450 if (ceph_osd_is_down(osdmap, set->osds[i])) { in raw_to_up_osds()
2463 if (ceph_osd_is_down(osdmap, set->osds[i])) in raw_to_up_osds()
2471 static void apply_primary_affinity(struct ceph_osdmap *osdmap, in apply_primary_affinity() argument
2483 if (!osdmap->osd_primary_affinity) in apply_primary_affinity()
2490 osdmap->osd_primary_affinity[osd] != in apply_primary_affinity()
2510 aff = osdmap->osd_primary_affinity[osd]; in apply_primary_affinity()
2547 static void get_temp_osds(struct ceph_osdmap *osdmap, in get_temp_osds() argument
2558 pg = lookup_pg_mapping(&osdmap->pg_temp, pgid); in get_temp_osds()
2561 if (ceph_osd_is_down(osdmap, pg->pg_temp.osds[i])) { in get_temp_osds()
2581 pg = lookup_pg_mapping(&osdmap->primary_temp, pgid); in get_temp_osds()
2593 void ceph_pg_to_up_acting_osds(struct ceph_osdmap *osdmap, in ceph_pg_to_up_acting_osds() argument
2605 pg_to_raw_osds(osdmap, pi, raw_pgid, up, &pps); in ceph_pg_to_up_acting_osds()
2606 apply_upmap(osdmap, &pgid, up); in ceph_pg_to_up_acting_osds()
2607 raw_to_up_osds(osdmap, pi, up); in ceph_pg_to_up_acting_osds()
2608 apply_primary_affinity(osdmap, pi, pps, up); in ceph_pg_to_up_acting_osds()
2609 get_temp_osds(osdmap, pi, &pgid, acting); in ceph_pg_to_up_acting_osds()
2619 bool ceph_pg_to_primary_shard(struct ceph_osdmap *osdmap, in ceph_pg_to_primary_shard() argument
2637 ceph_pg_to_up_acting_osds(osdmap, pi, &pgid, &up, &acting); in ceph_pg_to_primary_shard()
2652 int ceph_pg_to_acting_primary(struct ceph_osdmap *osdmap, in ceph_pg_to_acting_primary() argument
2658 pi = ceph_pg_pool_by_id(osdmap, raw_pgid->pool); in ceph_pg_to_acting_primary()
2662 ceph_pg_to_up_acting_osds(osdmap, pi, raw_pgid, &up, &acting); in ceph_pg_to_acting_primary()