Commit graph

28623 commits

Author SHA1 Message Date
Neil Fuller
b87effbbdf Merge "Move /system dependency on tz_version to bionic"
am: f5eaea32b6

Change-Id: If638121775a3d416818dca51350a65f8eb720087
2019-04-29 06:10:57 -07:00
Neil Fuller
f5eaea32b6 Merge "Move /system dependency on tz_version to bionic" 2019-04-29 12:59:32 +00:00
Elliott Hughes
766c77f88e Merge "Fix running tests/benchmarks on the host."
am: dfa3231fae

Change-Id: I9f663c0f53cec6ffbb6327d6a0c0b8aebea68ebc
2019-04-27 09:30:13 -07:00
Elliott Hughes
dfa3231fae Merge "Fix running tests/benchmarks on the host." 2019-04-27 16:15:21 +00:00
Elliott Hughes
4da99ffe5e Fix running tests/benchmarks on the host.
This was broken by all the mainline modules stuff. It's quite a bit
hairier to set up now, given that we don't have an apexd on the host.
An alternative might be to actually set up a fake /apex that points to
the bootstrap directories?

Test: ./benchmarks/run-on-host.sh 64
Test: ./tests/run-on-host.sh 64
Change-Id: If2c277ba492c7c443cdf51526ea42f56568e2ea6
2019-04-26 17:45:17 -07:00
Ryan Prichard
4051029224 Merge "__cxa_finalize: skip fflush call on dlclose"
am: 34bf6107b6

Change-Id: I59568ea0f93338d3a2bdbd75490e41c0d18952b2
2019-04-26 15:07:12 -07:00
Ryan Prichard
34bf6107b6 Merge "__cxa_finalize: skip fflush call on dlclose" 2019-04-26 21:51:05 +00:00
Nick Kralevich
54ed6eef25 Merge changes I59a7c224,I82d28654
am: 70f090e4e8

Change-Id: I144e3378522abdd81ea8ae93fc41f63aeffe10c3
2019-04-26 14:22:17 -07:00
Treehugger Robot
70f090e4e8 Merge changes I59a7c224,I82d28654
* changes:
  Don't honor LIBC_HOOKS_ENABLE across a security boundary
  Don't honor LD_CONFIG_FILE across security transitions
2019-04-26 21:15:28 +00:00
Nick Kralevich
560de5f5c7 Don't honor LIBC_HOOKS_ENABLE across a security boundary
Similar to the way we handle LIBC_DEBUG_MALLOC_OPTIONS
(bug 68003719), filter LIBC_HOOKS_ENABLE when we cross a
security boundary. This prevents modifying the allocation
behavior of a privileged program.

Introduced in
db478a6274%5E%21/#F0
(bug 30561479)

Test: compiles and boots
Change-Id: I59a7c224734b0991fd62efb45ab599dab8570723
2019-04-26 12:58:00 -07:00
Nick Kralevich
99cec1892d Don't honor LD_CONFIG_FILE across security transitions
For security reasons, when a binary is executed which causes a security
transition (eg, a setuid binary, setgid binary, filesystem capabilities,
or SELinux domain transition), the AT_SECURE flag is set. This causes
certain blacklisted environment variables to be stripped before the
process is executed. The list of blacklisted environment variables is
stored in UNSAFE_VARIABLE_NAMES. Generally speaking, most environment
variables used internally by libc show up in this list.

Commit 02586a2a34 ("linker: the
global group is added to all built-in namespaces", Aug 2017) added
support for the environment variable LD_CONFIG_FILE. This debug build
only feature allows the caller to specify the path to the loader
configuration file. Like other linker environment variables, setting
this variable allows the calling process to control executed code of the
called process, which has security implications (on debuggable builds
only).

Add LD_CONFIG_FILE to UNSAFE_VARIABLE_NAMES. This has the effect of
stripping, on all build types, the LD_CONFIG_FILE environment variable.
This has three advantages:

1) Prevents security bugs should LD_CONFIG_FILE ever be inadvertantly
exposed on a production build.
2) Makes the behavior of userdebug and user builds more similar, helping
prevent build-type dependent bugs where someone may come to rely on this
debug-only feature.
3) Protect droidfood users against malicious applications which can
trigger a security transition, eg, the execution of crash_dump or the
renderscript compiler.

Alternative considered but rejected:

If we treated LD_CONFIG_FILE like LD_PRELOAD, we could expose this on
all build types, and remove the build-type dependent behavior. But this
is contrary to enh's Aug 02 2017 guidance at
https://android-review.googlesource.com/c/platform/bionic/+/449956

  i'm still uncomfortable about LD_CONFIG_FILE because i'd like
  to be reducing the number of environment variables that affect
  the linker in P rather than increasing them.

Test: atest CtsBionicTestCases
Test: atest linker-unit-tests
Change-Id: I82d286546ee079b5cde04428dc89941c253c2d20
2019-04-26 12:08:54 -07:00
Ryan Prichard
c5d8c6c6e4 __cxa_finalize: skip fflush call on dlclose
In __cxa_finalize, only call fflush(NULL) when the program is exiting, not
when a library is unloaded with dlclose. This change restores behavior
from 2015.

Flushing output is needed when the program exits, but flushing everything
is hazardous at other times because it can block -- fflush(NULL) locks
every file, so it also blocks on read operations.

Bug: http://b/130655235
Test: manual
Change-Id: I2f5ecffa6724bfd98a93d145ab5313c793c01ae6
2019-04-25 16:38:31 -07:00
dimitry
f114ee76c0 Merge "Make pthread_get/setschedparam weak for native bridge"
am: 9f193e14ed

Change-Id: I47eab7fcc2a9be1ea42bd20b91403715e65713fc
2019-04-25 12:19:31 -07:00
Treehugger Robot
9f193e14ed Merge "Make pthread_get/setschedparam weak for native bridge" 2019-04-25 18:57:22 +00:00
Tom Cherry
b368a0b2e4 Allow device launched before Q to use legacy OEM AID value
Devices launched before Q may be using OEM defined AID that are not in
the OEM_RESERVED ranges. Those devices should be allowed to keep using
legacy oem AID values given it may not be possible to upgrade the
userdata and persist files through OTA.

Bug: 131095318
Test: bionic-unit-tests

Change-Id: I73fc0c452420be5287adcacb36a1e772acc9bb3e
2019-04-25 09:26:48 -07:00
dimitry
c7b81108b4 Make pthread_get/setschedparam weak for native bridge
Bug: http://b/130825973
Test: run affected app on cuttlefish
Change-Id: I776f26f5eaebdfdb1256ff621bd05ef5a90b852a
2019-04-25 16:43:24 +02:00
Neil Fuller
a7db90f32d Move /system dependency on tz_version to bionic
Move /system dependency on tz_version to bionic from core-libart.

The file is not used by code but is useful on device to identify
the format / version / origin of the tzdata file. The
tz_version file identifies the Android release (e.g. 3.1 == Q), which
implies the version of zic used to generate tzdata, and any Android
revision of the tzdata (e.g. 2019a v2) that may have taken place. The
file was previously used by by the tzdatacheck binary but it has since
switched to using the copy in the runtime module.

The bionic README.md is also updated here to reflect latest locations of
scripts.

Bug: 131239046
Test: make installclean / make droid / inspect /system
Change-Id: Ib142f98aa30c8c9d5eda33df55d4191478570ced
2019-04-25 09:35:58 +01:00
Tom Cherry
5bd54f3b4e Merge "Refactor some pieces of grp_pwd.cpp"
am: 731ed0fb52

Change-Id: Ia1346fff98c2fbfc45449f48d70cafedefc9a174
2019-04-24 16:13:02 -07:00
Tom Cherry
731ed0fb52 Merge "Refactor some pieces of grp_pwd.cpp" 2019-04-24 23:02:06 +00:00
Elliott Hughes
3716c5320d Merge "threads.h: Add C11 thread support."
am: 8c3140a612

Change-Id: I2b015a37c469055a44ba36cd7855e2cb770d1df0
2019-04-24 13:56:32 -07:00
Tom Cherry
5fb07634c3 Refactor some pieces of grp_pwd.cpp
We loop through android_ids in many functions, but this can be
consolidated into find functions.

Test: bionic-unit-tests
Change-Id: I70c423affe49090a93e999c72bb4c84a068de5d8
2019-04-24 13:37:11 -07:00
Elliott Hughes
8c3140a612 Merge "threads.h: Add C11 thread support." 2019-04-24 20:33:08 +00:00
Elliott Hughes
4206711352 threads.h: Add C11 thread support.
FreeBSD, glibc, and musl have all implemented C11 threads at this
point. POSIX is looking at how to align with it. Probably time to jump
on the bandwagon ourselves...

Implemented in the same style as <termios.h> so we can provide this
functionality even on older API levels. This does mean that this is
strictly more expensive than calling pthread functions directly.

Although this isn't in POSIX yet, assume that it's going to be basically
the same as C11 and add the header test anyway. We should revisit this
when POSIX actually adds <threads.h>.

Test: new tests
Change-Id: I8602d67ce71ca7f8ed1529daa0a8ea1feb083dd6
2019-04-24 09:12:29 -07:00
Elliott Hughes
7f58eb70dc Merge "Update doc comment about running the benchmarks."
am: 06a5617f24

Change-Id: I1bfa95158d958ab4913a9485c42da549e0cd2ca4
2019-04-23 17:06:40 -07:00
Treehugger Robot
06a5617f24 Merge "Update doc comment about running the benchmarks." 2019-04-23 23:54:17 +00:00
Elliott Hughes
d655bc6dfa Update doc comment about running the benchmarks.
Test: N/A
Change-Id: Idf1f8c38aa90478b861358677e1d12b96809377d
2019-04-23 11:49:13 -07:00
Christopher Ferris
a8c70ec4e1 Merge "Move all leak info functions to android_mallopt."
am: 31fe3c637e

Change-Id: Ie3e9e7578fc018aff41c1da0484eaefec24fa02f
2019-04-23 10:57:50 -07:00
Christopher Ferris
31fe3c637e Merge "Move all leak info functions to android_mallopt." 2019-04-23 17:45:01 +00:00
Elliott Hughes
f3859e2b79 Merge "libdl.a: make dlerror() always report an error."
am: 640bd0bf3a

Change-Id: Idced41c17f187c97333d632f01782bb441ee0d7c
2019-04-23 09:06:30 -07:00
Elliott Hughes
640bd0bf3a Merge "libdl.a: make dlerror() always report an error." 2019-04-23 14:47:05 +00:00
Yi Kong
aab432bed6 Merge "Implement __gnu_[u]ldivmod_helper methods in libc"
am: 7f3527fb5c

Change-Id: Ie1ccdb711872bf3fc317cb908fed67c9a8955e42
2019-04-22 23:13:17 -07:00
Yi Kong
7f3527fb5c Merge "Implement __gnu_[u]ldivmod_helper methods in libc" 2019-04-23 05:54:33 +00:00
Yi Kong
b410d0e69e Implement __gnu_[u]ldivmod_helper methods in libc
These symbols were previously provided by Android's out-dated libgcc,
but they're removed/deprecated in upstream libgcc, and also won't be
available in libclang_rt.builtins. We need to provide these methods in
libc itself for compatiblity.

Test: build with these symbols stripped in libgcc
Bug: 29275768
Change-Id: I04a05258c6c06b5a22ead41e148b02792ffbc941
2019-04-22 18:12:55 -07:00
Elliott Hughes
83513ea183 Merge "Reland ifuncs for strcmp and strlen."
am: 1311545bb2

Change-Id: I7adacc0f2d510ace5643d10a626ce53bfc055ccc
2019-04-22 16:57:45 -07:00
Torne (Richard Coles)
33e88b0caa Merge "Only write main library's RELRO by default."
am: 401e2efa39

Change-Id: I55013ac98d2ea1d4f57d5b3a252aaa679ad40b8a
2019-04-22 16:56:49 -07:00
Elliott Hughes
1311545bb2 Merge "Reland ifuncs for strcmp and strlen." 2019-04-22 23:32:33 +00:00
Treehugger Robot
401e2efa39 Merge "Only write main library's RELRO by default." 2019-04-22 23:26:36 +00:00
Ryan Prichard
3a186fa215 Merge "PIMutexUnlock: load owner_tid in non-common case"
am: b250766282

Change-Id: I737091c32d6522c3a986ab11a8a153b0908a41ae
2019-04-22 14:22:02 -07:00
Ryan Prichard
30cc4b4a4e Merge "Comment about lock destruction and unlocking"
am: f32e1a1f50

Change-Id: Id655a03d67387ae1934252e6f5a03934dc5abca4
2019-04-22 14:21:31 -07:00
Ryan Prichard
b250766282 Merge "PIMutexUnlock: load owner_tid in non-common case" 2019-04-22 21:09:52 +00:00
Ryan Prichard
f32e1a1f50 Merge "Comment about lock destruction and unlocking" 2019-04-22 21:09:44 +00:00
Elliott Hughes
a9e6f89385 Merge "Document __register_atfork."
am: b7155fd4e4

Change-Id: I266612af25caf40b816e9b5b2bac68f56eed820e
2019-04-22 13:19:20 -07:00
Elliott Hughes
b7155fd4e4 Merge "Document __register_atfork." 2019-04-22 19:38:42 +00:00
Elliott Hughes
927fe99692 Reland ifuncs for strcmp and strlen.
This reverts commit e4788d4c7e,
which undid this change during the Q betas.

Bug: http://b/120989619
Change-Id: Iea589fd0e56426971adf9f7c19c2aedf0d7a7a60
2019-04-22 18:57:21 +00:00
Elliott Hughes
fb9ce2882b Document __register_atfork.
Bug: https://github.com/android-ndk/ndk/issues/964
Test: N/A
Change-Id: I5f3fa4c7fa42abde05f5b5fe730748d8c5fb4bb2
2019-04-22 08:57:36 -07:00
Elliott Hughes
915c5fb9f6 libdl.a: make dlerror() always report an error.
Seems only logical, given that all the other calls fail.

(Only thing that's weird about this is that calling dlerror() usually
clears the error until you do something else that causes an error, but
that doesn't seem worth the bookkeeping?)

Bug: https://github.com/android-ndk/ndk/issues/965
Test: static unit tests still pass
Change-Id: I5e5401e148c5857f1dbab9c5a7f4a6fc43d8d626
2019-04-22 08:43:57 -07:00
Elliott Hughes
456ddd96b8 Merge "Move libdl and linker to static NOTICE files."
am: 493322baf1

Change-Id: I6df1abfa3de03933bcebaf04812f5c08c9f18ca5
2019-04-22 08:42:44 -07:00
Elliott Hughes
493322baf1 Merge "Move libdl and linker to static NOTICE files." 2019-04-22 15:33:05 +00:00
Elliott Hughes
fed43950b5 Merge "Workaround ASan not knowing about reallocarray."
am: bdf8528a85

Change-Id: Ia5b875340c4d76b72ca6fbf394247a74de7986cf
2019-04-22 08:01:35 -07:00
Elliott Hughes
bdf8528a85 Merge "Workaround ASan not knowing about reallocarray." 2019-04-22 14:50:57 +00:00