Plumb WriteBufferManager through JNI (#4492)
Summary: Allow rocks java to explicitly create WriteBufferManager by plumbing it to the native code through JNI. Pull Request resolved: https://github.com/facebook/rocksdb/pull/4492 Differential Revision: D10428506 Pulled By: sagar0 fbshipit-source-id: cd9dd8c2ef745a0303416b44e2080547bdcca1fdmain
parent
45f213b558
commit
a4d9aa6b18
@ -0,0 +1,38 @@ |
|||||||
|
// Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
|
||||||
|
// This source code is licensed under both the GPLv2 (found in the
|
||||||
|
// COPYING file in the root directory) and Apache 2.0 License
|
||||||
|
// (found in the LICENSE.Apache file in the root directory).
|
||||||
|
|
||||||
|
#include <jni.h> |
||||||
|
|
||||||
|
#include "include/org_rocksdb_WriteBufferManager.h" |
||||||
|
|
||||||
|
#include "rocksdb/cache.h" |
||||||
|
#include "rocksdb/write_buffer_manager.h" |
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_rocksdb_WriteBufferManager |
||||||
|
* Method: newWriteBufferManager |
||||||
|
* Signature: (JJ)J |
||||||
|
*/ |
||||||
|
jlong Java_org_rocksdb_WriteBufferManager_newWriteBufferManager( |
||||||
|
JNIEnv* /*env*/, jclass /*jclazz*/, jlong jbuffer_size, jlong jcache_handle) { |
||||||
|
auto* cache_ptr = |
||||||
|
reinterpret_cast<std::shared_ptr<rocksdb::Cache> *>(jcache_handle); |
||||||
|
auto* write_buffer_manager = new std::shared_ptr<rocksdb::WriteBufferManager>( |
||||||
|
std::make_shared<rocksdb::WriteBufferManager>(jbuffer_size, *cache_ptr)); |
||||||
|
return reinterpret_cast<jlong>(write_buffer_manager); |
||||||
|
} |
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_rocksdb_WriteBufferManager |
||||||
|
* Method: disposeInternal |
||||||
|
* Signature: (J)V |
||||||
|
*/ |
||||||
|
void Java_org_rocksdb_WriteBufferManager_disposeInternal( |
||||||
|
JNIEnv* /*env*/, jobject /*jobj*/, jlong jhandle) { |
||||||
|
auto* write_buffer_manager = |
||||||
|
reinterpret_cast<std::shared_ptr<rocksdb::WriteBufferManager> *>(jhandle); |
||||||
|
assert(write_buffer_manager != nullptr); |
||||||
|
delete write_buffer_manager; |
||||||
|
} |
@ -0,0 +1,30 @@ |
|||||||
|
package org.rocksdb; |
||||||
|
|
||||||
|
import org.rocksdb.Cache; |
||||||
|
|
||||||
|
/** |
||||||
|
* Java wrapper over native write_buffer_manager class
|
||||||
|
*/ |
||||||
|
public class WriteBufferManager extends RocksObject { |
||||||
|
static { |
||||||
|
RocksDB.loadLibrary(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Construct a new instance of WriteBufferManager. |
||||||
|
* |
||||||
|
* Check <a href="https://github.com/facebook/rocksdb/wiki/Write-Buffer-Manager"> |
||||||
|
* https://github.com/facebook/rocksdb/wiki/Write-Buffer-Manager</a>
|
||||||
|
* for more details on when to use it |
||||||
|
* |
||||||
|
* @param bufferSizeBytes buffer size(in bytes) to use for native write_buffer_manager |
||||||
|
* @param cache cache whose memory should be bounded by this write buffer manager |
||||||
|
*/ |
||||||
|
public WriteBufferManager(final long bufferSizeBytes, final Cache cache){ |
||||||
|
super(newWriteBufferManager(bufferSizeBytes, cache.nativeHandle_)); |
||||||
|
} |
||||||
|
|
||||||
|
private native static long newWriteBufferManager(final long bufferSizeBytes, final long cacheHandle); |
||||||
|
@Override |
||||||
|
protected native void disposeInternal(final long handle); |
||||||
|
} |
Loading…
Reference in new issue