| 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_);
|
|
|