RE: [PATCH v2 09/14] ACPICA: Debugger: Fix "quit/exit" command by cleaning up user commands termination logic

2015-10-20 Thread Zheng, Lv
It looks patch 08 is not listed on the 
https://patchwork.kernel.org/project/linux-acpi/list/.
I just re-sent it, hope it could reach the mailing list this time.
I'll also send it in attachment style via private route to you.

Thanks and best regards
-Lv

> From: linux-acpi-ow...@vger.kernel.org 
> [mailto:linux-acpi-ow...@vger.kernel.org] On Behalf Of Zheng, Lv
> Sent: Tuesday, October 20, 2015 10:04 AM
> 
> I was using linux-pm.git/linux-next base which I downloaded a week ago.
> Maybe the conflict was caused by the fast-path ACPICA table fix merged after 
> my downloading.
> Let me check again.
> 
> Thanks and best regards
> -Lv
> 
> > From: Rafael J. Wysocki [mailto:r...@rjwysocki.net]
> > Sent: Tuesday, October 20, 2015 5:04 AM
> >
> > On Monday, October 19, 2015 10:25:32 AM Lv Zheng wrote:
> > > ACPICA commit 0dd68e16274cd38224aa4781eddc57dc2cbaa108
> > >
> > > The quit/exit commands shouldn't invoke acpi_terminate_debugger() and
> > > acpi_terminate() right in the user command loop, because when the debugger
> > > exits, the kernel ACPI subsystem shouldn't be terminated 
> > > (acpi_terminate())
> > > and the debugger should only be terminated by its users
> > > (acpi_terminate_debugger()) rather than being terminated itself. Leaving 
> > > such
> > > invocations causes kernel panic when the debugger is shipped in the Linux
> > > kernel.
> > >
> > > This patch fixes this issue. Lv Zheng.
> > >
> > > Link: https://github.com/acpica/acpica/commit/0dd68e16
> > > Signed-off-by: Lv Zheng 
> > > Signed-off-by: Bob Moore 
> >
> > This patch does not apply for me on top of the current mainline.
> >
> > What tree is it applicable to?
> >
> > Thanks,
> > Rafael
> 
> N�r��y���b�X��ǧv�^�)޺{.n�+{�i�b�{ay�ʇڙ�,j
��f���h���z��w���
> 
> ���j:+v���w�j�m
zZ+�ݢj"��!�i


RE: [PATCH v2 09/14] ACPICA: Debugger: Fix "quit/exit" command by cleaning up user commands termination logic

2015-10-19 Thread Zheng, Lv
I was using linux-pm.git/linux-next base which I downloaded a week ago.
Maybe the conflict was caused by the fast-path ACPICA table fix merged after my 
downloading.
Let me check again.

Thanks and best regards
-Lv

> From: Rafael J. Wysocki [mailto:r...@rjwysocki.net]
> Sent: Tuesday, October 20, 2015 5:04 AM
> 
> On Monday, October 19, 2015 10:25:32 AM Lv Zheng wrote:
> > ACPICA commit 0dd68e16274cd38224aa4781eddc57dc2cbaa108
> >
> > The quit/exit commands shouldn't invoke acpi_terminate_debugger() and
> > acpi_terminate() right in the user command loop, because when the debugger
> > exits, the kernel ACPI subsystem shouldn't be terminated (acpi_terminate())
> > and the debugger should only be terminated by its users
> > (acpi_terminate_debugger()) rather than being terminated itself. Leaving 
> > such
> > invocations causes kernel panic when the debugger is shipped in the Linux
> > kernel.
> >
> > This patch fixes this issue. Lv Zheng.
> >
> > Link: https://github.com/acpica/acpica/commit/0dd68e16
> > Signed-off-by: Lv Zheng 
> > Signed-off-by: Bob Moore 
> 
> This patch does not apply for me on top of the current mainline.
> 
> What tree is it applicable to?
> 
> Thanks,
> Rafael

N�r��yb�X��ǧv�^�)޺{.n�+{zX����ܨ}���Ơz�&j:+v���zZ+��+zf���h���~i���z��w���?�&�)ߢf��^jǫy�m��@A�a���
0��h���i

Re: [PATCH v2 09/14] ACPICA: Debugger: Fix "quit/exit" command by cleaning up user commands termination logic

2015-10-19 Thread Rafael J. Wysocki
On Monday, October 19, 2015 10:25:32 AM Lv Zheng wrote:
> ACPICA commit 0dd68e16274cd38224aa4781eddc57dc2cbaa108
> 
> The quit/exit commands shouldn't invoke acpi_terminate_debugger() and
> acpi_terminate() right in the user command loop, because when the debugger
> exits, the kernel ACPI subsystem shouldn't be terminated (acpi_terminate())
> and the debugger should only be terminated by its users
> (acpi_terminate_debugger()) rather than being terminated itself. Leaving such
> invocations causes kernel panic when the debugger is shipped in the Linux
> kernel.
> 
> This patch fixes this issue. Lv Zheng.
> 
> Link: https://github.com/acpica/acpica/commit/0dd68e16
> Signed-off-by: Lv Zheng 
> Signed-off-by: Bob Moore 

This patch does not apply for me on top of the current mainline.

What tree is it applicable to?

Thanks,
Rafael

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/


[PATCH v2 09/14] ACPICA: Debugger: Fix "quit/exit" command by cleaning up user commands termination logic

2015-10-18 Thread Lv Zheng
ACPICA commit 0dd68e16274cd38224aa4781eddc57dc2cbaa108

The quit/exit commands shouldn't invoke acpi_terminate_debugger() and
acpi_terminate() right in the user command loop, because when the debugger
exits, the kernel ACPI subsystem shouldn't be terminated (acpi_terminate())
and the debugger should only be terminated by its users
(acpi_terminate_debugger()) rather than being terminated itself. Leaving such
invocations causes kernel panic when the debugger is shipped in the Linux
kernel.

This patch fixes this issue. Lv Zheng.

Link: https://github.com/acpica/acpica/commit/0dd68e16
Signed-off-by: Lv Zheng 
Signed-off-by: Bob Moore 
---
 drivers/acpi/acpica/acglobal.h |3 ++-
 drivers/acpi/acpica/dbinput.c  |   16 
 drivers/acpi/acpica/dbxface.c  |   20 
 drivers/acpi/acpica/utinit.c   |2 --
 drivers/acpi/acpica/utxface.c  |4 
 5 files changed, 26 insertions(+), 19 deletions(-)

diff --git a/drivers/acpi/acpica/acglobal.h b/drivers/acpi/acpica/acglobal.h
index 593de41..d82249c 100644
--- a/drivers/acpi/acpica/acglobal.h
+++ b/drivers/acpi/acpica/acglobal.h
@@ -324,7 +324,6 @@ ACPI_GLOBAL(struct acpi_external_file *, 
acpi_gbl_external_file_list);
 
 #ifdef ACPI_DEBUGGER
 
-ACPI_INIT_GLOBAL(u8, acpi_gbl_db_terminate_threads, FALSE);
 ACPI_INIT_GLOBAL(u8, acpi_gbl_abort_method, FALSE);
 ACPI_INIT_GLOBAL(u8, acpi_gbl_method_executing, FALSE);
 
@@ -336,6 +335,8 @@ ACPI_GLOBAL(char *, acpi_gbl_db_filename);
 ACPI_GLOBAL(u32, acpi_gbl_db_debug_level);
 ACPI_GLOBAL(u32, acpi_gbl_db_console_debug_level);
 ACPI_GLOBAL(struct acpi_namespace_node *, acpi_gbl_db_scope_node);
+ACPI_GLOBAL(u8, acpi_gbl_db_terminate_loop);
+ACPI_GLOBAL(u8, acpi_gbl_db_threads_terminated);
 
 ACPI_GLOBAL(char *, acpi_gbl_db_args[ACPI_DEBUGGER_MAX_ARGS]);
 ACPI_GLOBAL(acpi_object_type, acpi_gbl_db_arg_types[ACPI_DEBUGGER_MAX_ARGS]);
diff --git a/drivers/acpi/acpica/dbinput.c b/drivers/acpi/acpica/dbinput.c
index 7f1b6ec..f8cddd6 100644
--- a/drivers/acpi/acpica/dbinput.c
+++ b/drivers/acpi/acpica/dbinput.c
@@ -694,7 +694,7 @@ acpi_db_command_dispatch(char *input_buffer,
 
/* If acpi_terminate has been called, terminate this thread */
 
-   if (acpi_gbl_db_terminate_threads) {
+   if (acpi_gbl_db_terminate_loop) {
return (AE_CTRL_TERMINATE);
}
 
@@ -1116,7 +1116,7 @@ acpi_db_command_dispatch(char *input_buffer,
 #ifdef ACPI_APPLICATION
acpi_db_close_debug_file();
 #endif
-   acpi_gbl_db_terminate_threads = TRUE;
+   acpi_gbl_db_terminate_loop = TRUE;
return (AE_CTRL_TERMINATE);
 
case CMD_NOT_FOUND:
@@ -1166,6 +1166,7 @@ void ACPI_SYSTEM_XFACE acpi_db_execute_thread(void 
*context)
 
acpi_os_release_mutex(acpi_gbl_db_command_complete);
}
+   acpi_gbl_db_threads_terminated = TRUE;
 }
 
 
/***
@@ -1212,7 +1213,7 @@ acpi_status acpi_db_user_commands(char prompt, union 
acpi_parse_object *op)
 
/* TBD: [Restructure] Need a separate command line buffer for step mode 
*/
 
-   while (!acpi_gbl_db_terminate_threads) {
+   while (!acpi_gbl_db_terminate_loop) {
 
/* Force output to console until a command is entered */
 
@@ -1261,14 +1262,5 @@ acpi_status acpi_db_user_commands(char prompt, union 
acpi_parse_object *op)
}
}
 
-   /* Shut down the debugger */
-
-   acpi_terminate_debugger();
-
-   /*
-* Only this thread (the original thread) should actually terminate the
-* subsystem, because all the semaphores are deleted during termination
-*/
-   status = acpi_terminate();
return (status);
 }
diff --git a/drivers/acpi/acpica/dbxface.c b/drivers/acpi/acpica/dbxface.c
index 26023bd..bef5f4e 100644
--- a/drivers/acpi/acpica/dbxface.c
+++ b/drivers/acpi/acpica/dbxface.c
@@ -401,6 +401,10 @@ acpi_status acpi_initialize_debugger(void)
acpi_gbl_db_scope_buf[1] = 0;
acpi_gbl_db_scope_node = acpi_gbl_root_node;
 
+   /* Initialize user commands loop */
+
+   acpi_gbl_db_terminate_loop = FALSE;
+
/*
 * If configured for multi-thread support, the debug executor runs in
 * a separate thread so that the front end can be in another address
@@ -426,11 +430,13 @@ acpi_status acpi_initialize_debugger(void)
 
/* Create the debug execution thread to execute commands */
 
+   acpi_gbl_db_threads_terminated = FALSE;
status = acpi_os_execute(OSL_DEBUGGER_THREAD,
 acpi_db_execute_thread, NULL);
if (ACPI_FAILURE(status)) {
ACPI_EXCEPTION((AE_INFO, status,
"Could not start debugger thread"));
+   acpi_gbl_db_threads_terminated = TRUE;
return_ACPI_STATUS(status);