* commit 'ab4e2ed182011998751ff5d6c321ff5bae20c6cd': Fix dlerror(3).
This commit is contained in:
@@ -26,31 +26,30 @@
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <errno.h>
|
||||
#include <pthread.h>
|
||||
#include <time.h>
|
||||
#include <stdio.h>
|
||||
#include <arpa/inet.h>
|
||||
#include <sys/socket.h>
|
||||
#include <dlfcn.h>
|
||||
#include <errno.h>
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <pthread.h>
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stddef.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
#include <stddef.h>
|
||||
#include <stdarg.h>
|
||||
#include <fcntl.h>
|
||||
#include <unwind.h>
|
||||
#include <dlfcn.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <sys/socket.h>
|
||||
#include <sys/system_properties.h>
|
||||
#include <sys/types.h>
|
||||
#include <time.h>
|
||||
#include <unistd.h>
|
||||
#include <unwind.h>
|
||||
|
||||
#include "dlmalloc.h"
|
||||
#include "logd.h"
|
||||
|
||||
#include "malloc_debug_common.h"
|
||||
#include "malloc_debug_check_mapinfo.h"
|
||||
#include "malloc_debug_common.h"
|
||||
#include "ScopedPthreadMutexLocker.h"
|
||||
|
||||
static mapinfo *milist;
|
||||
|
||||
|
||||
@@ -40,12 +40,15 @@
|
||||
* or static (libc.a) linking.
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <pthread.h>
|
||||
#include <unistd.h>
|
||||
#include "dlmalloc.h"
|
||||
#include "malloc_debug_common.h"
|
||||
|
||||
#include <pthread.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "dlmalloc.h"
|
||||
#include "ScopedPthreadMutexLocker.h"
|
||||
|
||||
/*
|
||||
* In a VM process, this is set to 1 after fork()ing out of zygote.
|
||||
*/
|
||||
|
||||
@@ -33,6 +33,8 @@
|
||||
#ifndef MALLOC_DEBUG_COMMON_H
|
||||
#define MALLOC_DEBUG_COMMON_H
|
||||
|
||||
#include <stdlib.h>
|
||||
|
||||
#define HASHTABLE_SIZE 1543
|
||||
#define BACKTRACE_SIZE 32
|
||||
/* flag definitions, currently sharing storage with "size" */
|
||||
@@ -101,18 +103,4 @@ typedef void (*MallocDebugFini)();
|
||||
#define info_log(format, ...) \
|
||||
__libc_android_log_print(ANDROID_LOG_INFO, "malloc_leak_check", (format), ##__VA_ARGS__ )
|
||||
|
||||
class ScopedPthreadMutexLocker {
|
||||
public:
|
||||
explicit ScopedPthreadMutexLocker(pthread_mutex_t* mu) : mu_(mu) {
|
||||
pthread_mutex_lock(mu_);
|
||||
}
|
||||
|
||||
~ScopedPthreadMutexLocker() {
|
||||
pthread_mutex_unlock(mu_);
|
||||
}
|
||||
|
||||
private:
|
||||
pthread_mutex_t* mu_;
|
||||
};
|
||||
|
||||
#endif // MALLOC_DEBUG_COMMON_H
|
||||
|
||||
@@ -26,6 +26,7 @@
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <arpa/inet.h>
|
||||
#include <dlfcn.h>
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
@@ -36,19 +37,18 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <unwind.h>
|
||||
|
||||
#include <arpa/inet.h>
|
||||
#include <sys/select.h>
|
||||
#include <sys/socket.h>
|
||||
#include <sys/system_properties.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/un.h>
|
||||
#include <unistd.h>
|
||||
#include <unwind.h>
|
||||
|
||||
#include "dlmalloc.h"
|
||||
#include "logd.h"
|
||||
#include "malloc_debug_common.h"
|
||||
#include "ScopedPthreadMutexLocker.h"
|
||||
|
||||
// This file should be included into the build only when
|
||||
// MALLOC_LEAK_CHECK, or MALLOC_QEMU_INSTRUMENT, or both
|
||||
|
||||
40
libc/private/ScopedPthreadMutexLocker.h
Normal file
40
libc/private/ScopedPthreadMutexLocker.h
Normal file
@@ -0,0 +1,40 @@
|
||||
/*
|
||||
* Copyright (C) 2012 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef SCOPED_PTHREAD_MUTEX_LOCKER_H
|
||||
#define SCOPED_PTHREAD_MUTEX_LOCKER_H
|
||||
|
||||
#include <pthread.h>
|
||||
|
||||
class ScopedPthreadMutexLocker {
|
||||
public:
|
||||
explicit ScopedPthreadMutexLocker(pthread_mutex_t* mu) : mu_(mu) {
|
||||
pthread_mutex_lock(mu_);
|
||||
}
|
||||
|
||||
~ScopedPthreadMutexLocker() {
|
||||
pthread_mutex_unlock(mu_);
|
||||
}
|
||||
|
||||
private:
|
||||
pthread_mutex_t* mu_;
|
||||
|
||||
// Disallow copy and assignment.
|
||||
ScopedPthreadMutexLocker(const ScopedPthreadMutexLocker&);
|
||||
void operator=(const ScopedPthreadMutexLocker&);
|
||||
};
|
||||
|
||||
#endif // SCOPED_PTHREAD_MUTEX_LOCKER_H
|
||||
Reference in New Issue
Block a user