Home | History | Annotate | only in /system/core/crash_reporter
Up to higher level directory
NameDateSize
.project_alias21-Oct-20166
99-crash-reporter.rules21-Oct-2016861
Android.mk21-Oct-20164.6K
crash_collector.cc21-Oct-201614K
crash_collector.h21-Oct-20166.8K
crash_collector_test.cc21-Oct-20168.8K
crash_collector_test.h21-Oct-20161.1K
crash_reporter.cc21-Oct-201611.1K
crash_reporter.rc21-Oct-20161.4K
crash_reporter_logs.conf21-Oct-20165.1K
crash_reporter_logs_test.cc21-Oct-20161.4K
crash_sender21-Oct-201621.5K
dbus_bindings/21-Oct-2016
init/21-Oct-2016
kernel_collector.cc21-Oct-201620K
kernel_collector.h21-Oct-20164K
kernel_collector_test.cc21-Oct-201630.4K
kernel_collector_test.h21-Oct-2016992
kernel_log_collector.sh21-Oct-20161.9K
kernel_warning_collector.cc21-Oct-20163.5K
kernel_warning_collector.h21-Oct-20161.4K
list_proxies.cc21-Oct-201610.1K
OWNERS21-Oct-201633
periodic_scheduler21-Oct-20162.3K
README.md21-Oct-20163K
TEST_WARNING21-Oct-20163.5K
testrunner.cc21-Oct-2016775
udev_collector.cc21-Oct-20169K
udev_collector.h21-Oct-20162.8K
udev_collector_test.cc21-Oct-20166.4K
unclean_shutdown_collector.cc21-Oct-20162.9K
unclean_shutdown_collector.h21-Oct-20161.9K
unclean_shutdown_collector_test.cc21-Oct-20164.5K
user_collector.cc21-Oct-201623.2K
user_collector.h21-Oct-20167.5K
user_collector_test.cc21-Oct-201614.4K
warn_collector.l21-Oct-201610K
warn_collector_test.c21-Oct-2016850
warn_collector_test.sh21-Oct-20162.4K
warn_collector_test_reporter.sh21-Oct-2016862

README.md

      1 # crash_reporter
      2 
      3 `crash_reporter` is a deamon running on the device that saves the call stack of
      4 crashing programs. It makes use of the
      5 [Breakpad](https://chromium.googlesource.com/breakpad/breakpad/) library.
      6 
      7 During a build, Breakpad symbol files are generated for all binaries.  They are
      8 packaged into a zip file when running `m dist`, so that a developer can upload
      9 them to the crash server.
     10 
     11 On a device, if the user has opted in to metrics and crash reporting, a
     12 Breakpad minidump is generated when an executable crashes, which is then
     13 uploaded to the crash server.
     14 
     15 On the crash server, it compares the minidump's signature to the symbol files
     16 that the developer has uploaded, and extracts and symbolizes the stack trace
     17 from the minidump.
     18 
     19 ## SELinux policies
     20 
     21 In order to correctly generate a minidump, `crash_reporter` needs to be given
     22 the proper SELinux permissions for accessing the domain of the crashing
     23 executable.  By default, `crash_reporter` has only been given access to a select
     24 number of system domains, such as `metricsd`, `weave`, and `update_engine`.  If
     25 a developer wants their executable's crashes to be caught by `crash_reporter`,
     26 they will have to set their SELinux policies in their .te file to allow
     27 `crash_reporter` access to their domain.  This can be done through a simple
     28 [macro](https://android.googlesource.com/device/generic/brillo/+/master/sepolicy/te_macros):
     29 
     30     allow_crash_reporter(domain_name)
     31 
     32 Replace *domain_name* with whatever domain is assigned to the executable in
     33 the `file_contexts` file.
     34 
     35 ## Configuration
     36 
     37 `crash_reporter` has a few different configuration options that have to be set.
     38 
     39 - Crashes are only handled and uploaded if analytics reporting is enabled,
     40   either via the weave call to set `_metrics.enableAnalyticsReporting` or by
     41   manually creating the file `/data/misc/metrics/enabled` (for testing only).
     42 - The `BRILLO_CRASH_SERVER` make variable should be set in the `product.mk`
     43   file to the URL of the crash server.  For Brillo builds, it is set
     44   automatically through the product configuration.  Setting this variable will
     45   populate the `/etc/os-release.d/crash_server` file on the device, which is
     46   read by `crash_sender`.
     47 - The `BRILLO_PRODUCT_ID` make variable should be set in the `product.mk` file
     48   to the product's ID.  For Brillo builds, it is set automatically through the
     49   product configuration.  Setting this variable will populate the
     50   `/etc/os-release.d/product_id`, which is read by `crash_sender`.
     51 
     52 ## Uploading crash reports in *eng* builds
     53 
     54 By default, crash reports are only uploaded to the server for production
     55 *user* and *userdebug* images.  In *eng* builds, with crash reporting enabled
     56 the device will generate minidumps for any crashing executables but will not
     57 send them to the crash server.  If a developer does want to force an upload,
     58 they can do so by issuing the command `SECONDS_SEND_SPREAD=5 FORCE_OFFICIAL=1
     59 crash_sender` from an ADB shell.  This will send the report to the server, with
     60 the *image_type* field set to *force-official* so that these reports can be
     61 differentiated from normal reports.
     62