mirror of
https://github.com/monero-project/monero.git
synced 2025-01-18 23:53:39 +02:00
Merge pull request #415
180bcde
build: default to Berkeley DB for 32 bit and ARM (moneromooo-monero)791d8cb
db_bdb: fix hard fork keys (moneromooo-monero)
This commit is contained in:
commit
2ce54a0d3e
@ -216,8 +216,17 @@ if (DATABASE STREQUAL "lmdb")
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if (BERKELEY_DB AND (ARCH_WIDTH STREQUAL "32" OR ARM6 OR ARM7))
|
||||||
|
message(STATUS "Using Berkeley DB as default DB type")
|
||||||
|
add_definitions("-DDEFAULT_DB_TYPE=\"berkeley\"")
|
||||||
|
else()
|
||||||
|
message(STATUS "Using LMDB as default DB type")
|
||||||
|
add_definitions("-DDEFAULT_DB_TYPE=\"lmdb\"")
|
||||||
|
endif()
|
||||||
elseif (DATABASE STREQUAL "memory")
|
elseif (DATABASE STREQUAL "memory")
|
||||||
set(BLOCKCHAIN_DB DB_MEMORY)
|
set(BLOCKCHAIN_DB DB_MEMORY)
|
||||||
|
add_definitions("-DDEFAULT_DB_TYPE=\"memory\"")
|
||||||
else()
|
else()
|
||||||
die("Invalid database type: ${DATABASE}")
|
die("Invalid database type: ${DATABASE}")
|
||||||
endif()
|
endif()
|
||||||
|
@ -1865,7 +1865,7 @@ void BlockchainBDB::set_hard_fork_starting_height(uint8_t version, uint64_t heig
|
|||||||
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
||||||
check_open();
|
check_open();
|
||||||
|
|
||||||
Dbt_copy<uint8_t> val_key(version);
|
Dbt_copy<uint32_t> val_key(version + 1);
|
||||||
Dbt_copy<uint64_t> val(height);
|
Dbt_copy<uint64_t> val(height);
|
||||||
if (m_hf_starting_heights->put(DB_DEFAULT_TX, &val_key, &val, 0))
|
if (m_hf_starting_heights->put(DB_DEFAULT_TX, &val_key, &val, 0))
|
||||||
throw1(DB_ERROR("Error adding hard fork starting height to db transaction."));
|
throw1(DB_ERROR("Error adding hard fork starting height to db transaction."));
|
||||||
@ -1876,7 +1876,7 @@ uint64_t BlockchainBDB::get_hard_fork_starting_height(uint8_t version) const
|
|||||||
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
||||||
check_open();
|
check_open();
|
||||||
|
|
||||||
Dbt_copy<uint8_t> key(version);
|
Dbt_copy<uint32_t> key(version + 1);
|
||||||
Dbt_copy<uint64_t> result;
|
Dbt_copy<uint64_t> result;
|
||||||
|
|
||||||
auto get_result = m_hf_starting_heights->get(DB_DEFAULT_TX, &key, &result, 0);
|
auto get_result = m_hf_starting_heights->get(DB_DEFAULT_TX, &key, &result, 0);
|
||||||
@ -1893,7 +1893,7 @@ void BlockchainBDB::set_hard_fork_version(uint64_t height, uint8_t version)
|
|||||||
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
||||||
check_open();
|
check_open();
|
||||||
|
|
||||||
Dbt_copy<uint64_t> val_key(height);
|
Dbt_copy<uint32_t> val_key(height + 1);
|
||||||
Dbt_copy<uint8_t> val(version);
|
Dbt_copy<uint8_t> val(version);
|
||||||
if (m_hf_versions->put(DB_DEFAULT_TX, &val_key, &val, 0))
|
if (m_hf_versions->put(DB_DEFAULT_TX, &val_key, &val, 0))
|
||||||
throw1(DB_ERROR("Error adding hard fork version to db transaction."));
|
throw1(DB_ERROR("Error adding hard fork version to db transaction."));
|
||||||
@ -1904,7 +1904,7 @@ uint8_t BlockchainBDB::get_hard_fork_version(uint64_t height) const
|
|||||||
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
LOG_PRINT_L3("BlockchainBDB::" << __func__);
|
||||||
check_open();
|
check_open();
|
||||||
|
|
||||||
Dbt_copy<uint64_t> key(height);
|
Dbt_copy<uint32_t> key(height + 1);
|
||||||
Dbt_copy<uint8_t> result;
|
Dbt_copy<uint8_t> result;
|
||||||
|
|
||||||
auto get_result = m_hf_versions->get(DB_DEFAULT_TX, &key, &result, 0);
|
auto get_result = m_hf_versions->get(DB_DEFAULT_TX, &key, &result, 0);
|
||||||
|
@ -73,7 +73,7 @@ namespace daemon_args
|
|||||||
const command_line::arg_descriptor<std::string> arg_db_type = {
|
const command_line::arg_descriptor<std::string> arg_db_type = {
|
||||||
"db-type"
|
"db-type"
|
||||||
, "Specify database type"
|
, "Specify database type"
|
||||||
, "lmdb"
|
, DEFAULT_DB_TYPE
|
||||||
};
|
};
|
||||||
const command_line::arg_descriptor<uint64_t> arg_prep_blocks_threads = {
|
const command_line::arg_descriptor<uint64_t> arg_prep_blocks_threads = {
|
||||||
"prep-blocks-threads"
|
"prep-blocks-threads"
|
||||||
|
Loading…
Reference in New Issue
Block a user