Index: src/platform-linux.cc |
diff --git a/src/platform-linux.cc b/src/platform-linux.cc |
index 50b0b67d891a3f506fe7243c5d5bc2e92b147423..5e378a7376081b54520860a21256f41423f9cf8a 100644 |
--- a/src/platform-linux.cc |
+++ b/src/platform-linux.cc |
@@ -573,16 +573,18 @@ bool ThreadHandle::IsValid() const { |
} |
-Thread::Thread(Isolate* isolate) |
+Thread::Thread(Isolate* isolate, const Options& options) |
: ThreadHandle(ThreadHandle::INVALID), |
- isolate_(isolate) { |
- set_name("v8:<unknown>"); |
+ isolate_(isolate), |
+ stack_size_(options.stack_size) { |
+ set_name(options.name); |
} |
Thread::Thread(Isolate* isolate, const char* name) |
: ThreadHandle(ThreadHandle::INVALID), |
- isolate_(isolate) { |
+ isolate_(isolate), |
+ stack_size_(0) { |
set_name(name); |
} |
@@ -614,7 +616,14 @@ void Thread::set_name(const char* name) { |
void Thread::Start() { |
- pthread_create(&thread_handle_data()->thread_, NULL, ThreadEntry, this); |
+ pthread_attr_t* attr_ptr = NULL; |
+ pthread_attr_t attr; |
+ if (stack_size_ > 0) { |
+ pthread_attr_init(&attr); |
+ pthread_attr_setstacksize(&attr, static_cast<size_t>(stack_size_)); |
+ attr_ptr = &attr; |
+ } |
+ pthread_create(&thread_handle_data()->thread_, attr_ptr, ThreadEntry, this); |
ASSERT(IsValid()); |
} |
@@ -875,7 +884,9 @@ class SignalSender : public Thread { |
}; |
explicit SignalSender(int interval) |
- : Thread(NULL), vm_tgid_(getpid()), interval_(interval) {} |
+ : Thread(NULL, "SignalSender"), |
+ vm_tgid_(getpid()), |
+ interval_(interval) {} |
static void AddActiveSampler(Sampler* sampler) { |
ScopedLock lock(mutex_); |