readded with-enabled-interrupts
This commit is contained in:
parent
539638acbd
commit
6f15160aac
|
@ -64,7 +64,7 @@
|
||||||
|
|
||||||
(define *enabled-interrupts*
|
(define *enabled-interrupts*
|
||||||
(let lp ((i 0) (mask 0))
|
(let lp ((i 0) (mask 0))
|
||||||
(if (= i (number-of-interrupts))
|
(if (= i number-of-interrupts)
|
||||||
mask
|
mask
|
||||||
(lp (+ i 1) (interrupt-enable i mask)))))
|
(lp (+ i 1) (interrupt-enable i mask)))))
|
||||||
|
|
||||||
|
@ -77,11 +77,10 @@
|
||||||
;;;
|
;;;
|
||||||
;;; I think you should...
|
;;; I think you should...
|
||||||
(define (set-enabled-interrupts new-enabled-interrupts)
|
(define (set-enabled-interrupts new-enabled-interrupts)
|
||||||
(let ((number-of-interrupts (number-of-interrupts)))
|
(do ((int 0 (+ int 1)))
|
||||||
(do ((int 0 (+ int 1)))
|
((= int number-of-interrupts) new-enabled-interrupts)
|
||||||
((= int number-of-interrupts) new-enabled-interrupts)
|
(let ((old-state (interrupt-enabled? int *enabled-interrupts*))
|
||||||
(let ((old-state (interrupt-enabled? int *enabled-interrupts*))
|
(new-state (interrupt-enabled? int new-enabled-interrupts)))
|
||||||
(new-state (interrupt-enabled? int new-enabled-interrupts)))
|
|
||||||
(cond ((and old-state (not new-state))
|
(cond ((and old-state (not new-state))
|
||||||
(vector-set! blockade-vector int (block-interrupt int)))
|
(vector-set! blockade-vector int (block-interrupt int)))
|
||||||
((and (not old-state) new-state)
|
((and (not old-state) new-state)
|
||||||
|
@ -90,7 +89,7 @@
|
||||||
(error "there was no blockade" int))
|
(error "there was no blockade" int))
|
||||||
(unblock-interrupt blockade)
|
(unblock-interrupt blockade)
|
||||||
(vector-set! blockade-vector int #f)))
|
(vector-set! blockade-vector int #f)))
|
||||||
(else 'unchanged)))))
|
(else 'unchanged))))
|
||||||
(set! *enabled-interrupts* new-enabled-interrupts))
|
(set! *enabled-interrupts* new-enabled-interrupts))
|
||||||
|
|
||||||
;;; Enableing/Disableing = Unblocking/Blocking
|
;;; Enableing/Disableing = Unblocking/Blocking
|
||||||
|
@ -118,7 +117,7 @@
|
||||||
(pending? #f))
|
(pending? #f))
|
||||||
|
|
||||||
|
|
||||||
(define blockade-vector (make-vector (number-of-interrupts) #f))
|
(define blockade-vector (make-vector number-of-interrupts #f))
|
||||||
|
|
||||||
;;; do nothing in low-interrupt, the new handler will be recorded in the
|
;;; do nothing in low-interrupt, the new handler will be recorded in the
|
||||||
;;; interrupt-handler-vector however
|
;;; interrupt-handler-vector however
|
||||||
|
@ -140,7 +139,7 @@
|
||||||
low-int-set!)))
|
low-int-set!)))
|
||||||
; fade out the low-interupt-set
|
; fade out the low-interupt-set
|
||||||
(set-cdr! handler-setter-cell (fake-set-interrupt blockade))
|
(set-cdr! handler-setter-cell (fake-set-interrupt blockade))
|
||||||
; set the fake handler in low-interupt:
|
; set the fake handler in low-interupt:
|
||||||
((blockade:low-int-set! blockade) (fake-handler blockade))
|
((blockade:low-int-set! blockade) (fake-handler blockade))
|
||||||
blockade))
|
blockade))
|
||||||
|
|
||||||
|
@ -150,80 +149,63 @@
|
||||||
; install the handler that resides in the vector
|
; install the handler that resides in the vector
|
||||||
(let ((low-int-set! (blockade:low-int-set! blockade)))
|
(let ((low-int-set! (blockade:low-int-set! blockade)))
|
||||||
(low-int-set! handler)
|
(low-int-set! handler)
|
||||||
; resinstall the low-interrupt-setter
|
; reinstall the low-interrupt-setter
|
||||||
(set-cdr! (blockade:interrupt-vector-cell blockade)
|
(set-cdr! (blockade:interrupt-vector-cell blockade)
|
||||||
low-int-set!)
|
low-int-set!)
|
||||||
(if (blockade:pending? blockade)
|
(if (blockade:pending? blockade)
|
||||||
(apply handler (blockade:pending? blockade))))))
|
(apply handler (blockade:pending? blockade))))))
|
||||||
|
|
||||||
|
|
||||||
;(define-simple-syntax (with-enabled-interrupts mask body ...)
|
(define-simple-syntax (with-enabled-interrupts interrupt-set body ...)
|
||||||
; (with-interrupts mask (lambda () body ...)))
|
|
||||||
(define-simple-syntax (with-enabled-interrupts mask body ...)
|
|
||||||
(begin
|
(begin
|
||||||
;(display "JMG: use of w-e-i")
|
(with-enabled-interrupts* interrupt-set (lambda () body ...))))
|
||||||
body ...))
|
|
||||||
|
|
||||||
(define (with-enabled-interrupts* thunk thunk)
|
(define (with-enabled-interrupts* interrupt-set thunk)
|
||||||
(warn "JMG: use of with-enabled-interrupts*")
|
(let ((before *enabled-interrupts*))
|
||||||
(thunk))
|
(set-enabled-interrupts interrupt-set)
|
||||||
|
(let ((return (thunk)))
|
||||||
|
(set-enabled-interrupts before)
|
||||||
|
return)))
|
||||||
|
|
||||||
|
|
||||||
; Fakes vm vector
|
; Fakes vm vector
|
||||||
;;; car is the actual handler, cdr is a proc to set handler in low-interrupt system
|
;;; car is the actual handler, cdr is a proc to set handler in
|
||||||
|
;;; low-interrupt system
|
||||||
|
|
||||||
(define *interrupt-handlers-vector*
|
(define *interrupt-handlers-vector*
|
||||||
(make-vector (number-of-interrupts) (cons #f #f)))
|
(make-vector number-of-interrupts (cons #f #f)))
|
||||||
|
|
||||||
(define (interrupt-handlers-vector)
|
(define (interrupt-handlers-vector)
|
||||||
*interrupt-handlers-vector*)
|
*interrupt-handlers-vector*)
|
||||||
|
|
||||||
(define (interrupt-handler-ref int)
|
(define (interrupt-handler-ref int)
|
||||||
(if (or (< int 0) (>= int (number-of-interrupts)))
|
(if (or (< int 0) (>= int number-of-interrupts))
|
||||||
(error "ill signum in interrupt-handler-ref" int)
|
(error "ill signum in interrupt-handler-ref" int)
|
||||||
(car (vector-ref *interrupt-handlers-vector* int))))
|
(car (vector-ref *interrupt-handlers-vector* int))))
|
||||||
|
|
||||||
|
;;; the handler is not interested in the enabled interupts of the vm
|
||||||
|
;;; but in those managed here
|
||||||
|
(define (make-handler handler)
|
||||||
|
(lambda (enabled-low)
|
||||||
|
(handler (enabled-interrupts))))
|
||||||
|
|
||||||
(define (set-interrupt-handler! int handler)
|
(define (set-interrupt-handler! int handler)
|
||||||
(if (or (< int 0) (>= int (number-of-interrupts)))
|
(if (or (< int 0) (>= int number-of-interrupts))
|
||||||
(error "ill signum in set-interrupt-handler!" int)
|
(error "ill signum in set-interrupt-handler!" int)
|
||||||
(let ((old (vector-ref *interrupt-handlers-vector* int)))
|
(let ((handler-setter (vector-ref *interrupt-handlers-vector* int))
|
||||||
(if (not (cdr old)) ; not yet registered?
|
(handler-enabled-here (make-handler handler)))
|
||||||
|
(if (not (cdr handler-setter)) ; not yet registered?
|
||||||
(let ((setter (low-interrupt-register
|
(let ((setter (low-interrupt-register
|
||||||
int handler)))
|
int handler-enabled-here)))
|
||||||
(vector-set! *interrupt-handlers-vector*
|
(vector-set! *interrupt-handlers-vector*
|
||||||
int
|
int
|
||||||
(cons handler setter)))
|
(cons handler setter)))
|
||||||
(begin
|
(begin
|
||||||
((cdr old) handler) ; set it with setter
|
((cdr handler-setter) handler-enabled-here) ; set it with setter
|
||||||
(set-car! (vector-ref *interrupt-handlers-vector* int)
|
(set-car! (vector-ref *interrupt-handlers-vector* int)
|
||||||
handler))))))
|
handler))))))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
;(define (init-interrupt)
|
|
||||||
; (do ((sig 32 (- sig 1)))
|
|
||||||
; ((< sig 0))
|
|
||||||
|
|
||||||
|
|
||||||
; (set-scsh-low-interrupt-handler!
|
|
||||||
; sig
|
|
||||||
; (lambda (x) #t)))
|
|
||||||
; (set-interrupt-handler!
|
|
||||||
; (enum interrupt os-signal)
|
|
||||||
; (lambda (type arg enabled-interrupts)
|
|
||||||
; (if (= type (enum scsh-os-signal chld))
|
|
||||||
; (begin
|
|
||||||
; (procobj-handler enabled-interrupts)))
|
|
||||||
; ((scsh-os-signal-handler-ref type) enabled-interrupts)
|
|
||||||
; ))
|
|
||||||
; (display "sighandler installed")
|
|
||||||
; #t)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
;;; Get/Set signal handlers
|
;;; Get/Set signal handlers
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
|
@ -352,7 +334,7 @@
|
||||||
|
|
||||||
(define (%install-scsh-handlers)
|
(define (%install-scsh-handlers)
|
||||||
(do ((int 0 (+ int 1)))
|
(do ((int 0 (+ int 1)))
|
||||||
((= int (number-of-interrupts)))
|
((= int number-of-interrupts))
|
||||||
(set-interrupt-handler
|
(set-interrupt-handler
|
||||||
int
|
int
|
||||||
(lambda a #f)))
|
(lambda a #f)))
|
||||||
|
|
Loading…
Reference in New Issue