blob: 489b7018deda2f7894fd2c53eaa64374e205311f [file] [log] [blame]
Nick Kralevich5bcf3982013-06-28 10:34:09 -07001/*
2 * Copyright (C) 2013 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Dan Albertf68dcbe2016-02-02 17:13:03 -080017// -Werror is on whether we like it or not, and we're intentionally doing awful
18// things in this file. GCC is dumb and doesn't have a specific error class for
19// the fortify failures (it's just -Werror), so we can't use anything more
20// constrained than disabling all the warnings in the file :( It also won't let
21// us use system_header in a .cpp file, so we have to #include this from
22// fortify_test_main.cpp.
23#pragma GCC system_header
24
Nick Kralevich5bcf3982013-06-28 10:34:09 -070025#include <gtest/gtest.h>
Yabin Cui9df70402014-11-05 18:01:01 -080026#include "BionicDeathTest.h"
Nick Kralevich5bcf3982013-06-28 10:34:09 -070027
Yabin Cui9df70402014-11-05 18:01:01 -080028#include <fcntl.h>
29#include <malloc.h>
Elliott Hughes4674e382015-02-02 09:15:19 -080030#include <poll.h>
Yabin Cui9df70402014-11-05 18:01:01 -080031#include <signal.h>
32#include <stdarg.h>
33#include <string.h>
34#include <sys/socket.h>
35#include <sys/stat.h>
36#include <sys/types.h>
Yabin Cuif4fe6932015-02-03 17:52:32 -080037#include <time.h>
Yabin Cui9df70402014-11-05 18:01:01 -080038
Elliott Hughesd036e942015-02-02 11:18:58 -080039#if __BIONIC__
40#define ASSERT_FORTIFY(expr) ASSERT_EXIT(expr, testing::KilledBySignal(SIGABRT), "FORTIFY")
41#else
42#define ASSERT_FORTIFY(expr) ASSERT_EXIT(expr, testing::KilledBySignal(SIGABRT), "")
43#endif
44
Yabin Cui9df70402014-11-05 18:01:01 -080045// Fortify test code needs to run multiple times, so TEST_NAME macro is used to
46// distinguish different tests. TEST_NAME is defined in compilation command.
Nick Kralevich5bcf3982013-06-28 10:34:09 -070047#define DEATHTEST_PASTER(name) name##_DeathTest
48#define DEATHTEST_EVALUATOR(name) DEATHTEST_PASTER(name)
49#define DEATHTEST DEATHTEST_EVALUATOR(TEST_NAME)
50
Yabin Cui9df70402014-11-05 18:01:01 -080051class DEATHTEST : public BionicDeathTest {};
Nick Kralevichbe0e43b2014-07-23 13:56:23 -070052
Nick Kralevich5bcf3982013-06-28 10:34:09 -070053#if defined(_FORTIFY_SOURCE) && _FORTIFY_SOURCE == 2
54struct foo {
55 char empty[0];
56 char one[1];
57 char a[10];
58 char b[10];
59};
60
Nick Kralevichbe0e43b2014-07-23 13:56:23 -070061TEST_F(DEATHTEST, stpncpy_fortified2) {
Christopher Ferris950a58e2014-04-04 14:38:18 -070062 foo myfoo;
63 int copy_amt = atoi("11");
Elliott Hughesd036e942015-02-02 11:18:58 -080064 ASSERT_FORTIFY(stpncpy(myfoo.a, "01234567890", copy_amt));
Christopher Ferris950a58e2014-04-04 14:38:18 -070065}
Christopher Ferris950a58e2014-04-04 14:38:18 -070066
Nick Kralevichbe0e43b2014-07-23 13:56:23 -070067TEST_F(DEATHTEST, stpncpy2_fortified2) {
Christopher Ferris950a58e2014-04-04 14:38:18 -070068 foo myfoo;
69 memset(&myfoo, 0, sizeof(myfoo));
70 myfoo.one[0] = 'A'; // not null terminated string
Elliott Hughesd036e942015-02-02 11:18:58 -080071 ASSERT_FORTIFY(stpncpy(myfoo.b, myfoo.one, sizeof(myfoo.b)));
Christopher Ferris950a58e2014-04-04 14:38:18 -070072}
Christopher Ferris950a58e2014-04-04 14:38:18 -070073
Nick Kralevichbe0e43b2014-07-23 13:56:23 -070074TEST_F(DEATHTEST, strncpy_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -070075 foo myfoo;
76 int copy_amt = atoi("11");
Elliott Hughesd036e942015-02-02 11:18:58 -080077 ASSERT_FORTIFY(strncpy(myfoo.a, "01234567890", copy_amt));
Nick Kralevich5bcf3982013-06-28 10:34:09 -070078}
Nick Kralevich5bcf3982013-06-28 10:34:09 -070079
Nick Kralevichbe0e43b2014-07-23 13:56:23 -070080TEST_F(DEATHTEST, strncpy2_fortified2) {
Nick Kralevich93501d32013-08-28 10:47:43 -070081 foo myfoo;
82 memset(&myfoo, 0, sizeof(myfoo));
83 myfoo.one[0] = 'A'; // not null terminated string
Elliott Hughesd036e942015-02-02 11:18:58 -080084 ASSERT_FORTIFY(strncpy(myfoo.b, myfoo.one, sizeof(myfoo.b)));
Nick Kralevich93501d32013-08-28 10:47:43 -070085}
Nick Kralevich93501d32013-08-28 10:47:43 -070086
Nick Kralevichbe0e43b2014-07-23 13:56:23 -070087TEST_F(DEATHTEST, sprintf_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -070088 foo myfoo;
89 char source_buf[15];
90 memcpy(source_buf, "12345678901234", 15);
Elliott Hughesd036e942015-02-02 11:18:58 -080091 ASSERT_FORTIFY(sprintf(myfoo.a, "%s", source_buf));
Nick Kralevich5bcf3982013-06-28 10:34:09 -070092}
Nick Kralevich5bcf3982013-06-28 10:34:09 -070093
Nick Kralevich884a3de2014-10-06 00:39:47 +000094TEST_F(DEATHTEST, sprintf2_fortified2) {
Nick Kralevich884a3de2014-10-06 00:39:47 +000095 foo myfoo;
Elliott Hughesd036e942015-02-02 11:18:58 -080096 ASSERT_FORTIFY(sprintf(myfoo.a, "0123456789"));
Nick Kralevich884a3de2014-10-06 00:39:47 +000097}
Nick Kralevich884a3de2014-10-06 00:39:47 +000098
Nick Kralevich5bcf3982013-06-28 10:34:09 -070099static int vsprintf_helper2(const char *fmt, ...) {
100 foo myfoo;
101 va_list va;
102 int result;
103
104 va_start(va, fmt);
105 result = vsprintf(myfoo.a, fmt, va); // should crash here
106 va_end(va);
107 return result;
108}
109
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700110TEST_F(DEATHTEST, vsprintf_fortified2) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800111 ASSERT_FORTIFY(vsprintf_helper2("%s", "0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700112}
113
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700114TEST_F(DEATHTEST, vsprintf2_fortified2) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800115 ASSERT_FORTIFY(vsprintf_helper2("0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700116}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700117
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700118static int vsnprintf_helper2(const char *fmt, ...) {
119 foo myfoo;
120 va_list va;
121 int result;
122 size_t size = atoi("11");
123
124 va_start(va, fmt);
125 result = vsnprintf(myfoo.a, size, fmt, va); // should crash here
126 va_end(va);
127 return result;
128}
129
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700130TEST_F(DEATHTEST, vsnprintf_fortified2) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800131 ASSERT_FORTIFY(vsnprintf_helper2("%s", "0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700132}
133
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700134TEST_F(DEATHTEST, vsnprintf2_fortified2) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800135 ASSERT_FORTIFY(vsnprintf_helper2("0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700136}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700137
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700138// zero sized target with "\0" source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700139TEST_F(DEATHTEST, stpcpy_fortified2) {
Christopher Ferris950a58e2014-04-04 14:38:18 -0700140#if defined(__BIONIC__)
Christopher Ferris950a58e2014-04-04 14:38:18 -0700141 foo myfoo;
142 char* src = strdup("");
Elliott Hughesd036e942015-02-02 11:18:58 -0800143 ASSERT_FORTIFY(stpcpy(myfoo.empty, src));
Christopher Ferris950a58e2014-04-04 14:38:18 -0700144 free(src);
145#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800146 GTEST_SKIP() << "stpcpy not available";
Christopher Ferris950a58e2014-04-04 14:38:18 -0700147#endif // __BIONIC__
148}
Christopher Ferris950a58e2014-04-04 14:38:18 -0700149
Christopher Ferris950a58e2014-04-04 14:38:18 -0700150// zero sized target with "\0" source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700151TEST_F(DEATHTEST, strcpy_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800152#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700153 foo myfoo;
154 char* src = strdup("");
Elliott Hughesd036e942015-02-02 11:18:58 -0800155 ASSERT_FORTIFY(strcpy(myfoo.empty, src));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700156 free(src);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800157#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800158 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800159#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700160}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700161
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700162// zero sized target with longer source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700163TEST_F(DEATHTEST, strcpy2_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800164#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700165 foo myfoo;
166 char* src = strdup("1");
Elliott Hughesd036e942015-02-02 11:18:58 -0800167 ASSERT_FORTIFY(strcpy(myfoo.empty, src));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700168 free(src);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800169#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800170 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800171#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700172}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700173
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700174// one byte target with longer source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700175TEST_F(DEATHTEST, strcpy3_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800176#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700177 foo myfoo;
178 char* src = strdup("12");
Elliott Hughesd036e942015-02-02 11:18:58 -0800179 ASSERT_FORTIFY(strcpy(myfoo.one, src));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700180 free(src);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800181#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800182 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800183#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700184}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700185
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700186TEST_F(DEATHTEST, strchr_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800187#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700188 foo myfoo;
189 memcpy(myfoo.a, "0123456789", sizeof(myfoo.a));
190 myfoo.b[0] = '\0';
Elliott Hughesd036e942015-02-02 11:18:58 -0800191 ASSERT_FORTIFY(printf("%s", strchr(myfoo.a, 'a')));
George Burgess IVbd3d2082017-04-04 17:34:02 -0700192 ASSERT_FORTIFY(printf("%s", strchr(static_cast<const char*>(myfoo.a), 'a')));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800193#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800194 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800195#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700196}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700197
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700198TEST_F(DEATHTEST, strrchr_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800199#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700200 foo myfoo;
201 memcpy(myfoo.a, "0123456789", 10);
202 memcpy(myfoo.b, "01234", 6);
Elliott Hughesd036e942015-02-02 11:18:58 -0800203 ASSERT_FORTIFY(printf("%s", strrchr(myfoo.a, 'a')));
George Burgess IVbd3d2082017-04-04 17:34:02 -0700204 ASSERT_FORTIFY(printf("%s", strrchr(static_cast<const char*>(myfoo.a), 'a')));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800205#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800206 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800207#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700208}
George Burgess IVbd3d2082017-04-04 17:34:02 -0700209
210TEST_F(DEATHTEST, memchr_fortified2) {
211#if defined(__BIONIC__)
212 foo myfoo;
213 volatile int asize = sizeof(myfoo.a) + 1;
214 memcpy(myfoo.a, "0123456789", sizeof(myfoo.a));
215 ASSERT_FORTIFY(printf("%s", memchr(myfoo.a, 'a', asize)));
216 ASSERT_FORTIFY(printf("%s", memchr(static_cast<const void*>(myfoo.a), 'a', asize)));
217#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800218 GTEST_SKIP() << "glibc is broken";
George Burgess IVbd3d2082017-04-04 17:34:02 -0700219#endif // __BIONIC__
220}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700221
Elliott Hughes55a8cc22017-11-08 21:22:44 -0800222TEST_F(DEATHTEST, memrchr_fortified2) {
223#if defined(__BIONIC__)
224 foo myfoo;
225 volatile int asize = sizeof(myfoo.a) + 1;
226 memcpy(myfoo.a, "0123456789", sizeof(myfoo.a));
227 ASSERT_FORTIFY(printf("%s", memrchr(myfoo.a, 'a', asize)));
228 ASSERT_FORTIFY(printf("%s", memrchr(static_cast<const void*>(myfoo.a), 'a', asize)));
229#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800230 GTEST_SKIP() << "glibc is broken";
Elliott Hughes55a8cc22017-11-08 21:22:44 -0800231#endif // __BIONIC__
232}
233
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700234TEST_F(DEATHTEST, strlcpy_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800235#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700236 foo myfoo;
237 strcpy(myfoo.a, "01");
238 size_t n = strlen(myfoo.a);
Elliott Hughesd036e942015-02-02 11:18:58 -0800239 ASSERT_FORTIFY(strlcpy(myfoo.one, myfoo.a, n));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800240#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800241 GTEST_SKIP() << "strlcpy not available";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800242#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700243}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700244
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700245TEST_F(DEATHTEST, strlcat_fortified2) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800246#if defined(__BIONIC__)
Nick Kralevicha6cde392013-06-29 08:15:25 -0700247 foo myfoo;
248 strcpy(myfoo.a, "01");
249 myfoo.one[0] = '\0';
250 size_t n = strlen(myfoo.a);
Elliott Hughesd036e942015-02-02 11:18:58 -0800251 ASSERT_FORTIFY(strlcat(myfoo.one, myfoo.a, n));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800252#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800253 GTEST_SKIP() << "strlcat not available";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800254#endif // __BIONIC__
Nick Kralevicha6cde392013-06-29 08:15:25 -0700255}
Nick Kralevicha6cde392013-06-29 08:15:25 -0700256
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700257TEST_F(DEATHTEST, strncat_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700258 foo myfoo;
259 size_t n = atoi("10"); // avoid compiler optimizations
260 strncpy(myfoo.a, "012345678", n);
Elliott Hughesd036e942015-02-02 11:18:58 -0800261 ASSERT_FORTIFY(strncat(myfoo.a, "9", n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700262}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700263
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700264TEST_F(DEATHTEST, strncat2_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700265 foo myfoo;
266 myfoo.a[0] = '\0';
267 size_t n = atoi("10"); // avoid compiler optimizations
Elliott Hughesd036e942015-02-02 11:18:58 -0800268 ASSERT_FORTIFY(strncat(myfoo.a, "0123456789", n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700269}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700270
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700271TEST_F(DEATHTEST, strncat3_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700272 foo myfoo;
273 memcpy(myfoo.a, "0123456789", sizeof(myfoo.a)); // unterminated string
274 myfoo.b[0] = '\0';
275 size_t n = atoi("10"); // avoid compiler optimizations
Elliott Hughesd036e942015-02-02 11:18:58 -0800276 ASSERT_FORTIFY(strncat(myfoo.b, myfoo.a, n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700277}
278
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700279TEST_F(DEATHTEST, strcat_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700280 char src[11];
281 strcpy(src, "0123456789");
282 foo myfoo;
283 myfoo.a[0] = '\0';
Elliott Hughesd036e942015-02-02 11:18:58 -0800284 ASSERT_FORTIFY(strcat(myfoo.a, src));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700285}
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700286
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700287TEST_F(DEATHTEST, strcat2_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700288 foo myfoo;
289 memcpy(myfoo.a, "0123456789", sizeof(myfoo.a)); // unterminated string
290 myfoo.b[0] = '\0';
Elliott Hughesd036e942015-02-02 11:18:58 -0800291 ASSERT_FORTIFY(strcat(myfoo.b, myfoo.a));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700292}
293
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700294TEST_F(DEATHTEST, snprintf_fortified2) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700295 foo myfoo;
296 strcpy(myfoo.a, "012345678");
297 size_t n = strlen(myfoo.a) + 2;
Elliott Hughesd036e942015-02-02 11:18:58 -0800298 ASSERT_FORTIFY(snprintf(myfoo.b, n, "a%s", myfoo.a));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700299}
300
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700301TEST_F(DEATHTEST, bzero_fortified2) {
Nick Kralevicha6cde392013-06-29 08:15:25 -0700302 foo myfoo;
303 memcpy(myfoo.b, "0123456789", sizeof(myfoo.b));
304 size_t n = atoi("11");
Elliott Hughesd036e942015-02-02 11:18:58 -0800305 ASSERT_FORTIFY(bzero(myfoo.b, n));
Nick Kralevicha6cde392013-06-29 08:15:25 -0700306}
307
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700308#endif /* defined(_FORTIFY_SOURCE) && _FORTIFY_SOURCE=2 */
309
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700310// multibyte target where we over fill (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700311TEST_F(DEATHTEST, strcpy_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800312#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700313 char buf[10];
314 char *orig = strdup("0123456789");
Elliott Hughesd036e942015-02-02 11:18:58 -0800315 ASSERT_FORTIFY(strcpy(buf, orig));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700316 free(orig);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800317#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800318 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800319#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700320}
321
322// zero sized target with "\0" source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700323TEST_F(DEATHTEST, strcpy2_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800324#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700325 char buf[0];
326 char *orig = strdup("");
Elliott Hughesd036e942015-02-02 11:18:58 -0800327 ASSERT_FORTIFY(strcpy(buf, orig));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700328 free(orig);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800329#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800330 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800331#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700332}
333
334// zero sized target with longer source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700335TEST_F(DEATHTEST, strcpy3_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800336#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700337 char buf[0];
338 char *orig = strdup("1");
Elliott Hughesd036e942015-02-02 11:18:58 -0800339 ASSERT_FORTIFY(strcpy(buf, orig));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700340 free(orig);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800341#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800342 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800343#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700344}
345
346// one byte target with longer source (should fail)
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700347TEST_F(DEATHTEST, strcpy4_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800348#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700349 char buf[1];
350 char *orig = strdup("12");
Elliott Hughesd036e942015-02-02 11:18:58 -0800351 ASSERT_FORTIFY(strcpy(buf, orig));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700352 free(orig);
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800353#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800354 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800355#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700356}
357
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700358TEST_F(DEATHTEST, strlen_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800359#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700360 char buf[10];
361 memcpy(buf, "0123456789", sizeof(buf));
Elliott Hughesd036e942015-02-02 11:18:58 -0800362 ASSERT_FORTIFY(printf("%zd", strlen(buf)));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800363#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800364 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800365#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700366}
367
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700368TEST_F(DEATHTEST, strchr_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800369#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700370 char buf[10];
371 memcpy(buf, "0123456789", sizeof(buf));
Elliott Hughesd036e942015-02-02 11:18:58 -0800372 ASSERT_FORTIFY(printf("%s", strchr(buf, 'a')));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800373#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800374 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800375#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700376}
377
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700378TEST_F(DEATHTEST, strrchr_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800379#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700380 char buf[10];
381 memcpy(buf, "0123456789", sizeof(buf));
Elliott Hughesd036e942015-02-02 11:18:58 -0800382 ASSERT_FORTIFY(printf("%s", strrchr(buf, 'a')));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800383#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800384 GTEST_SKIP() << "glibc is broken";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800385#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700386}
387
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700388TEST_F(DEATHTEST, strlcpy_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800389#if defined(__BIONIC__)
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700390 char bufa[15];
391 char bufb[10];
392 strcpy(bufa, "01234567890123");
393 size_t n = strlen(bufa);
Elliott Hughesd036e942015-02-02 11:18:58 -0800394 ASSERT_FORTIFY(strlcpy(bufb, bufa, n));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800395#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800396 GTEST_SKIP() << "strlcpy not available";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800397#endif // __BIONIC__
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700398}
399
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700400TEST_F(DEATHTEST, strlcat_fortified) {
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800401#if defined(__BIONIC__)
Nick Kralevicha6cde392013-06-29 08:15:25 -0700402 char bufa[15];
403 char bufb[10];
404 bufb[0] = '\0';
405 strcpy(bufa, "01234567890123");
406 size_t n = strlen(bufa);
Elliott Hughesd036e942015-02-02 11:18:58 -0800407 ASSERT_FORTIFY(strlcat(bufb, bufa, n));
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800408#else // __BIONIC__
Elliott Hughesbcaa4542019-03-08 15:20:23 -0800409 GTEST_SKIP() << "strlcat not available";
Christopher Ferrisf04935c2013-12-20 18:43:21 -0800410#endif // __BIONIC__
Nick Kralevicha6cde392013-06-29 08:15:25 -0700411}
412
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700413TEST_F(DEATHTEST, sprintf_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700414 char buf[10];
415 char source_buf[15];
416 memcpy(source_buf, "12345678901234", 15);
Elliott Hughesd036e942015-02-02 11:18:58 -0800417 ASSERT_FORTIFY(sprintf(buf, "%s", source_buf));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700418}
419
George Burgess IVe9c0e822018-03-22 11:22:59 -0700420#if !__has_attribute(alloc_size)
Yi Kong2d3122c2017-04-30 15:08:05 -0700421// TODO: remove this after Clang prebuilt rebase.
George Burgess IV5f8a6732017-04-06 11:26:11 -0700422#else
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700423TEST_F(DEATHTEST, sprintf_malloc_fortified) {
Nick Kralevichb91791d2013-10-02 14:14:40 -0700424 char* buf = (char *) malloc(10);
425 char source_buf[11];
426 memcpy(source_buf, "1234567890", 11);
Elliott Hughesd036e942015-02-02 11:18:58 -0800427 ASSERT_FORTIFY(sprintf(buf, "%s", source_buf));
Nick Kralevichb91791d2013-10-02 14:14:40 -0700428 free(buf);
429}
430#endif
431
Nick Kralevich884a3de2014-10-06 00:39:47 +0000432TEST_F(DEATHTEST, sprintf2_fortified) {
Nick Kralevich884a3de2014-10-06 00:39:47 +0000433 char buf[5];
Elliott Hughesd036e942015-02-02 11:18:58 -0800434 ASSERT_FORTIFY(sprintf(buf, "aaaaa"));
Nick Kralevich884a3de2014-10-06 00:39:47 +0000435}
436
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700437static int vsprintf_helper(const char *fmt, ...) {
438 char buf[10];
439 va_list va;
440 int result;
441
442 va_start(va, fmt);
443 result = vsprintf(buf, fmt, va); // should crash here
444 va_end(va);
445 return result;
446}
447
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700448TEST_F(DEATHTEST, vsprintf_fortified) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800449 ASSERT_FORTIFY(vsprintf_helper("%s", "0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700450}
451
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700452TEST_F(DEATHTEST, vsprintf2_fortified) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800453 ASSERT_FORTIFY(vsprintf_helper("0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700454}
455
456static int vsnprintf_helper(const char *fmt, ...) {
457 char buf[10];
458 va_list va;
459 int result;
460 size_t size = atoi("11");
461
462 va_start(va, fmt);
463 result = vsnprintf(buf, size, fmt, va); // should crash here
464 va_end(va);
465 return result;
466}
467
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700468TEST_F(DEATHTEST, vsnprintf_fortified) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800469 ASSERT_FORTIFY(vsnprintf_helper("%s", "0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700470}
471
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700472TEST_F(DEATHTEST, vsnprintf2_fortified) {
Elliott Hughesd036e942015-02-02 11:18:58 -0800473 ASSERT_FORTIFY(vsnprintf_helper("0123456789"));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700474}
475
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700476TEST_F(DEATHTEST, strncat_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700477 char buf[10];
478 size_t n = atoi("10"); // avoid compiler optimizations
479 strncpy(buf, "012345678", n);
Elliott Hughesd036e942015-02-02 11:18:58 -0800480 ASSERT_FORTIFY(strncat(buf, "9", n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700481}
482
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700483TEST_F(DEATHTEST, strncat2_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700484 char buf[10];
485 buf[0] = '\0';
486 size_t n = atoi("10"); // avoid compiler optimizations
Elliott Hughesd036e942015-02-02 11:18:58 -0800487 ASSERT_FORTIFY(strncat(buf, "0123456789", n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700488}
489
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700490TEST_F(DEATHTEST, strcat_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700491 char src[11];
492 strcpy(src, "0123456789");
493 char buf[10];
494 buf[0] = '\0';
Elliott Hughesd036e942015-02-02 11:18:58 -0800495 ASSERT_FORTIFY(strcat(buf, src));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700496}
497
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700498TEST_F(DEATHTEST, memmove_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700499 char buf[20];
500 strcpy(buf, "0123456789");
501 size_t n = atoi("10");
Elliott Hughesd036e942015-02-02 11:18:58 -0800502 ASSERT_FORTIFY(memmove(buf + 11, buf, n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700503}
504
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700505TEST_F(DEATHTEST, memcpy_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700506 char bufa[10];
507 char bufb[10];
508 strcpy(bufa, "012345678");
509 size_t n = atoi("11");
Elliott Hughesd036e942015-02-02 11:18:58 -0800510 ASSERT_FORTIFY(memcpy(bufb, bufa, n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700511}
512
Elliott Hughes62e59642016-03-01 11:22:42 -0800513TEST_F(DEATHTEST, memset_fortified) {
514 char buf[10];
515 size_t n = atoi("11");
516 ASSERT_FORTIFY(memset(buf, 0, n));
517}
518
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700519TEST_F(DEATHTEST, stpncpy_fortified) {
Christopher Ferris950a58e2014-04-04 14:38:18 -0700520 char bufa[15];
521 char bufb[10];
522 strcpy(bufa, "01234567890123");
523 size_t n = strlen(bufa);
Elliott Hughesd036e942015-02-02 11:18:58 -0800524 ASSERT_FORTIFY(stpncpy(bufb, bufa, n));
Christopher Ferris950a58e2014-04-04 14:38:18 -0700525}
526
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700527TEST_F(DEATHTEST, stpncpy2_fortified) {
Christopher Ferris950a58e2014-04-04 14:38:18 -0700528 char dest[11];
529 char src[10];
530 memcpy(src, "0123456789", sizeof(src)); // src is not null terminated
Elliott Hughesd036e942015-02-02 11:18:58 -0800531 ASSERT_FORTIFY(stpncpy(dest, src, sizeof(dest)));
Christopher Ferris950a58e2014-04-04 14:38:18 -0700532}
533
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700534TEST_F(DEATHTEST, strncpy_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700535 char bufa[15];
536 char bufb[10];
537 strcpy(bufa, "01234567890123");
538 size_t n = strlen(bufa);
Elliott Hughesd036e942015-02-02 11:18:58 -0800539 ASSERT_FORTIFY(strncpy(bufb, bufa, n));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700540}
541
Christopher Ferris950a58e2014-04-04 14:38:18 -0700542
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700543TEST_F(DEATHTEST, strncpy2_fortified) {
Nick Kralevich93501d32013-08-28 10:47:43 -0700544 char dest[11];
545 char src[10];
546 memcpy(src, "0123456789", sizeof(src)); // src is not null terminated
Elliott Hughesd036e942015-02-02 11:18:58 -0800547 ASSERT_FORTIFY(strncpy(dest, src, sizeof(dest)));
Nick Kralevich93501d32013-08-28 10:47:43 -0700548}
549
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700550TEST_F(DEATHTEST, snprintf_fortified) {
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700551 char bufa[15];
552 char bufb[10];
553 strcpy(bufa, "0123456789");
554 size_t n = strlen(bufa) + 1;
Elliott Hughesd036e942015-02-02 11:18:58 -0800555 ASSERT_FORTIFY(snprintf(bufb, n, "%s", bufa));
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700556}
557
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700558TEST_F(DEATHTEST, bzero_fortified) {
Nick Kralevicha6cde392013-06-29 08:15:25 -0700559 char buf[10];
560 memcpy(buf, "0123456789", sizeof(buf));
561 size_t n = atoi("11");
Elliott Hughesd036e942015-02-02 11:18:58 -0800562 ASSERT_FORTIFY(bzero(buf, n));
Nick Kralevicha6cde392013-06-29 08:15:25 -0700563}
564
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700565TEST_F(DEATHTEST, umask_fortified) {
Nick Kralevicha6cde392013-06-29 08:15:25 -0700566 mode_t mask = atoi("1023"); // 01777 in octal
Elliott Hughesd036e942015-02-02 11:18:58 -0800567 ASSERT_FORTIFY(umask(mask));
Nick Kralevicha6cde392013-06-29 08:15:25 -0700568}
569
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700570TEST_F(DEATHTEST, recv_fortified) {
Nick Kralevich60f4f9a2013-09-24 16:32:07 -0700571 size_t data_len = atoi("11"); // suppress compiler optimizations
572 char buf[10];
Elliott Hughesd036e942015-02-02 11:18:58 -0800573 ASSERT_FORTIFY(recv(0, buf, data_len, 0));
Nick Kralevich60f4f9a2013-09-24 16:32:07 -0700574}
575
Daniel Micay95b59c52017-02-13 17:27:59 -0800576TEST_F(DEATHTEST, send_fortified) {
577 size_t data_len = atoi("11"); // suppress compiler optimizations
578 char buf[10] = {0};
579 ASSERT_FORTIFY(send(0, buf, data_len, 0));
580}
581
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700582TEST_F(DEATHTEST, FD_ISSET_fortified) {
Elliott Hughes063525c2014-05-13 11:19:57 -0700583#if defined(__BIONIC__) // glibc catches this at compile-time.
Nick Kralevich90201d52013-10-02 16:11:30 -0700584 fd_set set;
585 memset(&set, 0, sizeof(set));
Elliott Hughesd036e942015-02-02 11:18:58 -0800586 ASSERT_FORTIFY(FD_ISSET(-1, &set));
Elliott Hughes409588c2014-04-23 23:02:43 -0700587#endif
Nick Kralevich90201d52013-10-02 16:11:30 -0700588}
589
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700590TEST_F(DEATHTEST, FD_ISSET_2_fortified) {
Nick Kralevich7943df62013-10-03 14:08:39 -0700591 char buf[1];
592 fd_set* set = (fd_set*) buf;
Elliott Hughesd036e942015-02-02 11:18:58 -0800593 ASSERT_FORTIFY(FD_ISSET(0, set));
Nick Kralevich7943df62013-10-03 14:08:39 -0700594}
595
Daniel Micay9101b002015-05-20 15:31:26 -0400596TEST_F(DEATHTEST, getcwd_fortified) {
597 char buf[1];
598 size_t ct = atoi("2"); // prevent optimizations
599 ASSERT_FORTIFY(getcwd(buf, ct));
600}
601
Daniel Micaye7e1c872015-04-16 09:07:45 -0400602TEST_F(DEATHTEST, pread_fortified) {
603 char buf[1];
604 size_t ct = atoi("2"); // prevent optimizations
605 int fd = open("/dev/null", O_RDONLY);
606 ASSERT_FORTIFY(pread(fd, buf, ct, 0));
607 close(fd);
608}
609
610TEST_F(DEATHTEST, pread64_fortified) {
611 char buf[1];
612 size_t ct = atoi("2"); // prevent optimizations
613 int fd = open("/dev/null", O_RDONLY);
614 ASSERT_FORTIFY(pread64(fd, buf, ct, 0));
615 close(fd);
616}
617
Daniel Micayafdd1542015-07-20 21:37:29 -0400618TEST_F(DEATHTEST, pwrite_fortified) {
619 char buf[1] = {0};
620 size_t ct = atoi("2"); // prevent optimizations
621 int fd = open("/dev/null", O_WRONLY);
622 ASSERT_FORTIFY(pwrite(fd, buf, ct, 0));
623 close(fd);
624}
625
626TEST_F(DEATHTEST, pwrite64_fortified) {
627 char buf[1] = {0};
628 size_t ct = atoi("2"); // prevent optimizations
629 int fd = open("/dev/null", O_WRONLY);
630 ASSERT_FORTIFY(pwrite64(fd, buf, ct, 0));
631 close(fd);
632}
633
Nick Kralevichbe0e43b2014-07-23 13:56:23 -0700634TEST_F(DEATHTEST, read_fortified) {
Nick Kralevichb036b5c2013-10-09 20:16:34 -0700635 char buf[1];
636 size_t ct = atoi("2"); // prevent optimizations
637 int fd = open("/dev/null", O_RDONLY);
Elliott Hughesd036e942015-02-02 11:18:58 -0800638 ASSERT_FORTIFY(read(fd, buf, ct));
Nick Kralevichb036b5c2013-10-09 20:16:34 -0700639 close(fd);
640}
641
Daniel Micayafdd1542015-07-20 21:37:29 -0400642TEST_F(DEATHTEST, write_fortified) {
643 char buf[1] = {0};
644 size_t ct = atoi("2"); // prevent optimizations
645 int fd = open("/dev/null", O_WRONLY);
646 ASSERT_EXIT(write(fd, buf, ct), testing::KilledBySignal(SIGABRT), "");
647 close(fd);
648}
649
Daniel Micayfed26592015-07-18 13:55:51 -0400650TEST_F(DEATHTEST, fread_fortified) {
651 char buf[1];
652 size_t ct = atoi("2"); // prevent optimizations
653 FILE* fp = fopen("/dev/null", "r");
654 ASSERT_FORTIFY(fread(buf, 1, ct, fp));
655 fclose(fp);
656}
657
658TEST_F(DEATHTEST, fwrite_fortified) {
659 char buf[1] = {0};
660 size_t ct = atoi("2"); // prevent optimizations
661 FILE* fp = fopen("/dev/null", "w");
662 ASSERT_FORTIFY(fwrite(buf, 1, ct, fp));
663 fclose(fp);
664}
665
Daniel Micay42281882015-04-17 11:26:36 -0400666TEST_F(DEATHTEST, readlink_fortified) {
667 char buf[1];
668 size_t ct = atoi("2"); // prevent optimizations
669 ASSERT_FORTIFY(readlink("/dev/null", buf, ct));
670}
671
672TEST_F(DEATHTEST, readlinkat_fortified) {
673 char buf[1];
674 size_t ct = atoi("2"); // prevent optimizations
675 ASSERT_FORTIFY(readlinkat(AT_FDCWD, "/dev/null", buf, ct));
676}
677
Nick Kralevich5bcf3982013-06-28 10:34:09 -0700678extern "C" char* __strncat_chk(char*, const char*, size_t, size_t);
679extern "C" char* __strcat_chk(char*, const char*, size_t);
680
681TEST(TEST_NAME, strncat) {
682 char buf[10];
683 memset(buf, 'A', sizeof(buf));
684 buf[0] = 'a';
685 buf[1] = '\0';
686 char* res = __strncat_chk(buf, "01234", sizeof(buf) - strlen(buf) - 1, sizeof(buf));
687 ASSERT_EQ(buf, res);
688 ASSERT_EQ('a', buf[0]);
689 ASSERT_EQ('0', buf[1]);
690 ASSERT_EQ('1', buf[2]);
691 ASSERT_EQ('2', buf[3]);
692 ASSERT_EQ('3', buf[4]);
693 ASSERT_EQ('4', buf[5]);
694 ASSERT_EQ('\0', buf[6]);
695 ASSERT_EQ('A', buf[7]);
696 ASSERT_EQ('A', buf[8]);
697 ASSERT_EQ('A', buf[9]);
698}
699
700TEST(TEST_NAME, strncat2) {
701 char buf[10];
702 memset(buf, 'A', sizeof(buf));
703 buf[0] = 'a';
704 buf[1] = '\0';
705 char* res = __strncat_chk(buf, "0123456789", 5, sizeof(buf));
706 ASSERT_EQ(buf, res);
707 ASSERT_EQ('a', buf[0]);
708 ASSERT_EQ('0', buf[1]);
709 ASSERT_EQ('1', buf[2]);
710 ASSERT_EQ('2', buf[3]);
711 ASSERT_EQ('3', buf[4]);
712 ASSERT_EQ('4', buf[5]);
713 ASSERT_EQ('\0', buf[6]);
714 ASSERT_EQ('A', buf[7]);
715 ASSERT_EQ('A', buf[8]);
716 ASSERT_EQ('A', buf[9]);
717}
718
719TEST(TEST_NAME, strncat3) {
720 char buf[10];
721 memset(buf, 'A', sizeof(buf));
722 buf[0] = '\0';
723 char* res = __strncat_chk(buf, "0123456789", 5, sizeof(buf));
724 ASSERT_EQ(buf, res);
725 ASSERT_EQ('0', buf[0]);
726 ASSERT_EQ('1', buf[1]);
727 ASSERT_EQ('2', buf[2]);
728 ASSERT_EQ('3', buf[3]);
729 ASSERT_EQ('4', buf[4]);
730 ASSERT_EQ('\0', buf[5]);
731 ASSERT_EQ('A', buf[6]);
732 ASSERT_EQ('A', buf[7]);
733 ASSERT_EQ('A', buf[8]);
734 ASSERT_EQ('A', buf[9]);
735}
736
737TEST(TEST_NAME, strncat4) {
738 char buf[10];
739 memset(buf, 'A', sizeof(buf));
740 buf[9] = '\0';
741 char* res = __strncat_chk(buf, "", 5, sizeof(buf));
742 ASSERT_EQ(buf, res);
743 ASSERT_EQ('A', buf[0]);
744 ASSERT_EQ('A', buf[1]);
745 ASSERT_EQ('A', buf[2]);
746 ASSERT_EQ('A', buf[3]);
747 ASSERT_EQ('A', buf[4]);
748 ASSERT_EQ('A', buf[5]);
749 ASSERT_EQ('A', buf[6]);
750 ASSERT_EQ('A', buf[7]);
751 ASSERT_EQ('A', buf[8]);
752 ASSERT_EQ('\0', buf[9]);
753}
754
755TEST(TEST_NAME, strncat5) {
756 char buf[10];
757 memset(buf, 'A', sizeof(buf));
758 buf[0] = 'a';
759 buf[1] = '\0';
760 char* res = __strncat_chk(buf, "01234567", 8, sizeof(buf));
761 ASSERT_EQ(buf, res);
762 ASSERT_EQ('a', buf[0]);
763 ASSERT_EQ('0', buf[1]);
764 ASSERT_EQ('1', buf[2]);
765 ASSERT_EQ('2', buf[3]);
766 ASSERT_EQ('3', buf[4]);
767 ASSERT_EQ('4', buf[5]);
768 ASSERT_EQ('5', buf[6]);
769 ASSERT_EQ('6', buf[7]);
770 ASSERT_EQ('7', buf[8]);
771 ASSERT_EQ('\0', buf[9]);
772}
773
774TEST(TEST_NAME, strncat6) {
775 char buf[10];
776 memset(buf, 'A', sizeof(buf));
777 buf[0] = 'a';
778 buf[1] = '\0';
779 char* res = __strncat_chk(buf, "01234567", 9, sizeof(buf));
780 ASSERT_EQ(buf, res);
781 ASSERT_EQ('a', buf[0]);
782 ASSERT_EQ('0', buf[1]);
783 ASSERT_EQ('1', buf[2]);
784 ASSERT_EQ('2', buf[3]);
785 ASSERT_EQ('3', buf[4]);
786 ASSERT_EQ('4', buf[5]);
787 ASSERT_EQ('5', buf[6]);
788 ASSERT_EQ('6', buf[7]);
789 ASSERT_EQ('7', buf[8]);
790 ASSERT_EQ('\0', buf[9]);
791}
792
793
794TEST(TEST_NAME, strcat) {
795 char buf[10];
796 memset(buf, 'A', sizeof(buf));
797 buf[0] = 'a';
798 buf[1] = '\0';
799 char* res = __strcat_chk(buf, "01234", sizeof(buf));
800 ASSERT_EQ(buf, res);
801 ASSERT_EQ('a', buf[0]);
802 ASSERT_EQ('0', buf[1]);
803 ASSERT_EQ('1', buf[2]);
804 ASSERT_EQ('2', buf[3]);
805 ASSERT_EQ('3', buf[4]);
806 ASSERT_EQ('4', buf[5]);
807 ASSERT_EQ('\0', buf[6]);
808 ASSERT_EQ('A', buf[7]);
809 ASSERT_EQ('A', buf[8]);
810 ASSERT_EQ('A', buf[9]);
811}
812
813TEST(TEST_NAME, strcat2) {
814 char buf[10];
815 memset(buf, 'A', sizeof(buf));
816 buf[0] = 'a';
817 buf[1] = '\0';
818 char* res = __strcat_chk(buf, "01234567", sizeof(buf));
819 ASSERT_EQ(buf, res);
820 ASSERT_EQ('a', buf[0]);
821 ASSERT_EQ('0', buf[1]);
822 ASSERT_EQ('1', buf[2]);
823 ASSERT_EQ('2', buf[3]);
824 ASSERT_EQ('3', buf[4]);
825 ASSERT_EQ('4', buf[5]);
826 ASSERT_EQ('5', buf[6]);
827 ASSERT_EQ('6', buf[7]);
828 ASSERT_EQ('7', buf[8]);
829 ASSERT_EQ('\0', buf[9]);
830}
Nick Kralevich93501d32013-08-28 10:47:43 -0700831
Christopher Ferris950a58e2014-04-04 14:38:18 -0700832TEST(TEST_NAME, stpncpy) {
833 char src[10];
834 char dst[10];
835 memcpy(src, "0123456789", sizeof(src)); // non null terminated string
836 stpncpy(dst, src, sizeof(dst));
837 ASSERT_EQ('0', dst[0]);
838 ASSERT_EQ('1', dst[1]);
839 ASSERT_EQ('2', dst[2]);
840 ASSERT_EQ('3', dst[3]);
841 ASSERT_EQ('4', dst[4]);
842 ASSERT_EQ('5', dst[5]);
843 ASSERT_EQ('6', dst[6]);
844 ASSERT_EQ('7', dst[7]);
845 ASSERT_EQ('8', dst[8]);
846 ASSERT_EQ('9', dst[9]);
847}
848
849TEST(TEST_NAME, stpncpy2) {
850 char src[10];
851 char dst[15];
852 memcpy(src, "012345678\0", sizeof(src));
853 stpncpy(dst, src, sizeof(dst));
854 ASSERT_EQ('0', dst[0]);
855 ASSERT_EQ('1', dst[1]);
856 ASSERT_EQ('2', dst[2]);
857 ASSERT_EQ('3', dst[3]);
858 ASSERT_EQ('4', dst[4]);
859 ASSERT_EQ('5', dst[5]);
860 ASSERT_EQ('6', dst[6]);
861 ASSERT_EQ('7', dst[7]);
862 ASSERT_EQ('8', dst[8]);
863 ASSERT_EQ('\0', dst[9]);
864 ASSERT_EQ('\0', dst[10]);
865 ASSERT_EQ('\0', dst[11]);
866 ASSERT_EQ('\0', dst[12]);
867 ASSERT_EQ('\0', dst[13]);
868 ASSERT_EQ('\0', dst[14]);
869}
870
Nick Kralevich93501d32013-08-28 10:47:43 -0700871TEST(TEST_NAME, strncpy) {
872 char src[10];
873 char dst[10];
874 memcpy(src, "0123456789", sizeof(src)); // non null terminated string
875 strncpy(dst, src, sizeof(dst));
876 ASSERT_EQ('0', dst[0]);
877 ASSERT_EQ('1', dst[1]);
878 ASSERT_EQ('2', dst[2]);
879 ASSERT_EQ('3', dst[3]);
880 ASSERT_EQ('4', dst[4]);
881 ASSERT_EQ('5', dst[5]);
882 ASSERT_EQ('6', dst[6]);
883 ASSERT_EQ('7', dst[7]);
884 ASSERT_EQ('8', dst[8]);
885 ASSERT_EQ('9', dst[9]);
886}
887
888TEST(TEST_NAME, strncpy2) {
889 char src[10];
890 char dst[15];
891 memcpy(src, "012345678\0", sizeof(src));
892 strncpy(dst, src, sizeof(dst));
893 ASSERT_EQ('0', dst[0]);
894 ASSERT_EQ('1', dst[1]);
895 ASSERT_EQ('2', dst[2]);
896 ASSERT_EQ('3', dst[3]);
897 ASSERT_EQ('4', dst[4]);
898 ASSERT_EQ('5', dst[5]);
899 ASSERT_EQ('6', dst[6]);
900 ASSERT_EQ('7', dst[7]);
901 ASSERT_EQ('8', dst[8]);
902 ASSERT_EQ('\0', dst[9]);
903 ASSERT_EQ('\0', dst[10]);
904 ASSERT_EQ('\0', dst[11]);
905 ASSERT_EQ('\0', dst[12]);
906 ASSERT_EQ('\0', dst[13]);
907 ASSERT_EQ('\0', dst[14]);
908}
Christopher Ferris16e185c2013-09-10 16:56:34 -0700909
910TEST(TEST_NAME, strcat_chk_max_int_size) {
911 char buf[10];
912 memset(buf, 'A', sizeof(buf));
913 buf[0] = 'a';
914 buf[1] = '\0';
915 char* res = __strcat_chk(buf, "01234567", (size_t)-1);
916 ASSERT_EQ(buf, res);
917 ASSERT_EQ('a', buf[0]);
918 ASSERT_EQ('0', buf[1]);
919 ASSERT_EQ('1', buf[2]);
920 ASSERT_EQ('2', buf[3]);
921 ASSERT_EQ('3', buf[4]);
922 ASSERT_EQ('4', buf[5]);
923 ASSERT_EQ('5', buf[6]);
924 ASSERT_EQ('6', buf[7]);
925 ASSERT_EQ('7', buf[8]);
926 ASSERT_EQ('\0', buf[9]);
927}
928
Christopher Ferris950a58e2014-04-04 14:38:18 -0700929extern "C" char* __stpcpy_chk(char*, const char*, size_t);
930
931TEST(TEST_NAME, stpcpy_chk_max_int_size) {
932 char buf[10];
933 char* res = __stpcpy_chk(buf, "012345678", (size_t)-1);
934 ASSERT_EQ(buf + strlen("012345678"), res);
935 ASSERT_STREQ("012345678", buf);
936}
937
Christopher Ferris16e185c2013-09-10 16:56:34 -0700938extern "C" char* __strcpy_chk(char*, const char*, size_t);
939
940TEST(TEST_NAME, strcpy_chk_max_int_size) {
941 char buf[10];
942 char* res = __strcpy_chk(buf, "012345678", (size_t)-1);
943 ASSERT_EQ(buf, res);
Christopher Ferris950a58e2014-04-04 14:38:18 -0700944 ASSERT_STREQ("012345678", buf);
Christopher Ferris16e185c2013-09-10 16:56:34 -0700945}
946
947extern "C" void* __memcpy_chk(void*, const void*, size_t, size_t);
948
949TEST(TEST_NAME, memcpy_chk_max_int_size) {
950 char buf[10];
951 void* res = __memcpy_chk(buf, "012345678", sizeof(buf), (size_t)-1);
952 ASSERT_EQ((void*)buf, res);
953 ASSERT_EQ('0', buf[0]);
954 ASSERT_EQ('1', buf[1]);
955 ASSERT_EQ('2', buf[2]);
956 ASSERT_EQ('3', buf[3]);
957 ASSERT_EQ('4', buf[4]);
958 ASSERT_EQ('5', buf[5]);
959 ASSERT_EQ('6', buf[6]);
960 ASSERT_EQ('7', buf[7]);
961 ASSERT_EQ('8', buf[8]);
962 ASSERT_EQ('\0', buf[9]);
963}
Stephen Hines6e380722013-10-11 00:45:24 -0700964
965// Verify that macro expansion is done properly for sprintf/snprintf (which
966// are defined as macros in stdio.h under clang).
967#define CONTENTS "macro expansion"
968#define BUF_AND_SIZE(A) A, sizeof(A)
969#define BUF_AND_CONTENTS(A) A, CONTENTS
970#define BUF_AND_SIZE_AND_CONTENTS(A) A, sizeof(A), CONTENTS
971TEST(TEST_NAME, s_n_printf_macro_expansion) {
972 char buf[BUFSIZ];
973 snprintf(BUF_AND_SIZE(buf), CONTENTS);
974 EXPECT_STREQ(CONTENTS, buf);
975
976 snprintf(BUF_AND_SIZE_AND_CONTENTS(buf));
977 EXPECT_STREQ(CONTENTS, buf);
978
979 sprintf(BUF_AND_CONTENTS(buf));
980 EXPECT_STREQ(CONTENTS, buf);
981}
Elliott Hughes4674e382015-02-02 09:15:19 -0800982
983TEST_F(DEATHTEST, poll_fortified) {
984 nfds_t fd_count = atoi("2"); // suppress compiler optimizations
985 pollfd buf[1] = {{0, POLLIN, 0}};
Yabin Cuif4fe6932015-02-03 17:52:32 -0800986 // Set timeout to zero to prevent waiting in poll when fortify test fails.
987 ASSERT_FORTIFY(poll(buf, fd_count, 0));
Elliott Hughes4674e382015-02-02 09:15:19 -0800988}
989
990TEST_F(DEATHTEST, ppoll_fortified) {
991 nfds_t fd_count = atoi("2"); // suppress compiler optimizations
992 pollfd buf[1] = {{0, POLLIN, 0}};
Yabin Cuif4fe6932015-02-03 17:52:32 -0800993 // Set timeout to zero to prevent waiting in ppoll when fortify test fails.
994 timespec timeout;
995 timeout.tv_sec = timeout.tv_nsec = 0;
Elliott Hughesb83bf142018-03-22 11:01:25 -0700996 ASSERT_FORTIFY(ppoll(buf, fd_count, &timeout, nullptr));
997}
998
999TEST_F(DEATHTEST, ppoll64_fortified) {
1000#if __BIONIC__ // glibc doesn't have ppoll64.
1001 nfds_t fd_count = atoi("2"); // suppress compiler optimizations
1002 pollfd buf[1] = {{0, POLLIN, 0}};
1003 // Set timeout to zero to prevent waiting in ppoll when fortify test fails.
1004 timespec timeout;
1005 timeout.tv_sec = timeout.tv_nsec = 0;
1006 ASSERT_FORTIFY(ppoll64(buf, fd_count, &timeout, nullptr));
1007#endif
Elliott Hughes4674e382015-02-02 09:15:19 -08001008}
Elliott Hughesb115aef2017-08-04 09:34:19 -07001009
1010TEST_F(DEATHTEST, open_O_CREAT_without_mode_fortified) {
1011 int flags = O_CREAT; // Fool the compiler.
1012 ASSERT_FORTIFY(open("", flags));
1013}
1014
1015TEST_F(DEATHTEST, open_O_TMPFILE_without_mode_fortified) {
1016#if __BIONIC__ // Our glibc is too old for O_TMPFILE.
1017 int flags = O_TMPFILE; // Fool the compiler.
1018 ASSERT_FORTIFY(open("", flags));
1019#endif
1020}