File: cpatch.lisp

package info (click to toggle)
gcl 2.6.7%2Bdfsga-1
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 84,796 kB
  • sloc: ansic: 452,686; lisp: 156,133; asm: 111,405; sh: 29,299; cpp: 18,599; perl: 5,602; makefile: 5,201; tcl: 3,181; sed: 469; yacc: 378; lex: 174; fortran: 48; awk: 30; csh: 23
file content (32 lines) | stat: -rw-r--r-- 755 bytes parent folder | download | duplicates (14)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
;;				-[Thu Feb 22 08:38:07 1990 by jkf]-
;; cpatch.cl
;;  compiler patch for the fast clos
;;  
;; copyright (c) 1990 Franz Inc.
;;

(in-package :comp)

(def-quad-op tail-funcall qp-end-block
  ;; u = (argcount function-object)
  ;;
  ;; does a tail call to the function-object given
  ;; never returns
  )

(defun-in-runtime sys::copy-function (func))

(in-package :hyperion)

(def-quad-hyp r-tail-funcall comp::tail-funcall (u d quad)
  ;; u = (argcount function)
  ;;
  (r-move-single-to-loc (treg-loc (car u)) *count-reg*)
  (r-move-single-to-loc (treg-loc (cadr u)) *fcnin-reg*)
  (re restore *zero-reg* *zero-reg*)
  (re move.l `(d #.r-function-start-adj #.*fcnout-reg*) '#.*ctr2-reg*)
  (re jmpl '(d 0 #.*ctr2-reg*) *zero-reg*)
  (re nop))