/* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "aslr_test.h" /* run tests if on supported arch */ #if defined(__x86_64__) || defined(__i386__) || defined(__aarch64__) || defined(__arm__) /* make sure the default entropy values matches what we expect */ TEST_F(AslrMmapTest, match_default) { if (user32) { // running 32-bit userspace on 64-bit kernel, only compat used. return; } else { EXPECT_EQ(def, get_mmap_rnd_bits(false)); } } /* make sure the default compat entropy values matches what we expect */ TEST_F(AslrMmapTest, match_compat_default) { if (compat || user32) EXPECT_EQ(def_cmpt, get_mmap_rnd_bits(true)); } /* make sure we can't set entropy below a minimum threshold */ TEST_F(AslrMmapTest, match_min) { if (user32) { // running 32-bit userspace on 64-bit kernel, only compat used. return; } else { EXPECT_FALSE(set_mmap_rnd_bits(min - 1, false)); EXPECT_TRUE(set_mmap_rnd_bits(min, false)); EXPECT_EQ(min, get_mmap_rnd_bits(false)); } } /* make sure we can't set compat entropy below a minimum threshold */ TEST_F(AslrMmapTest, match_compat_min) { if (compat || user32) { EXPECT_FALSE(set_mmap_rnd_bits(min_cmpt - 1, true)); EXPECT_TRUE(set_mmap_rnd_bits(min_cmpt, true)); EXPECT_EQ(min_cmpt, get_mmap_rnd_bits(true)); } } /* make sure we can't set entropy above a maximum threshold */ TEST_F(AslrMmapTest, match_max) { if (user32) { // running 32-bit userspace on 64-bit kernel, only compat used. return; } else { EXPECT_FALSE(set_mmap_rnd_bits(max + 1, false)); EXPECT_TRUE(set_mmap_rnd_bits(max, false)); EXPECT_EQ(max, get_mmap_rnd_bits(false)); } } /* make sure we can't set compat entropy above a maximum threshold */ TEST_F(AslrMmapTest, match_compat_max) { if (compat || user32) { EXPECT_FALSE(set_mmap_rnd_bits(max_cmpt + 1, true)); EXPECT_TRUE(set_mmap_rnd_bits(max_cmpt, true)); EXPECT_EQ(max_cmpt, get_mmap_rnd_bits(true)); } } /* make sure observed entropy is what we expect when we set min value */ TEST_F(AslrMmapTest, entropy_min) { if (user32) { // running 32-bit userspace on 64-bit kernel, only compat used. return; } else { EXPECT_TRUE(set_mmap_rnd_bits(min, false)); EXPECT_EQ(min, calc_mmap_entropy(path, lib, 16)); } } /* make sure observed compat entropy is what we expect when we set min value */ TEST_F(AslrMmapTest, entropy_cmpt_min) { if (compat || user32) { EXPECT_TRUE(set_mmap_rnd_bits(min_cmpt, true)); EXPECT_EQ(min_cmpt, calc_mmap_entropy(SCRAPE_PATH_32, SCRAPE_LIB_32, 16)); } } /* make sure observed entropy is what we expect when we set max value */ TEST_F(AslrMmapTest, entropy_max) { if (user32) { // running 32-bit userspace on 64-bit kernel, only compat used. return; } else { EXPECT_TRUE(set_mmap_rnd_bits(max, false)); EXPECT_EQ(max, calc_mmap_entropy(path, lib, 16)); } } /* make sure observed compat entropy is what we expect when we set max value */ TEST_F(AslrMmapTest, entropy_cmpt_max) { if (compat || user32) { EXPECT_TRUE(set_mmap_rnd_bits(max_cmpt, true)); EXPECT_EQ(max_cmpt, calc_mmap_entropy(SCRAPE_PATH_32, SCRAPE_LIB_32, 16)); } } /* make sure observed entropy is what we expect for default value */ TEST_F(AslrMmapTest, entropy_def) { if (user32) { // running 32-bit userspace on 64-bit kernel, only compat used. return; } else { EXPECT_EQ(def, calc_mmap_entropy(path, lib, 16)); } } /* make sure observed entropy is what we expect for default compat value */ TEST_F(AslrMmapTest, entropy_cmpt_def) { if (compat || user32) { EXPECT_EQ(def_cmpt, calc_mmap_entropy(SCRAPE_PATH_32, SCRAPE_LIB_32, 16)); } } #endif /* supported arch */