File: TODO

package info (click to toggle)
pypy 7.3.3%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 113,660 kB
  • sloc: python: 1,419,707; ansic: 64,313; cpp: 3,290; sh: 2,763; makefile: 540; xml: 256; asm: 213; lisp: 45; awk: 4
file content (35 lines) | stat: -rw-r--r-- 1,480 bytes parent folder | download | duplicates (2)
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
33
34
35
* cond_call and following guard_exception


* We can try to make generate_quick_failure() emit two instructions less:
  the two store_reg() [one in generate_quick_failure and the other in
  push_gcmap].  Instead we'd load the values in ip2 and ip3, and the
  store_regs would occur inside self.failure_recovery_code
  (which 'target' points to).


* use STP instead of STR in all long sequences of STR.  Same with LDR

* use "STR xzr, [..]" instead of "gen_load_int(ip, 0); STR ip, [..]".
  Search around for gen_load_int(...0): it occurs at least in pop_gcmap()
  _build_failure_recovery(), build_frame_realloc_slowpath(), etc.


* malloc_cond() and malloc_cond_varsize_frame() hard-code forward jump
  distances by guessing the number of instructions that follows.  Bad
  idea because some of these instructions could easily be optimized in
  the future to be a bit shorter.  Rewrite this two places to use the
  proper way instead of a magic "40" (or at least assert that it was
  really 40).


* use "CBNZ register, offset" (compare-and-branch-if-not-zero)
  instead of a CMP+BNE pair.  Same with CBZ instead of CMP+BEQ


* when we need to save things on the stack, we typically push two words
  and pop them later.  It would be cheaper if we reserved two locations
  in the stack from _call_header, then we could just write there.
  *OR*
  maybe it's enough if we use the form "str x0, [sp, !#offset]" which
  combines in a single instruction the "str" with the change of sp