Properly support 16, 24 and 32-bit modes; now working properly.
[syslinux.git] / abort.inc
blob80d70ad607b4593b7b31e1cbaa36a22657f49fb8
1 ; -----------------------------------------------------------------------
3 ;   Copyright 2005-2006 H. Peter Anvin - All Rights Reserved
5 ;   This program is free software; you can redistribute it and/or modify
6 ;   it under the terms of the GNU General Public License as published by
7 ;   the Free Software Foundation, Inc., 53 Temple Place Ste 330,
8 ;   Boston MA 02111-1307, USA; either version 2 of the License, or
9 ;   (at your option) any later version; incorporated herein by reference.
11 ; -----------------------------------------------------------------------
14 ; abort.inc
16 ; Code to terminate a kernel load
19                 section .text
21 ; abort_check: let the user abort with <ESC> or <Ctrl-C>
23 abort_check:
24                 call pollchar
25                 jz .ret1
26                 pusha
27                 call getchar
28                 cmp al,27                       ; <ESC>
29                 je .kill
30                 cmp al,3                        ; <Ctrl-C>
31                 je .kill
32 .ret2:          popa
33 .ret1:          ret
35 .kill:          mov si,aborted_msg
37                 ; ... fall through ...
40 ; abort_load: Called by various routines which wants to print a fatal
41 ;             error message and return to the command prompt.  Since this
42 ;             may happen at just about any stage of the boot process, assume
43 ;             our state is messed up, and just reset the segment registers
44 ;             and the stack forcibly.
46 ;             SI    = offset (in _text) of error message to print
48 abort_load:
49                 RESET_STACK_AND_SEGS AX
50                 call cwritestr                  ; Expects SI -> error msg
52                 ; Return to the command prompt
53                 jmp enter_command