Lines Matching refs:ks
480 static void gdb_cmd_status(struct kgdb_state *ks) in gdb_cmd_status() argument
491 hex_byte_pack(&remcom_out_buffer[1], ks->signo); in gdb_cmd_status()
494 static void gdb_get_regs_helper(struct kgdb_state *ks) in gdb_get_regs_helper() argument
502 thread = kgdb_info[ks->cpu].task; in gdb_get_regs_helper()
503 local_debuggerinfo = kgdb_info[ks->cpu].debuggerinfo; in gdb_get_regs_helper()
538 static void gdb_cmd_getregs(struct kgdb_state *ks) in gdb_cmd_getregs() argument
540 gdb_get_regs_helper(ks); in gdb_cmd_getregs()
545 static void gdb_cmd_setregs(struct kgdb_state *ks) in gdb_cmd_setregs() argument
552 gdb_regs_to_pt_regs(gdb_regs, ks->linux_regs); in gdb_cmd_setregs()
558 static void gdb_cmd_memread(struct kgdb_state *ks) in gdb_cmd_memread() argument
576 static void gdb_cmd_memwrite(struct kgdb_state *ks) in gdb_cmd_memwrite() argument
599 static void gdb_cmd_reg_get(struct kgdb_state *ks) in gdb_cmd_reg_get() argument
609 gdb_get_regs_helper(ks); in gdb_cmd_reg_get()
614 static void gdb_cmd_reg_set(struct kgdb_state *ks) in gdb_cmd_reg_set() argument
623 !dbg_get_reg(regnum, gdb_regs, ks->linux_regs)) { in gdb_cmd_reg_set()
635 dbg_set_reg(regnum, gdb_regs, ks->linux_regs); in gdb_cmd_reg_set()
641 static void gdb_cmd_binwrite(struct kgdb_state *ks) in gdb_cmd_binwrite() argument
652 static void gdb_cmd_detachkill(struct kgdb_state *ks) in gdb_cmd_detachkill() argument
677 static int gdb_cmd_reboot(struct kgdb_state *ks) in gdb_cmd_reboot() argument
698 static void gdb_cmd_query(struct kgdb_state *ks) in gdb_cmd_query() argument
720 ks->thr_query = 0; in gdb_cmd_query()
729 if (i >= ks->thr_query && !finished) { in gdb_cmd_query()
733 ks->thr_query++; in gdb_cmd_query()
734 if (ks->thr_query % KGDB_MAX_THREAD_QUERY == 0) in gdb_cmd_query()
746 ks->threadid = shadow_pid(current->pid); in gdb_cmd_query()
747 int_to_threadref(thref, ks->threadid); in gdb_cmd_query()
754 ks->threadid = 0; in gdb_cmd_query()
756 kgdb_hex2long(&ptr, &ks->threadid); in gdb_cmd_query()
757 if (!getthread(ks->linux_regs, ks->threadid)) { in gdb_cmd_query()
761 if ((int)ks->threadid > 0) { in gdb_cmd_query()
762 kgdb_mem2hex(getthread(ks->linux_regs, in gdb_cmd_query()
763 ks->threadid)->comm, in gdb_cmd_query()
769 (int)(-ks->threadid - 2)); in gdb_cmd_query()
787 kdb_common_init_state(ks); in gdb_cmd_query()
812 static void gdb_cmd_task(struct kgdb_state *ks) in gdb_cmd_task() argument
820 kgdb_hex2long(&ptr, &ks->threadid); in gdb_cmd_task()
821 thread = getthread(ks->linux_regs, ks->threadid); in gdb_cmd_task()
822 if (!thread && ks->threadid > 0) { in gdb_cmd_task()
827 ks->kgdb_usethreadid = ks->threadid; in gdb_cmd_task()
832 kgdb_hex2long(&ptr, &ks->threadid); in gdb_cmd_task()
833 if (!ks->threadid) { in gdb_cmd_task()
836 thread = getthread(ks->linux_regs, ks->threadid); in gdb_cmd_task()
837 if (!thread && ks->threadid > 0) { in gdb_cmd_task()
849 static void gdb_cmd_thread(struct kgdb_state *ks) in gdb_cmd_thread() argument
854 kgdb_hex2long(&ptr, &ks->threadid); in gdb_cmd_thread()
855 thread = getthread(ks->linux_regs, ks->threadid); in gdb_cmd_thread()
863 static void gdb_cmd_break(struct kgdb_state *ks) in gdb_cmd_break() argument
925 static int gdb_cmd_exception_pass(struct kgdb_state *ks) in gdb_cmd_exception_pass() argument
932 ks->pass_exception = 1; in gdb_cmd_exception_pass()
937 ks->pass_exception = 1; in gdb_cmd_exception_pass()
957 int gdb_serial_stub(struct kgdb_state *ks) in gdb_serial_stub() argument
964 kgdb_usethread = kgdb_info[ks->cpu].task; in gdb_serial_stub()
965 ks->kgdb_usethreadid = shadow_pid(kgdb_info[ks->cpu].task->pid); in gdb_serial_stub()
966 ks->pass_exception = 0; in gdb_serial_stub()
975 ptr = hex_byte_pack(ptr, ks->signo); in gdb_serial_stub()
993 gdb_cmd_status(ks); in gdb_serial_stub()
996 gdb_cmd_getregs(ks); in gdb_serial_stub()
999 gdb_cmd_setregs(ks); in gdb_serial_stub()
1002 gdb_cmd_memread(ks); in gdb_serial_stub()
1005 gdb_cmd_memwrite(ks); in gdb_serial_stub()
1009 gdb_cmd_reg_get(ks); in gdb_serial_stub()
1012 gdb_cmd_reg_set(ks); in gdb_serial_stub()
1016 gdb_cmd_binwrite(ks); in gdb_serial_stub()
1023 gdb_cmd_detachkill(ks); in gdb_serial_stub()
1026 if (gdb_cmd_reboot(ks)) in gdb_serial_stub()
1030 gdb_cmd_query(ks); in gdb_serial_stub()
1033 gdb_cmd_task(ks); in gdb_serial_stub()
1036 gdb_cmd_thread(ks); in gdb_serial_stub()
1040 gdb_cmd_break(ks); in gdb_serial_stub()
1045 gdb_cmd_detachkill(ks); in gdb_serial_stub()
1051 tmp = gdb_cmd_exception_pass(ks); in gdb_serial_stub()
1067 error = kgdb_arch_handle_exception(ks->ex_vector, in gdb_serial_stub()
1068 ks->signo, in gdb_serial_stub()
1069 ks->err_code, in gdb_serial_stub()
1072 ks->linux_regs); in gdb_serial_stub()
1090 if (ks->pass_exception) in gdb_serial_stub()
1095 int gdbstub_state(struct kgdb_state *ks, char *cmd) in gdbstub_state() argument
1101 error = kgdb_arch_handle_exception(ks->ex_vector, in gdbstub_state()
1102 ks->signo, in gdbstub_state()
1103 ks->err_code, in gdbstub_state()
1106 ks->linux_regs); in gdbstub_state()