Revert "bionic: revert to a single (larger) property area"
This reverts commit 5f05348c18286a2cea46eae8acf94ed5b7932fac.
diff --git a/tests/property_benchmark.cpp b/tests/property_benchmark.cpp
index d10be91..7266bd0 100644
--- a/tests/property_benchmark.cpp
+++ b/tests/property_benchmark.cpp
@@ -23,7 +23,7 @@
#include <vector>
#include <string>
-extern void *__system_property_area__;
+extern void *__system_property_regions__[PA_REGION_COUNT];
#define TEST_NUM_PROPS \
Arg(1)->Arg(4)->Arg(16)->Arg(64)->Arg(128)->Arg(256)->Arg(512)->Arg(1024)
@@ -39,8 +39,10 @@
return;
}
- old_pa = __system_property_area__;
- __system_property_area__ = NULL;
+ for (size_t i = 0; i < PA_REGION_COUNT; i++) {
+ old_pa[i] = __system_property_regions__[i];
+ __system_property_regions__[i] = NULL;
+ }
pa_dirname = dirname;
pa_filename = pa_dirname + "/__properties__";
@@ -77,7 +79,9 @@
if (!valid)
return;
- __system_property_area__ = old_pa;
+ for (size_t i = 0; i < PA_REGION_COUNT; i++) {
+ __system_property_regions__[i] = old_pa[i];
+ }
__system_property_set_filename(PROP_FILENAME);
unlink(pa_filename.c_str());
@@ -103,7 +107,7 @@
private:
std::string pa_dirname;
std::string pa_filename;
- void *old_pa;
+ void *old_pa[PA_REGION_COUNT];
};
static void BM_property_get(int iters, int nprops)
diff --git a/tests/system_properties_test.cpp b/tests/system_properties_test.cpp
index b9256c6..bafd2c3 100644
--- a/tests/system_properties_test.cpp
+++ b/tests/system_properties_test.cpp
@@ -24,7 +24,7 @@
#define _REALLY_INCLUDE_SYS__SYSTEM_PROPERTIES_H_
#include <sys/_system_properties.h>
-extern void *__system_property_area__;
+extern void *__system_property_regions__[PA_REGION_COUNT];
struct LocalPropertyTestState {
LocalPropertyTestState() : valid(false) {
@@ -35,8 +35,10 @@
return;
}
- old_pa = __system_property_area__;
- __system_property_area__ = NULL;
+ for (size_t i = 0; i < PA_REGION_COUNT; i++) {
+ old_pa[i] = __system_property_regions__[i];
+ __system_property_regions__[i] = NULL;
+ }
pa_dirname = dirname;
pa_filename = pa_dirname + "/__properties__";
@@ -50,7 +52,9 @@
if (!valid)
return;
- __system_property_area__ = old_pa;
+ for (size_t i = 0; i < PA_REGION_COUNT; i++) {
+ __system_property_regions__[i] = old_pa[i];
+ }
__system_property_set_filename(PROP_FILENAME);
unlink(pa_filename.c_str());
@@ -61,7 +65,7 @@
private:
std::string pa_dirname;
std::string pa_filename;
- void *old_pa;
+ void *old_pa[PA_REGION_COUNT];
};
TEST(properties, add) {