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
  
36
  
37
  
38
  
39
  
40
  
41
  
42
  
43
  
44
  
45
  
46
  
47
  
48
  
49
  
50
  
51
  
52
  
53
  
54
  
55
  
56
  
57
  
58
  
59
  
60
  
61
  
62
  
63
  
64
  
65
  
66
  
67
  
68
  
69
  
70
  
71
  
72
  
73
  
74
  
75
  
76
  
77
  
78
  
79
  
80
  
81
  
82
  
83
  
84
  
/* 
|| This file is part of Pike. For copyright information see COPYRIGHT. 
|| Pike is distributed under GPL, LGPL and MPL. See the file COPYING 
|| for more information. 
*/ 
 
/* 
 * Default bytecode assembler for Pike. 
 */ 
 
void ins_f_byte(unsigned int b) 
{ 
  b-=F_OFFSET; 
#ifdef PIKE_DEBUG 
  if(b>255) 
    Pike_error("Instruction too big %d\n",b); 
#endif 
 
  add_to_program((unsigned char)b); 
} 
 
void ins_f_byte_with_arg(unsigned int a, INT32 bb) 
{ 
  unsigned INT32 b = bb; 
  switch(b >> 8) 
  { 
  case 0 : break; 
  case 1 : ins_f_byte(F_PREFIX_256); break; 
  case 2 : ins_f_byte(F_PREFIX_512); break; 
  case 3 : ins_f_byte(F_PREFIX_768); break; 
  case 4 : ins_f_byte(F_PREFIX_1024); break; 
  default: 
    if( b < 256*256) 
    { 
      ins_f_byte(F_PREFIX_CHARX256); 
      add_to_program((unsigned char)(b>>8)); 
    }else if(b < 256*256*256) { 
      ins_f_byte(F_PREFIX_WORDX256); 
      add_to_program((unsigned char)(b>>16)); 
      add_to_program((unsigned char)(b>>8)); 
    }else{ 
      ins_f_byte(F_PREFIX_24BITX256); 
      add_to_program((unsigned char)(b>>24)); 
      add_to_program((unsigned char)(b>>16)); 
      add_to_program((unsigned char)(b>>8)); 
    } 
  } 
  ins_f_byte(a); 
  add_to_program((PIKE_OPCODE_T)b); 
} 
 
void ins_f_byte_with_2_args(unsigned int a, 
                            INT32 c, 
                            INT32 bb) 
{ 
  unsigned INT32 b = bb; 
  switch(b >> 8) 
  { 
  case 0 : break; 
  case 1 : ins_f_byte(F_PREFIX2_256); break; 
  case 2 : ins_f_byte(F_PREFIX2_512); break; 
  case 3 : ins_f_byte(F_PREFIX2_768); break; 
  case 4 : ins_f_byte(F_PREFIX2_1024); break; 
  default: 
    if( b < 256*256) 
    { 
      ins_f_byte(F_PREFIX2_CHARX256); 
      add_to_program((unsigned char)(b>>8)); 
    }else if(b < 256*256*256) { 
      ins_f_byte(F_PREFIX2_WORDX256); 
      add_to_program((unsigned char)(b>>16)); 
      add_to_program((unsigned char)(b>>8)); 
    }else{ 
      ins_f_byte(F_PREFIX2_24BITX256); 
      add_to_program((unsigned char)(b>>24)); 
      add_to_program((unsigned char)(b>>16)); 
      add_to_program((unsigned char)(b>>8)); 
    } 
  } 
  ins_f_byte_with_arg(a,c); 
  add_to_program((PIKE_OPCODE_T)b); 
}