Node.c 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /* vim: set expandtab ts=4 sw=4: */
  2. /*
  3. * You may redistribute this program and/or modify it under the terms of
  4. * the GNU General Public License as published by the Free Software Foundation,
  5. * either version 3 of the License, or (at your option) any later version.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #include "dht/dhtcore/Node.h"
  16. #include "switch/EncodingScheme.h"
  17. #include "util/Assert.h"
  18. #include "util/Bits.h"
  19. void Node_setReach(struct Node_Two* node, uint32_t newReach)
  20. {
  21. if (newReach) {
  22. Assert_true(Node_getBestParent(node));
  23. Assert_true(node->address.path < UINT64_MAX);
  24. Assert_true(newReach > 512);
  25. } else {
  26. Assert_true(!Node_getBestParent(node));
  27. Assert_true(node->address.path == UINT64_MAX);
  28. }
  29. node->reach_pvt = newReach;
  30. }
  31. void Node_setParentReachAndPath(struct Node_Two* node,
  32. struct Node_Link* bestParent,
  33. uint32_t reach,
  34. uint64_t path)
  35. {
  36. if (bestParent) {
  37. Assert_true(bestParent->child == node);
  38. Assert_true(reach > 512);
  39. Assert_true(path != UINT64_MAX);
  40. // make an exception for the self-node
  41. if (Node_getReach(bestParent->parent) <= reach) {
  42. Assert_true(bestParent->parent == node);
  43. Assert_true(reach == UINT32_MAX);
  44. Assert_true(path == 1);
  45. }
  46. } else {
  47. Assert_true(!reach);
  48. Assert_true(path == UINT64_MAX);
  49. }
  50. node->bestParent_pvt = bestParent;
  51. node->reach_pvt = reach;
  52. node->address.path = path;
  53. }
  54. bool Node_isOneHopLink(struct Node_Link* link)
  55. {
  56. struct EncodingScheme* ps = link->parent->encodingScheme;
  57. int num = EncodingScheme_getFormNum(ps, link->cannonicalLabel);
  58. Assert_true(num > -1 && num < ps->count);
  59. return EncodingScheme_formSize(&ps->forms[num]) == Bits_log2x64(link->cannonicalLabel);
  60. }