summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNed Deily <nad@acm.org>2011-04-09 21:53:47 (GMT)
committerNed Deily <nad@acm.org>2011-04-09 21:53:47 (GMT)
commit2604e33f3002c48437df2f013a085197be8aba8d (patch)
tree4e7f49adee6015a274ced2d3b2a931ee0880ed93
parent15012a67d25dbd1cee5e014be5f5f999c96c9c13 (diff)
parent45e47e58edf101e7865d4bdaa2261ce1421a4209 (diff)
downloadcpython-2604e33f3002c48437df2f013a085197be8aba8d.zip
cpython-2604e33f3002c48437df2f013a085197be8aba8d.tar.gz
cpython-2604e33f3002c48437df2f013a085197be8aba8d.tar.bz2
Issue9670: Merge backout to 3.2.
-rw-r--r--Lib/test/test_threading.py30
-rw-r--r--Misc/NEWS5
-rw-r--r--Python/thread_pthread.h12
3 files changed, 0 insertions, 47 deletions
diff --git a/Lib/test/test_threading.py b/Lib/test/test_threading.py
index 32f9e99..5f99b2e 100644
--- a/Lib/test/test_threading.py
+++ b/Lib/test/test_threading.py
@@ -677,36 +677,6 @@ class ThreadingExceptionTests(BaseTestCase):
thread.start()
self.assertRaises(RuntimeError, setattr, thread, "daemon", True)
- def test_recursion_limit(self):
- # Issue 9670
- # test that excessive recursion within a non-main thread causes
- # an exception rather than crashing the interpreter on platforms
- # like Mac OS X or FreeBSD which have small default stack sizes
- # for threads
- script = """if True:
- import threading
-
- def recurse():
- return recurse()
-
- def outer():
- try:
- recurse()
- except RuntimeError:
- pass
-
- w = threading.Thread(target=outer)
- w.start()
- w.join()
- print('end of main thread')
- """
- expected_output = "end of main thread\n"
- p = subprocess.Popen([sys.executable, "-c", script],
- stdout=subprocess.PIPE)
- stdout, stderr = p.communicate()
- data = stdout.decode().replace('\r', '')
- self.assertEqual(p.returncode, 0, "Unexpected error")
- self.assertEqual(data, expected_output)
class LockTests(lock_tests.LockTests):
locktype = staticmethod(threading.Lock)
diff --git a/Misc/NEWS b/Misc/NEWS
index dfb129c..23026db 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,11 +10,6 @@ What's New in Python 3.2.1?
Core and Builtins
-----------------
-- Issue #9670: Increase the default stack size for secondary threads on
- Mac OS X and FreeBSD to reduce the chances of a crash instead of a
- "maximum recursion depth" RuntimeError exception.
- (original patch by Ronald Oussoren)
-
- Issue #11650: PyOS_StdioReadline() retries fgets() if it was interrupted
(EINTR), for example if the program is stopped with CTRL+z on Mac OS X. Patch
written by Charles-Francois Natali.
diff --git a/Python/thread_pthread.h b/Python/thread_pthread.h
index f120291..ffc791c 100644
--- a/Python/thread_pthread.h
+++ b/Python/thread_pthread.h
@@ -18,18 +18,6 @@
#ifndef THREAD_STACK_SIZE
#define THREAD_STACK_SIZE 0 /* use default stack size */
#endif
-
-#if (defined(__APPLE__) || defined(__FreeBSD__)) && defined(THREAD_STACK_SIZE) && THREAD_STACK_SIZE == 0
- /* The default stack size for new threads on OSX is small enough that
- * we'll get hard crashes instead of 'maximum recursion depth exceeded'
- * exceptions.
- *
- * The default stack size below is the minimal stack size where a
- * simple recursive function doesn't cause a hard crash.
- */
-#undef THREAD_STACK_SIZE
-#define THREAD_STACK_SIZE 0x100000
-#endif
/* for safety, ensure a viable minimum stacksize */
#define THREAD_STACK_MIN 0x8000 /* 32kB */
#else /* !_POSIX_THREAD_ATTR_STACKSIZE */