mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-12 12:10:16 +00:00
5a82c74822
Also, change sources.redhat.com to sourceware.org. This patch was automatically generated by running the following shell script, which uses GNU sed, and which avoids modifying files imported from upstream: sed -ri ' s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g ' \ $(find $(git ls-files) -prune -type f \ ! -name '*.po' \ ! -name 'ChangeLog*' \ ! -path COPYING ! -path COPYING.LIB \ ! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \ ! -path manual/texinfo.tex ! -path scripts/config.guess \ ! -path scripts/config.sub ! -path scripts/install-sh \ ! -path scripts/mkinstalldirs ! -path scripts/move-if-change \ ! -path INSTALL ! -path locale/programs/charmap-kw.h \ ! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \ ! '(' -name configure \ -execdir test -f configure.ac -o -f configure.in ';' ')' \ ! '(' -name preconfigure \ -execdir test -f preconfigure.ac ';' ')' \ -print) and then by running 'make dist-prepare' to regenerate files built from the altered files, and then executing the following to cleanup: chmod a+x sysdeps/unix/sysv/linux/riscv/configure # Omit irrelevant whitespace and comment-only changes, # perhaps from a slightly-different Autoconf version. git checkout -f \ sysdeps/csky/configure \ sysdeps/hppa/configure \ sysdeps/riscv/configure \ sysdeps/unix/sysv/linux/csky/configure # Omit changes that caused a pre-commit check to fail like this: # remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines git checkout -f \ sysdeps/powerpc/powerpc64/ppc-mcount.S \ sysdeps/unix/sysv/linux/s390/s390-64/syscall.S # Omit change that caused a pre-commit check to fail like this: # remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
101 lines
3.6 KiB
Python
101 lines
3.6 KiB
Python
# Tests for the MutexPrinter class.
|
|
#
|
|
# Copyright (C) 2016-2019 Free Software Foundation, Inc.
|
|
# This file is part of the GNU C Library.
|
|
#
|
|
# The GNU C Library is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
# License as published by the Free Software Foundation; either
|
|
# version 2.1 of the License, or (at your option) any later version.
|
|
#
|
|
# The GNU C Library is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
# Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with the GNU C Library; if not, see
|
|
# <https://www.gnu.org/licenses/>.
|
|
|
|
import sys
|
|
|
|
from test_printers_common import *
|
|
|
|
test_source = sys.argv[1]
|
|
test_bin = sys.argv[2]
|
|
printer_files = sys.argv[3:]
|
|
printer_names = ['global glibc-pthread-locks']
|
|
|
|
try:
|
|
init_test(test_bin, printer_files, printer_names)
|
|
go_to_main()
|
|
|
|
var = 'mutex'
|
|
to_string = 'pthread_mutex_t'
|
|
|
|
break_at(test_source, 'Test status (destroyed)')
|
|
continue_cmd() # Go to test_status_destroyed
|
|
test_printer(var, to_string, {'Status': 'Destroyed'})
|
|
|
|
break_at(test_source, 'Test status (non-robust)')
|
|
continue_cmd() # Go to test_status_no_robust
|
|
test_printer(var, to_string, {'Status': 'Not acquired'})
|
|
next_cmd()
|
|
thread_id = get_current_thread_lwpid()
|
|
# Owner ID might be reported either as the thread ID or as "Unknown"
|
|
# (if e.g. lock elision is enabled).
|
|
test_printer(var, to_string,
|
|
{'Status': 'Acquired, possibly with no waiters',
|
|
'Owner ID': r'({0}|Unknown)'.format(thread_id)})
|
|
|
|
break_at(test_source, 'Test status (robust)')
|
|
continue_cmd() # Go to test_status_robust
|
|
test_printer(var, to_string, {'Status': 'Not acquired'})
|
|
|
|
# We'll now test the robust mutex locking states. We'll create a new
|
|
# thread that will lock a robust mutex and exit without unlocking it.
|
|
break_at(test_source, 'Create')
|
|
continue_cmd() # Go to test_locking_state_robust
|
|
# Set a breakpoint for the new thread to hit.
|
|
break_at(test_source, 'Thread function')
|
|
continue_cmd()
|
|
# By now the new thread is created and has hit its breakpoint.
|
|
set_scheduler_locking(True)
|
|
parent = 1
|
|
child = 2
|
|
select_thread(child)
|
|
child_id = get_current_thread_lwpid()
|
|
# We've got the new thread's ID.
|
|
select_thread(parent)
|
|
# Make the new thread finish its function while we wait.
|
|
continue_cmd(thread=child)
|
|
# The new thread should be dead by now.
|
|
break_at(test_source, 'Test locking (robust)')
|
|
continue_cmd()
|
|
test_printer(var, to_string, {'Owner ID': r'{0} \(dead\)'.format(child_id)})
|
|
# Try to lock and unlock the mutex.
|
|
next_cmd()
|
|
test_printer(var, to_string, {'Owner ID': thread_id,
|
|
'State protected by this mutex': 'Inconsistent'})
|
|
next_cmd()
|
|
test_printer(var, to_string, {'Status': 'Not acquired',
|
|
'State protected by this mutex': 'Not recoverable'})
|
|
set_scheduler_locking(False)
|
|
|
|
break_at(test_source, 'Test recursive locks')
|
|
continue_cmd() # Go to test_recursive_locks
|
|
test_printer(var, to_string, {'Times acquired by the owner': '2'})
|
|
next_cmd()
|
|
test_printer(var, to_string, {'Times acquired by the owner': '3'})
|
|
continue_cmd() # Exit
|
|
|
|
except (NoLineError, pexpect.TIMEOUT) as exception:
|
|
print('Error: {0}'.format(exception))
|
|
result = FAIL
|
|
|
|
else:
|
|
print('Test succeeded.')
|
|
result = PASS
|
|
|
|
exit(result)
|