mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
Issue #26647: Python interpreter now uses 16-bit wordcode instead of bytecode.
Patch by Demur Rumed.
This commit is contained in:
parent
c35f491a06
commit
b0f80b0312
18 changed files with 4747 additions and 5022 deletions
38
Python/wordcode_helpers.h
Normal file
38
Python/wordcode_helpers.h
Normal file
|
@ -0,0 +1,38 @@
|
|||
/* This file contains code shared by the compiler and the peephole
|
||||
optimizer.
|
||||
*/
|
||||
|
||||
/* Minimum number of bytes necessary to encode instruction with EXTENDED_ARGs */
|
||||
static int
|
||||
instrsize(unsigned int oparg)
|
||||
{
|
||||
return oparg <= 0xff ? 2 :
|
||||
oparg <= 0xffff ? 4 :
|
||||
oparg <= 0xffffff ? 6 :
|
||||
8;
|
||||
}
|
||||
|
||||
/* Spits out op/oparg pair using ilen bytes. codestr should be pointed at the
|
||||
desired location of the first EXTENDED_ARG */
|
||||
static void
|
||||
write_op_arg(unsigned char *codestr, unsigned char opcode,
|
||||
unsigned int oparg, int ilen)
|
||||
{
|
||||
switch (ilen) {
|
||||
case 8:
|
||||
*codestr++ = EXTENDED_ARG;
|
||||
*codestr++ = (oparg >> 24) & 0xff;
|
||||
case 6:
|
||||
*codestr++ = EXTENDED_ARG;
|
||||
*codestr++ = (oparg >> 16) & 0xff;
|
||||
case 4:
|
||||
*codestr++ = EXTENDED_ARG;
|
||||
*codestr++ = (oparg >> 8) & 0xff;
|
||||
case 2:
|
||||
*codestr++ = opcode;
|
||||
*codestr++ = oparg & 0xff;
|
||||
break;
|
||||
default:
|
||||
assert(0);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue