Date: Mon, 30 Apr 2007 14:32:39 -0400 From: John Baldwin <jhb@freebsd.org> To: Alexey Tarasov <taleks@freebsd.org> Cc: Perforce Change Reviews <perforce@freebsd.org> Subject: Re: PERFORCE change 119002 for review Message-ID: <200704301432.40011.jhb@freebsd.org> In-Reply-To: <200704301724.l3UHOrtc053926@repoman.freebsd.org> References: <200704301724.l3UHOrtc053926@repoman.freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Monday 30 April 2007 01:24:53 pm Alexey Tarasov wrote: > http://perforce.freebsd.org/chv.cgi?CH=119002 > > Change 119002 by taleks@taleks_th on 2007/04/30 17:24:19 > > Started adding of isr_install sys call. and call gate selector (from ring 0 to ring 3) to BTX . You don't really need to run the ISR in protected mode. If you check the PXE docs, all you need to do is set a global variable and make a !PXE call. You can write a real-mode ISR to do that and just chain that into the appropriate IRQ. Will be a lot simpler I think. > Affected files ... > > .. //depot/projects/soc2007/taleks-pxe_http/btx_mod/btx/btx.S#2 edit > .. //depot/projects/soc2007/taleks-pxe_http/btx_mod/lib/btxsys.s#2 edit > .. //depot/projects/soc2007/taleks-pxe_http/btx_mod/lib/btxv86.h#2 edit > > Differences ... > > ==== //depot/projects/soc2007/taleks-pxe_http/btx_mod/btx/btx.S#2 (text+ko) ==== > > @@ -44,6 +44,7 @@ > .set SEL_UCODE,0x28|3 # User code > .set SEL_UDATA,0x30|3 # User data > .set SEL_TSS,0x38 # TSS > + .set SEL_CALLGATE,0x40 # super2user callgate > /* > * Task state segment fields. > */ > @@ -56,6 +57,7 @@ > */ > .set SYS_EXIT,0x0 # Exit > .set SYS_EXEC,0x1 # Exec > + .set SYS_ISR_INSTALL,0x2 # ISR_install > /* > * V86 constants. > */ > @@ -620,7 +622,7 @@ > * reads count of words from saved %cx > * returns success by setting %ah to 0 > */ > -int15_87: pushl %esi # Save > +int15_87: pushl %esi # Save > pushl %edi # registers > movl 0x3C(%ebp),%edi # Load ES > movzwl 0x4(%ebp),%eax # Load user's SI > @@ -841,7 +843,9 @@ > /* > * System Call. > */ > -intx30: cmpl $SYS_EXEC,%eax # Exec system call? > +intx30: cmpl $SYS_ISR_INSTALL, %eax # is isr_install? > + je intx30.2 # yes > + cmpl $SYS_EXEC,%eax # Exec system call? > jne intx30.1 # No > pushl %ss # Set up > popl %es # all > @@ -866,6 +870,56 @@ > intx30.1: orb $0x1,%ss:btx_hdr+0x7 # Flag reboot > jmp exit # Exit > /* > + * Here we need to modify IDT in such way, that at interrupt handle > + * will be run isr_trump, which role is to run provided function in user space. > + */ > +intx30.2: xorl %eax,%eax # clear eax > + > +/* > + * updating call gate > + */ > + mov gdtdesc,%edi # calculating descriptors entry > + add $SEL_CALLGATE, %edi # pointing callgate selector > + > + popl %eax # got 32bit offset to handler > + > + mov %ax, (%di) # +0: store offset > + shr $0x10, %eax # getting high word > + mov %ax, 0x6(%di) # +6: handler offset 16..31 > +/* > + * installing handler > + */ > + xor %ax,%ax # clear eax > + pop %ah # getting interrupt number > + mul $0x08,%ax # > + > + mov $MEM_IDT, %di # point to IDT. > + add %ax,%di # calculate entry > + > + mov $SEL_SCODE,%dh # supervisor code selector > + mov user_isr_call, %ax # tramp address > + > + mov $0x8e, %dl # i386+ interrupt gate, DPL=0 > + > + mov %ax,(%di) # 0: handler offset 0..15 > + mov %dh,0x2(%di) # +2: dest selector > + # +4: 000:word_count > + mov %dl,0x5(%di) # +5: P:DPL:type > + # +6: handler offset 16..31 > +/* > + * NOTE: do we need flush caches? > + */ > + iret # return from syscall > + > +user_isr_call: > +/* > + * NOTE: do we need update CS,DS & etc before and restore after? > +*/ > + # far call via callgate selector > + lcall $SEL_S2U_CALL # NOTE: find how it must be. > + iret # return from interrupt handler > + > +/* > * Dump structure [EBX] to [EDI], using format string [ESI]. > */ > dump.0: stosb # Save char > @@ -1098,6 +1152,7 @@ > .word 0xffff,MEM_USR,0xfa00,0xcf# SEL_UCODE > .word 0xffff,MEM_USR,0xf200,0xcf# SEL_UDATA > .word _TSSLM,MEM_TSS,0x8900,0x0 # SEL_TSS > + .word 0x5, 0x0, 0xec00,0x0 # SEL_CALLGATE > gdt.1: > /* > * Pseudo-descriptors. > @@ -1165,6 +1220,7 @@ > .ascii "ss:esp" # "ss:esp=" > .byte 0x80|DMP_MEM|DMP_EOL,0x0 # "00 00 ... 00 00\n" > .asciz "BTX halted\n" # End > + > /* > * End of BTX memory. > */ > > ==== //depot/projects/soc2007/taleks-pxe_http/btx_mod/lib/btxsys.s#2 (text+ko) ==== > > @@ -24,6 +24,7 @@ > # > .global __exit > .global __exec > + .global __isr_install > # > # Constants. > # > @@ -38,3 +39,8 @@ > # > __exec: movl $0x1,%eax # BTX system > int $INT_SYS # call 0x1 > +# > +# System call: isr_install > +# > +__isr_install: movl $0x2,%eax # BTX system > + int $INT_SYS # call 0x2 > > ==== //depot/projects/soc2007/taleks-pxe_http/btx_mod/lib/btxv86.h#2 (text+ko) ==== > > @@ -59,5 +59,10 @@ > > void __exit(int) __attribute__((__noreturn__)); > void __exec(caddr_t, ...); > +/* > + * Installs interrupt handler function for interrupt int_num. > + * caddr_t - in userspace. > + */ > +void __isr_install(caddr_t isr, uint8_t int_num); > > #endif /* !_BTXV86_H_ */ > -- John Baldwin
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200704301432.40011.jhb>