diff options
author | Denys Vlasenko <dvlasenk@redhat.com> | 2011-02-18 17:36:54 +0100 |
---|---|---|
committer | Denys Vlasenko <dvlasenk@redhat.com> | 2011-02-18 17:36:54 +0100 |
commit | ba57c93a3ae019deca5bfdc7167649f937e025c6 (patch) | |
tree | e68eea598b7c5f1eb5702393162467909dd9123e /src/hooks | |
parent | 20687708641ebdb0f532cdec9549237be97c8059 (diff) | |
parent | 75aa0e2d9616241effda82462a90efc8afec2a99 (diff) | |
download | abrt-ba57c93a3ae019deca5bfdc7167649f937e025c6.tar.gz abrt-ba57c93a3ae019deca5bfdc7167649f937e025c6.tar.xz abrt-ba57c93a3ae019deca5bfdc7167649f937e025c6.zip |
Merge branch 'master' of ssh://git.fedorahosted.org/git/abrt
Diffstat (limited to 'src/hooks')
-rw-r--r-- | src/hooks/abrt-hook-ccpp.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/src/hooks/abrt-hook-ccpp.c b/src/hooks/abrt-hook-ccpp.c index dc95d6dc..8b6a6926 100644 --- a/src/hooks/abrt-hook-ccpp.c +++ b/src/hooks/abrt-hook-ccpp.c @@ -498,8 +498,23 @@ int main(int argc, char** argv) if (dd) { dd_create_basic_files(dd, uid); + + char path_maps_in[sizeof("/proc/%lu/maps") + sizeof(long)*3]; + sprintf(path_maps_in, "/proc/%lu/maps", (long)pid); + char *path_maps_out = concat_path_file(dd->dd_dir, FILENAME_MAPS); + copy_file(path_maps_in, path_maps_out, 0); + free(path_maps_out); + + char path_smaps_in[sizeof("/proc/%lu/smaps") + sizeof(long)*3]; + sprintf(path_smaps_in, "/proc/%lu/smaps", (long)pid); + char *path_smaps_out = concat_path_file(dd->dd_dir, FILENAME_SMAPS); + copy_file(path_smaps_in, path_smaps_out, 0); + free(path_smaps_out); + char *cmdline = get_cmdline(pid); /* never NULL */ - char *reason = xasprintf("Process %s was killed by signal %s (SIG%s)", executable, signal_str, signame ? signame : signal_str); + char *reason = xasprintf("Process %s was killed by signal %s (SIG%s)", + executable, signal_str, signame ? signame : signal_str); + dd_save_text(dd, FILENAME_ANALYZER, "CCpp"); dd_save_text(dd, FILENAME_EXECUTABLE, executable); dd_save_text(dd, FILENAME_CMDLINE, cmdline); |