Commit Graph

791 Commits

Author SHA1 Message Date
f24342f117 Disable several features in Jellybean 2019-01-20 17:52:19 -05:00
50b55a77de Don't mount images when running core-only mode 2019-01-20 17:01:59 -05:00
fdf167db11 Get API level from build.prop 2019-01-20 15:20:34 -05:00
a4f8bd4ee0 Bump to C++17 2019-01-20 00:07:58 -05:00
3e4c12cf56 Migrate to STL 2019-01-19 23:59:37 -05:00
03c39e692a Switch to libc++ 2019-01-19 13:47:33 -05:00
23e5188422 Update scripts
1. Update build.py to use f-strings
2. Directly append busybox binaries to update-binary
3. Remove b64xz
2019-01-15 08:32:18 -05:00
928c56bda2 Don't use (deleted) copy constructor, use constructor directly to fix build 2019-01-13 13:19:00 -05:00
bc6f37eecc Fixes build error
device/phh/treble/magisk/Magisk/native/jni/systemproperties/prop_area.cpp:386:3: error: no matching function for call to 'atomic_store_explicit'
  atomic_store_explicit(&node->prop, 0, memory_order_release);
  ^~~~~~~~~~~~~~~~~~~~~
external/libcxx/include/atomic:1220:1: note: candidate template ignored: deduced conflicting types for parameter '_Tp' ('unsigned int' vs. 'int')
atomic_store_explicit(volatile atomic<_Tp>* __o, _Tp __d, memory_order __m) _NOEXCEPT
^
external/libcxx/include/atomic:1229:1: note: candidate template ignored: deduced conflicting types for parameter '_Tp' ('unsigned int' vs. 'int')
atomic_store_explicit(atomic<_Tp>* __o, _Tp __d, memory_order __m) _NOEXCEPT
2019-01-13 13:19:00 -05:00
04088b34a2 Update gradle scripts 2019-01-04 17:55:17 +08:00
1df65940b9 Support Kirin 960 devices
Close #928
2018-12-31 16:09:14 +08:00
3ccac8c3b8 Terminate forked children for exec after failure 2018-12-28 16:33:26 +08:00
0be158afa1 Official KitKat support 2018-12-28 16:03:23 +08:00
523e66294b Simpler su_info caching system 2018-12-26 11:56:49 +08:00
23f8f35098 Stop using system STL since it is no longer supported 2018-12-25 19:38:44 +08:00
8d210b5e37 Enhance EMUI 9 user experience 2018-12-25 01:08:46 +08:00
3c6c0e6700 Support EMUI 9.0 2018-12-24 21:36:37 +08:00
b245931c79 Prevent duplicates when "." or ".." occurs 2018-12-09 22:12:04 -05:00
1fae89cbb6 Add new cpio command: "exists", to magiskboot 2018-12-05 20:27:48 -05:00
109891d668 Make apk_install more portable 2018-12-05 18:36:27 -05:00
a868118f6f Use defined symbols in SDK 16 libsqlite.so 2018-12-05 12:48:01 -05:00
e5c62f5750 Allow post-fs-data module scripts to change module state 2018-12-05 12:47:29 -05:00
08cd5b81d1 Try to repair boot_hdr v1 entries 2018-12-04 03:30:43 -05:00
79b84da4b8 Adjust for new FrankeNDK 2018-12-04 02:08:51 -05:00
68b07c5913 Use flags for smaller binary 2018-12-03 19:43:02 -05:00
2a2e1236fc Use magic macros 2018-12-01 03:53:58 -05:00
9b170f2b4f Switch from deprecated AUDITDENY to DONTAUDIT 2018-11-29 06:42:04 -05:00
51e9ff59de Temporarily suppress warnings when applying Magisk rules 2018-11-29 06:31:05 -05:00
2977dbcded Remove all dontaudit in magisk rules 2018-11-29 06:28:37 -05:00
ac60b51035 Support removing redundant avtab nodes 2018-11-29 05:42:08 -05:00
4c2f33a089 Remove '--install' 2018-11-29 04:35:43 -05:00
3b071116ac Update magiskpolicy
- Generalize avtab node extraction and insertion
- Add new supported rules: type_change, type_member
- Update help message with official policy language
2018-11-29 03:46:29 -05:00
f723427b8b Add built-in procfs protection on SDK 24+
More information in the Medium Post:
https://medium.com/@topjohnwu/from-anime-game-to-android-system-security-vulnerability-9b955a182f20
2018-11-28 01:27:32 -05:00
f69a004c1c Use raw execve
Some devices have broken libc...
2018-11-28 00:07:57 -05:00
e8cba3524e Kill target processes properly 2018-11-27 03:56:14 -05:00
29457a1d28 Small adjustments 2018-11-26 03:26:45 -05:00
731455f164 Update exec functions signatures 2018-11-26 03:06:48 -05:00
b01a8cace6 Always try native accept4 2018-11-26 02:57:34 -05:00
e67965a381 Silent some errors 2018-11-24 15:53:15 -05:00
ec4723096f Prevent file descriptor from unclosed 2018-11-23 21:15:44 -05:00
762b678d24 Prevent any SELinux issues of root shell streams 2018-11-23 21:08:06 -05:00
38fcc57bbf Use component name as targets
Services can name their process name arbitrarily, for instance the service in
com.google.android.gms that is responsible for SafetyNet is named
com.google.android.gms.unstable. There are many apps out in the wild use
dedicated services with special names to detect root, and previously the user
is expected to add all of them to the hide list.

In this commit, we change from targeting process names to component names.
On Android, component names are composed of <pkg>/<cls>. When targeting
component names, we can always know what application spawned the new process.
This means that if the user adds a package name to the hidelist, MagiskHide can
now target ALL possible processes of that specific application.

To abide with this change, the default SafetyNet target is now changed from
com.google.android.gms.unstable (process name) to
com.google.android.gms/.droidguard.DroidGuardService (component name)
2018-11-23 15:47:49 -05:00
c8c57c74cc Optimize proc_monitor 2018-11-23 14:32:33 -05:00
0784448c69 Remove /.backup folder on start 2018-11-20 05:24:40 -05:00
de0064af47 Fix SIGWINCH never followed
Close #786
2018-11-20 04:40:42 -05:00
baae1fc84f Modernize selinux stub 2018-11-20 03:49:44 -05:00
2ab999f4ca Fix bug in DB query wrapper 2018-11-20 02:20:49 -05:00
c9f390d6e0 Abort upon any error occurred 2018-11-20 02:20:49 -05:00
3622c49ce1 Update busybox 2018-11-18 15:58:41 -05:00
0462e9a7d9 Update external dependencies 2018-11-18 03:34:59 -05:00