memtablejni.cc 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. // Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
  2. // This source code is licensed under both the GPLv2 (found in the
  3. // COPYING file in the root directory) and Apache 2.0 License
  4. // (found in the LICENSE.Apache file in the root directory).
  5. //
  6. // This file implements the "bridge" between Java and C++ for MemTables.
  7. #include "include/org_rocksdb_HashLinkedListMemTableConfig.h"
  8. #include "include/org_rocksdb_HashSkipListMemTableConfig.h"
  9. #include "include/org_rocksdb_SkipListMemTableConfig.h"
  10. #include "include/org_rocksdb_VectorMemTableConfig.h"
  11. #include "rocksdb/memtablerep.h"
  12. #include "rocksjni/cplusplus_to_java_convert.h"
  13. #include "rocksjni/portal.h"
  14. /*
  15. * Class: org_rocksdb_HashSkipListMemTableConfig
  16. * Method: newMemTableFactoryHandle
  17. * Signature: (JII)J
  18. */
  19. jlong Java_org_rocksdb_HashSkipListMemTableConfig_newMemTableFactoryHandle(
  20. JNIEnv* env, jclass /*jcls*/, jlong jbucket_count, jint jheight,
  21. jint jbranching_factor) {
  22. ROCKSDB_NAMESPACE::Status s =
  23. ROCKSDB_NAMESPACE::JniUtil::check_if_jlong_fits_size_t(jbucket_count);
  24. if (s.ok()) {
  25. return GET_CPLUSPLUS_POINTER(ROCKSDB_NAMESPACE::NewHashSkipListRepFactory(
  26. static_cast<size_t>(jbucket_count), static_cast<int32_t>(jheight),
  27. static_cast<int32_t>(jbranching_factor)));
  28. }
  29. ROCKSDB_NAMESPACE::IllegalArgumentExceptionJni::ThrowNew(env, s);
  30. return 0;
  31. }
  32. /*
  33. * Class: org_rocksdb_HashLinkedListMemTableConfig
  34. * Method: newMemTableFactoryHandle
  35. * Signature: (JJIZI)J
  36. */
  37. jlong Java_org_rocksdb_HashLinkedListMemTableConfig_newMemTableFactoryHandle(
  38. JNIEnv* env, jclass /*jcls*/, jlong jbucket_count,
  39. jlong jhuge_page_tlb_size, jint jbucket_entries_logging_threshold,
  40. jboolean jif_log_bucket_dist_when_flash, jint jthreshold_use_skiplist) {
  41. ROCKSDB_NAMESPACE::Status statusBucketCount =
  42. ROCKSDB_NAMESPACE::JniUtil::check_if_jlong_fits_size_t(jbucket_count);
  43. ROCKSDB_NAMESPACE::Status statusHugePageTlb =
  44. ROCKSDB_NAMESPACE::JniUtil::check_if_jlong_fits_size_t(
  45. jhuge_page_tlb_size);
  46. if (statusBucketCount.ok() && statusHugePageTlb.ok()) {
  47. return GET_CPLUSPLUS_POINTER(ROCKSDB_NAMESPACE::NewHashLinkListRepFactory(
  48. static_cast<size_t>(jbucket_count),
  49. static_cast<size_t>(jhuge_page_tlb_size),
  50. static_cast<int32_t>(jbucket_entries_logging_threshold),
  51. static_cast<bool>(jif_log_bucket_dist_when_flash),
  52. static_cast<int32_t>(jthreshold_use_skiplist)));
  53. }
  54. ROCKSDB_NAMESPACE::IllegalArgumentExceptionJni::ThrowNew(
  55. env, !statusBucketCount.ok() ? statusBucketCount : statusHugePageTlb);
  56. return 0;
  57. }
  58. /*
  59. * Class: org_rocksdb_VectorMemTableConfig
  60. * Method: newMemTableFactoryHandle
  61. * Signature: (J)J
  62. */
  63. jlong Java_org_rocksdb_VectorMemTableConfig_newMemTableFactoryHandle(
  64. JNIEnv* env, jclass /*jcls*/, jlong jreserved_size) {
  65. ROCKSDB_NAMESPACE::Status s =
  66. ROCKSDB_NAMESPACE::JniUtil::check_if_jlong_fits_size_t(jreserved_size);
  67. if (s.ok()) {
  68. return GET_CPLUSPLUS_POINTER(new ROCKSDB_NAMESPACE::VectorRepFactory(
  69. static_cast<size_t>(jreserved_size)));
  70. }
  71. ROCKSDB_NAMESPACE::IllegalArgumentExceptionJni::ThrowNew(env, s);
  72. return 0;
  73. }
  74. /*
  75. * Class: org_rocksdb_SkipListMemTableConfig
  76. * Method: newMemTableFactoryHandle0
  77. * Signature: (J)J
  78. */
  79. jlong Java_org_rocksdb_SkipListMemTableConfig_newMemTableFactoryHandle0(
  80. JNIEnv* env, jclass /*jcls*/, jlong jlookahead) {
  81. ROCKSDB_NAMESPACE::Status s =
  82. ROCKSDB_NAMESPACE::JniUtil::check_if_jlong_fits_size_t(jlookahead);
  83. if (s.ok()) {
  84. return GET_CPLUSPLUS_POINTER(new ROCKSDB_NAMESPACE::SkipListFactory(
  85. static_cast<size_t>(jlookahead)));
  86. }
  87. ROCKSDB_NAMESPACE::IllegalArgumentExceptionJni::ThrowNew(env, s);
  88. return 0;
  89. }