Home | History | Annotate | Line # | Download | only in include
frameasm.h revision 1.19
      1  1.19      maxv /*	$NetBSD: frameasm.h,v 1.19 2018/01/07 12:42:47 maxv Exp $	*/
      2   1.1      fvdl 
      3   1.1      fvdl #ifndef _I386_FRAMEASM_H_
      4   1.1      fvdl #define _I386_FRAMEASM_H_
      5   1.1      fvdl 
      6   1.1      fvdl #ifdef _KERNEL_OPT
      7   1.1      fvdl #include "opt_multiprocessor.h"
      8  1.11    bouyer #include "opt_xen.h"
      9  1.11    bouyer #endif
     10  1.11    bouyer 
     11  1.11    bouyer #if !defined(XEN)
     12  1.16      maxv #define CLI(reg)	cli
     13  1.16      maxv #define STI(reg)	sti
     14  1.11    bouyer #else
     15  1.11    bouyer /* XXX assym.h */
     16  1.16      maxv #define TRAP_INSTR	int	$0x82
     17  1.16      maxv #define XEN_BLOCK_EVENTS(reg)	movb	$1,EVTCHN_UPCALL_MASK(reg)
     18  1.16      maxv #define XEN_UNBLOCK_EVENTS(reg)	movb	$0,EVTCHN_UPCALL_MASK(reg)
     19  1.16      maxv #define XEN_TEST_PENDING(reg)	testb	$0xFF,EVTCHN_UPCALL_PENDING(reg)
     20  1.16      maxv 
     21  1.16      maxv #define CLI(reg)	movl	CPUVAR(VCPU),reg ;  \
     22  1.16      maxv 			XEN_BLOCK_EVENTS(reg)
     23  1.16      maxv #define STI(reg)	movl	CPUVAR(VCPU),reg ;  \
     24  1.11    bouyer 			XEN_UNBLOCK_EVENTS(reg)
     25  1.16      maxv #define STIC(reg)	movl	CPUVAR(VCPU),reg ;  \
     26  1.11    bouyer 			XEN_UNBLOCK_EVENTS(reg)  ; \
     27  1.16      maxv 			testb	$0xff,EVTCHN_UPCALL_PENDING(reg)
     28   1.1      fvdl #endif
     29   1.1      fvdl 
     30  1.19      maxv #define HOTPATCH(name, size) \
     31  1.19      maxv 123:						; \
     32  1.19      maxv 	.section	.rodata.hotpatch, "a"	; \
     33  1.19      maxv 	.byte		name			; \
     34  1.19      maxv 	.byte		size			; \
     35  1.19      maxv 	.long		123b			; \
     36  1.19      maxv 	.previous
     37  1.19      maxv 
     38   1.1      fvdl /*
     39   1.1      fvdl  * These are used on interrupt or trap entry or exit.
     40   1.1      fvdl  */
     41   1.1      fvdl #define	INTRENTRY \
     42   1.1      fvdl 	subl	$TF_PUSHSIZE,%esp	; \
     43  1.14  gmcgarry 	movw	%gs,TF_GS(%esp)	; \
     44  1.14  gmcgarry 	movw	%fs,TF_FS(%esp) ; \
     45   1.3  junyoung 	movl	%eax,TF_EAX(%esp)	; \
     46  1.14  gmcgarry 	movw	%es,TF_ES(%esp) ; \
     47  1.14  gmcgarry 	movw	%ds,TF_DS(%esp) ; \
     48   1.3  junyoung 	movl	$GSEL(GDATA_SEL, SEL_KPL),%eax	; \
     49   1.1      fvdl 	movl	%edi,TF_EDI(%esp)	; \
     50   1.1      fvdl 	movl	%esi,TF_ESI(%esp)	; \
     51  1.14  gmcgarry 	movw	%ax,%ds	; \
     52   1.1      fvdl 	movl	%ebp,TF_EBP(%esp)	; \
     53  1.14  gmcgarry 	movw	%ax,%es	; \
     54   1.1      fvdl 	movl	%ebx,TF_EBX(%esp)	; \
     55  1.14  gmcgarry 	movw	%ax,%gs	; \
     56   1.3  junyoung 	movl	%edx,TF_EDX(%esp)	; \
     57   1.1      fvdl 	movl	$GSEL(GCPU_SEL, SEL_KPL),%eax	; \
     58   1.3  junyoung 	movl	%ecx,TF_ECX(%esp)	; \
     59   1.1      fvdl 	movl	%eax,%fs	; \
     60  1.17      maxv 	cld
     61   1.1      fvdl 
     62   1.1      fvdl #define	INTRFASTEXIT \
     63  1.18      maxv 	jmp	intrfastexit
     64   1.1      fvdl 
     65   1.8      yamt #define	DO_DEFERRED_SWITCH \
     66   1.4      yamt 	cmpl	$0, CPUVAR(WANT_PMAPLOAD)		; \
     67   1.4      yamt 	jz	1f					; \
     68   1.4      yamt 	call	_C_LABEL(pmap_load)			; \
     69   1.4      yamt 	1:
     70   1.4      yamt 
     71  1.10      yamt #define	DO_DEFERRED_SWITCH_RETRY \
     72  1.10      yamt 	1:						; \
     73  1.10      yamt 	cmpl	$0, CPUVAR(WANT_PMAPLOAD)		; \
     74  1.10      yamt 	jz	1f					; \
     75  1.10      yamt 	call	_C_LABEL(pmap_load)			; \
     76  1.10      yamt 	jmp	1b					; \
     77  1.10      yamt 	1:
     78  1.10      yamt 
     79   1.8      yamt #define	CHECK_DEFERRED_SWITCH \
     80   1.4      yamt 	cmpl	$0, CPUVAR(WANT_PMAPLOAD)
     81   1.4      yamt 
     82   1.2   thorpej #define	CHECK_ASTPENDING(reg)	movl	CPUVAR(CURLWP),reg	; \
     83  1.12      yamt 				cmpl	$0, L_MD_ASTPENDING(reg)
     84   1.7        ad #define	CLEAR_ASTPENDING(reg)	movl	$0, L_MD_ASTPENDING(reg)
     85   1.1      fvdl 
     86   1.6      yamt /*
     87   1.6      yamt  * IDEPTH_INCR:
     88   1.6      yamt  * increase ci_idepth and switch to the interrupt stack if necessary.
     89   1.6      yamt  * note that the initial value of ci_idepth is -1.
     90   1.6      yamt  *
     91   1.6      yamt  * => should be called with interrupt disabled.
     92   1.6      yamt  * => save the old value of %esp in %eax.
     93   1.6      yamt  */
     94   1.6      yamt 
     95   1.6      yamt #define	IDEPTH_INCR \
     96   1.6      yamt 	incl	CPUVAR(IDEPTH); \
     97   1.6      yamt 	movl	%esp, %eax; \
     98   1.6      yamt 	jne	999f; \
     99   1.6      yamt 	movl	CPUVAR(INTRSTACK), %esp; \
    100  1.15      yamt 999:	pushl	%eax; /* eax == pointer to intrframe */ \
    101   1.6      yamt 
    102   1.6      yamt /*
    103   1.6      yamt  * IDEPTH_DECR:
    104   1.6      yamt  * decrement ci_idepth and switch back to
    105   1.6      yamt  * the original stack saved by IDEPTH_INCR.
    106   1.6      yamt  *
    107   1.6      yamt  * => should be called with interrupt disabled.
    108   1.6      yamt  */
    109   1.6      yamt 
    110   1.6      yamt #define	IDEPTH_DECR \
    111   1.6      yamt 	popl	%esp; \
    112   1.6      yamt 	decl	CPUVAR(IDEPTH)
    113   1.6      yamt 
    114   1.1      fvdl #endif /* _I386_FRAMEASM_H_ */
    115