diff options
-rw-r--r-- | net/ceph/osdmap.c | 79 |
1 files changed, 4 insertions, 75 deletions
diff --git a/net/ceph/osdmap.c b/net/ceph/osdmap.c index ae8f367c5291..408d14826b5e 100644 --- a/net/ceph/osdmap.c +++ b/net/ceph/osdmap.c | |||
@@ -1456,71 +1456,6 @@ static int do_crush(struct ceph_osdmap *map, int ruleno, int x, | |||
1456 | } | 1456 | } |
1457 | 1457 | ||
1458 | /* | 1458 | /* |
1459 | * Calculate raw osd vector for the given pgid. Return pointer to osd | ||
1460 | * array, or NULL on failure. | ||
1461 | */ | ||
1462 | static int *calc_pg_raw(struct ceph_osdmap *osdmap, struct ceph_pg pgid, | ||
1463 | int *osds, int *num) | ||
1464 | { | ||
1465 | struct ceph_pg_mapping *pg; | ||
1466 | struct ceph_pg_pool_info *pool; | ||
1467 | int ruleno; | ||
1468 | int r; | ||
1469 | u32 pps; | ||
1470 | |||
1471 | pool = __lookup_pg_pool(&osdmap->pg_pools, pgid.pool); | ||
1472 | if (!pool) | ||
1473 | return NULL; | ||
1474 | |||
1475 | /* pg_temp? */ | ||
1476 | pgid.seed = ceph_stable_mod(pgid.seed, pool->pg_num, | ||
1477 | pool->pg_num_mask); | ||
1478 | pg = __lookup_pg_mapping(&osdmap->pg_temp, pgid); | ||
1479 | if (pg) { | ||
1480 | *num = pg->pg_temp.len; | ||
1481 | return pg->pg_temp.osds; | ||
1482 | } | ||
1483 | |||
1484 | /* crush */ | ||
1485 | ruleno = crush_find_rule(osdmap->crush, pool->crush_ruleset, | ||
1486 | pool->type, pool->size); | ||
1487 | if (ruleno < 0) { | ||
1488 | pr_err("no crush rule pool %lld ruleset %d type %d size %d\n", | ||
1489 | pgid.pool, pool->crush_ruleset, pool->type, | ||
1490 | pool->size); | ||
1491 | return NULL; | ||
1492 | } | ||
1493 | |||
1494 | if (pool->flags & CEPH_POOL_FLAG_HASHPSPOOL) { | ||
1495 | /* hash pool id and seed sothat pool PGs do not overlap */ | ||
1496 | pps = crush_hash32_2(CRUSH_HASH_RJENKINS1, | ||
1497 | ceph_stable_mod(pgid.seed, pool->pgp_num, | ||
1498 | pool->pgp_num_mask), | ||
1499 | pgid.pool); | ||
1500 | } else { | ||
1501 | /* | ||
1502 | * legacy ehavior: add ps and pool together. this is | ||
1503 | * not a great approach because the PGs from each pool | ||
1504 | * will overlap on top of each other: 0.5 == 1.4 == | ||
1505 | * 2.3 == ... | ||
1506 | */ | ||
1507 | pps = ceph_stable_mod(pgid.seed, pool->pgp_num, | ||
1508 | pool->pgp_num_mask) + | ||
1509 | (unsigned)pgid.pool; | ||
1510 | } | ||
1511 | r = do_crush(osdmap, ruleno, pps, osds, min_t(int, pool->size, *num), | ||
1512 | osdmap->osd_weight, osdmap->max_osd); | ||
1513 | if (r < 0) { | ||
1514 | pr_err("error %d from crush rule: pool %lld ruleset %d type %d" | ||
1515 | " size %d\n", r, pgid.pool, pool->crush_ruleset, | ||
1516 | pool->type, pool->size); | ||
1517 | return NULL; | ||
1518 | } | ||
1519 | *num = r; | ||
1520 | return osds; | ||
1521 | } | ||
1522 | |||
1523 | /* | ||
1524 | * Calculate raw (crush) set for given pgid. | 1459 | * Calculate raw (crush) set for given pgid. |
1525 | * | 1460 | * |
1526 | * Return raw set length, or error. | 1461 | * Return raw set length, or error. |
@@ -1776,17 +1711,11 @@ int ceph_calc_pg_acting(struct ceph_osdmap *osdmap, struct ceph_pg pgid, | |||
1776 | */ | 1711 | */ |
1777 | int ceph_calc_pg_primary(struct ceph_osdmap *osdmap, struct ceph_pg pgid) | 1712 | int ceph_calc_pg_primary(struct ceph_osdmap *osdmap, struct ceph_pg pgid) |
1778 | { | 1713 | { |
1779 | int rawosds[CEPH_PG_MAX_SIZE], *osds; | 1714 | int osds[CEPH_PG_MAX_SIZE]; |
1780 | int i, num = CEPH_PG_MAX_SIZE; | 1715 | int primary; |
1781 | 1716 | ||
1782 | osds = calc_pg_raw(osdmap, pgid, rawosds, &num); | 1717 | ceph_calc_pg_acting(osdmap, pgid, osds, &primary); |
1783 | if (!osds) | ||
1784 | return -1; | ||
1785 | 1718 | ||
1786 | /* primary is first up osd */ | 1719 | return primary; |
1787 | for (i = 0; i < num; i++) | ||
1788 | if (ceph_osd_is_up(osdmap, osds[i])) | ||
1789 | return osds[i]; | ||
1790 | return -1; | ||
1791 | } | 1720 | } |
1792 | EXPORT_SYMBOL(ceph_calc_pg_primary); | 1721 | EXPORT_SYMBOL(ceph_calc_pg_primary); |