root/platform/g11/sub/100l/stubs_entry.S

/* [<][>][^][v][top][bottom][index][help] */
   1 // !!! THIS FILE IS GENERATED. DO NOT EDIT. !!!
   2 #include "stubs_asm.h"
   3 
   4 // Camera info:
   5 //   DRYOS R39 (DRYOS version 2.3, release #0039)
   6 //   Firmware Ver GM1.00L   // Found @ 0xff88c7ec, "GM1.00L" @ 0xff88c7f9
   7 //   Firmware build timestamp: Jan  7 2010 13:21:02
   8 //   Canon PowerShot G11
   9 
  10 // Values for makefile.inc
  11 //   PLATFORMOSVER = 39
  12 //   PLATFORMID = 12767 (0x31df) // Found @ 0xfffe0130
  13 //   MAXRAMADDR = 0x03ffffff
  14 //   MEMISOSTART = 0x001411e8
  15 //   KEYSYS = d4                 // Found @ 0xffff35a8
  16 //   NEED_ENCODED_DISKBOOT = 3   // Found @ 0xffff35b8
  17 //   ARAM_HEAP_START = 0x3ce000  // Found @ 0xff971d1c
  18 //   ARAM_HEAP_SIZE  = 0x32000   // Found @ 0xff971cdc
  19 
  20 // Detected address ranges:
  21 // ROM      0xff810000 - 0xffffffff (8323072 bytes)
  22 // RAM data 0x00001900 - 0x0000e90c copied from 0xffc0c3f8 (  53260 bytes)
  23 
  24 // Stubs below should be checked. Stub not matched 100%, or difference found to current 'stubs_entry_2.S'
  25 //    Name                                     Address      Rule  %  Comp to stubs_entry_2.S
  26 //NHSTUB(SetScriptMode                        ,0xff895134) //120        *** != 0xff810f4c
  27 //NHSTUB(TurnOffBackLight                     ,0xff8a34dc) //104        *** != 0xff8a348c
  28 NHSTUB(kbd_pwr_off                            ,0xff86043c) //  2 64%
  29 
  30 // Check of modemap from 'platform/CAMERA/shooting.c':
  31 // Firmware modemap table found @ffab4a38 -> ffbe71cc
  32 // No problems found with modemap table.
  33 
  34 // Values below can be overridden in 'stubs_min.S':
  35 DEF(physw_status                            ,0x00032578) // Found @0xff833584
  36 DEF(physw_run                               ,0x00001c44) // Found @0xff8331f4
  37 DEF(physw_sleep_delay                       ,0x00001c42) // Found @0xff8331f4
  38 DEF(levent_table                            ,0xffb95fe0) // Found @0xffb95fe0
  39 DEF(FlashParamsTable                        ,0xffbe73c0) // Found @0xffbe73c0
  40 DEF(movie_status                            ,0x00006d90) // Found @0xff962a78
  41 DEF(video_compression_rate                  ,0x00006dbc) // Found @0xff962c34
  42 DEF(full_screen_refresh                     ,0x00009840) // Found @0xffa0ee98
  43 DEF(canon_menu_active                       ,0x0000303c) // Found @0xff88e2cc
  44 DEF(canon_shoot_menu_active                 ,0x00008259) // Found @0xff9afaf4
  45 DEF(playrec_mode                            ,0x00002d64) // Found @0xff8805a8
  46 DEF(zoom_status                             ,0x0000c868) // Found @0xffab7924
  47 DEF(some_flag_for_af_scan                   ,0x000072b4) // Found @0xff9660f0
  48 // focus_len_table contains zoom focus lengths for use in 'get_focal_length' (main.c).
  49 // each entry contains 3 int value(s), the first is the zoom focus length.
  50 // there are 14 entries in the table - set NUM_FL to 14
  51 DEF(focus_len_table                         ,0xfffe2a8c) // Found @0xfffe2a8c
  52 DEF(zoom_busy                               ,0x00006cc0) // Found @0xff95ec54
  53 DEF(focus_busy                              ,0x00006bb4) // Found @0xff959c48
  54 //DEF(recreview_hold                          ,0x00003be4) // Found @0xff89fb4c, ** != ** stubs_min = 0x00007dd8 (0x7D00+0xD8)
  55 // Palette colour tables  found @ 0xffbb0cc0
  56 DEF(active_palette_buffer                   ,0x00009848) // Found @0xffa0edd4
  57 DEF(palette_buffer_ptr                      ,0x00009854) // Found @0xffa0eaa8
  58 // Offset from start of palette_buffer to color data = 8 (Found @0xffaeddd4)
  59 // Camera appears to have only 1 RAW buffer @ 0x41c0f460 (Found @0xffb09bc8)
  60 DEF(fileio_semaphore                        ,0x00002a00) // Found @0xff86e298
  61 DEF(exmem_alloc_table                       ,0x00038efc) // Found @0xff887b8c
  62 DEF(exmem_types_table                       ,0xffc0d984) // Found @0x00002e8c
  63 DEF_CONST(exmem_type_count                  ,0x00000012)
  64 DEF(imager_active                           ,0x0000201c) // Found @0xff84b6b4 (0x2018 + 4)
  65 DEF_CONST(uiprop_count                      ,0x0000006e) // Found @0xff995e24
  66 
  67 // Values below go in 'lib.c':
  68 //void *vid_get_bitmap_fb()        { return (void*)0x40471000; }             // Found @0xff85a4c0
  69 //void *vid_get_viewport_fb()      { return (void*)0x40587700; }             // Found @0xffb0696c
  70 DEF(viewport_fb_d                           ,0x00002aa8) // Found 0x2a50 (@0xff871348) + 0x58 (@0xff871380)
  71 //void *vid_get_viewport_fb_d()    { return (void*)(*(int*)(0x2a50+0x58)); } // Found @0xff871348 & 0xff871380
  72 DEF(jpeg_count_str                          ,0x00097234) // Found @0xffa012ac
  73 //char *camera_jpeg_count_str()    { return (char*)0x00097234; }             // Found @0xffa012ac
  74 //int get_flash_params_count(void) { return 0x84; }                          // Found @0xff996a78
  75 
  76 // Bitmap masks and physw_status index values for SD_READONLY and USB power flags (for kbd.c).
  77 //#define SD_READONLY_FLAG    0x00020000 // Found @0xffb477ac, levent 0x90a
  78 //#define SD_READONLY_IDX     2
  79 //#define USB_MASK            0x00100000 // Found @0xffb477d0, levent 0x902
  80 //#define USB_IDX             2
  81 //#define BATTCOVER_FLAG      0x00008000 // Found @0xffb47794, levent 0x905
  82 //#define BATTCOVER_IDX       2
  83 //#define HOTSHOE_FLAG        0x00080000 // Found @0xffb477c4, levent 0x904
  84 //#define HOTSHOE_IDX         2
  85 //#define ANALOG_AV_FLAG      0x00040000 // Found @0xffb477b8, levent 0x900 (non-inverted logic)
  86 //#define ANALOG_AV_IDX       2
  87 
  88 // Keymap values for kbd.c. Additional keys may be present, only common values included here.
  89 //static KeyMap keymap[] = {
  90 //    { 0, KEY_ZOOM_OUT        ,0x00000008 }, // Found @0xffb47638, levent 0x03
  91 //    { 0, KEY_ZOOM_IN         ,0x00000010 }, // Found @0xffb47644, levent 0x02
  92 //    { 0, KEY_LEFT            ,0x00000400 }, // Found @0xffb4768c, levent 0x06
  93 //    { 0, KEY_SET             ,0x00000800 }, // Found @0xffb47698, levent 0x08
  94 //    { 0, KEY_RIGHT           ,0x00001000 }, // Found @0xffb476a4, levent 0x07
  95 //    { 0, KEY_DOWN            ,0x00002000 }, // Found @0xffb476b0, levent 0x05
  96 //    { 0, KEY_UP              ,0x00004000 }, // Found @0xffb476bc, levent 0x04
  97 //    { 0, KEY_DISPLAY         ,0x00020000 }, // Found @0xffb476e0, levent 0x0a
  98 //    { 0, KEY_MENU            ,0x00040000 }, // Found @0xffb476ec, levent 0x09
  99 //    { 2, KEY_SHOOT_FULL      ,0x00000003 }, // Found @0xffb47770, levent 0x01
 100 //    { 2, KEY_SHOOT_FULL_ONLY ,0x00000002 }, // Found @0xffb47770, levent 0x01
 101 //    { 2, KEY_SHOOT_HALF      ,0x00000001 }, // Found @0xffb47764, levent 0x00
 102 //    { 2, KEY_POWER           ,0x00000004 }, // Found @0xffb4777c, levent 0x600 (uses inverted logic in physw_status)
 103 //    { 2, KEY_PLAYBACK        ,0x00000008 }, // Found @0xffb47788, levent 0x601 (uses inverted logic in physw_status)
 104 //    { 0, 0, 0 }
 105 //};
 106 
 107 // Values below go in 'platform_camera.h':
 108 //#define CAM_DRYOS         1
 109 //#define CAM_DRYOS_2_3_R39 1 // Defined for cameras with DryOS version R39 or higher
 110 //#define CAM_RAW_ROWPIX    3744 // Found @0xff935818
 111 //#define CAM_RAW_ROWS      2784 // Found @0xff935820
 112 //#undef  CAM_UNCACHED_BIT
 113 //#define CAM_UNCACHED_BIT  0x40000000 // Found @0xff839460
 114 //#define CAM_DATE_FOLDER_NAMING 0x100 // Found @0xffa70a0c (pass as 3rd param to GetImageFolder)
 115 //#define PARAM_CAMERA_NAME 4 // Found @0xffbe9bc8
 116 
 117 // Known propcases
 118 // //      PROPCASE_AFSTEP 13
 119 // #define PROPCASE_FOCUS_STATE 18
 120 // #define PROPCASE_AV 23
 121 // #define PROPCASE_BV 34
 122 // //      PROPCASE_DELTA_DIGITALGAIN 77
 123 // #define PROPCASE_DELTA_SV 79
 124 // //      PROPCASE_DELTA_ND 80
 125 // #define PROPCASE_EV_CORRECTION_2 209
 126 // #define PROPCASE_ORIENTATION_SENSOR 221
 127 // #define PROPCASE_SV_MARKET 248
 128 // //      PROPCASE_SVFIX 249
 129 // #define PROPCASE_TV 264
 130 // Guessed propset: 3
 131 
 132 // Misc stuff
 133 DEF(ctypes, 0xffb40586)
 134 
 135 // EXMEM types:
 136 // EXMEM_RAMDISK        0
 137 // EXMEM_COM            1
 138 // EXMEM_FORMATTER      2
 139 // EXMEM_SHADING        3
 140 // EXMEM_FAMODE         4
 141 // EXMEM_FIRMUP         5
 142 // EXMEM_FIRMUP_VRAM    6
 143 // EXMEM_FIRMUP_INFLATE 7
 144 // EXMEM_DVLPWORK       8
 145 // EXMEM_EVF            9
 146 // EXMEM_SCRIPT         10
 147 // EXMEM_FILESTORE      11
 148 // EXMEM_MOVIE_REC      12
 149 // EXMEM_MOVIE_PLY      13
 150 // EXMEM_WIDE           14
 151 // EXMEM_NARROW         15
 152 // EXMEM_CRAW_REC       16
 153 // EXMEM_PCEVF          17
 154 
 155 // ISR flag: 0x1964, pointer to current task's control block: 0x1960
 156 // pointer to TCB area: 0x19f0, found @ 0xff81683c
 157 
 158 // LED table init @ 0xff9172ec
 159 // LED #1: 0xc022012c, offset 0x384
 160 // LED #2: 0xc0220128, offset 0x3c4
 161 // LED #3: 0xc0220138, offset 0x84
 162 // LED #4: 0xc0220124, offset 0xc4
 163 // LED #5: 0xc0220134, offset 0x4
 164 // LED #6: 0xc0220130, offset 0x44
 165 
 166 // For capt_seq.c
 167 DEF(_nrflag,0x7290) // Found @ ff9689d8 (0x7298) & ff9689f8 (-0x08)
 168 //static long *nrflag = (long*)(0x7298-0x08);  // Found @ ff9689d8 & ff9689f4
 169 
 170 // Stubs below matched 100%.
 171 //    Name                                     Address                Comp to stubs_entry_2.S
 172 NHSTUB(AllocateUncacheableMemory              ,0xff83941c) //112
 173 NHSTUB(Close                                  ,0xff8359b0) //120
 174 NHSTUB(CreateBinarySemaphore                  ,0xff838bfc) //115
 175 NHSTUB(CreateTask                             ,0xff81e5b4) //120
 176 NHSTUB(DebugAssert                            ,0xff81e88c) //107
 177 NHSTUB(DeleteDirectory_Fut                    ,0xff835420) //116
 178 NHSTUB(DeleteFile_Fut                         ,0xff83533c) //112
 179 NHSTUB(DoAELock                               ,0xff8374e0) //120
 180 NHSTUB(DoAFLock                               ,0xff837158) //120
 181 NHSTUB(EnterToCompensationEVF                 ,0xff8373d8) //104
 182 NHSTUB(ExecuteEventProcedure                  ,0xff889954) //104
 183 NHSTUB(ExitFromCompensationEVF                ,0xff83741c) //104
 184 NHSTUB(ExitTask                               ,0xff81e844) //120
 185 NHSTUB(ExpCtrlTool_StartContiAE               ,0xff844ce0) //104
 186 NHSTUB(ExpCtrlTool_StopContiAE                ,0xff844db8) //104
 187 NHSTUB(Fclose_Fut                             ,0xff8354b8) //120
 188 NHSTUB(Feof_Fut                               ,0xff8356a4) //  1
 189 NHSTUB(Fflush_Fut                             ,0xff8356e0) //  1
 190 NHSTUB(Fgets_Fut                              ,0xff83560c) //  1
 191 NHSTUB(Fopen_Fut                              ,0xff835478) //120
 192 NHSTUB(Fread_Fut                              ,0xff835564) //120
 193 NHSTUB(FreeUncacheableMemory                  ,0xff83945c) //112
 194 NHSTUB(Fseek_Fut                              ,0xff835658) //120
 195 NHSTUB(Fwrite_Fut                             ,0xff8355b8) //120
 196 NHSTUB(GetBatteryTemperature                  ,0xff8635d8) //102
 197 NHSTUB(GetCCDTemperature                      ,0xff863564) //102
 198 NHSTUB(GetCurrentAvValue                      ,0xff95c3ec) //120
 199 NHSTUB(GetCurrentShutterSpeed                 ,0xff8af358) //120
 200 NHSTUB(GetUsableMaxAv                         ,0xffb0106c) //120
 201 NHSTUB(GetUsableMinAv                         ,0xffb01054) //120
 202 NHSTUB(GetDrive_ClusterSize                   ,0xff86fc80) //122
 203 NHSTUB(GetDrive_FreeClusters                  ,0xff86fce0) //  3
 204 NHSTUB(GetDrive_TotalClusters                 ,0xff86fcb4) //  3
 205 NHSTUB(GetFocusLensSubjectDistance            ,0xff95a9c0) //102
 206 NHSTUB(GetFocusLensSubjectDistanceFromLens    ,0xff95ae08) //  3
 207 NHSTUB(GetImageFolder                         ,0xff93d6a4) //122
 208 NHSTUB(GetKbdState                            ,0xff860424) //109
 209 NHSTUB(GetMemInfo                             ,0xff81a070) //115
 210 NHSTUB(GetOpticalTemperature                  ,0xff86364c) //120
 211 NHSTUB(GetParameterData                       ,0xff996a38) //101
 212 NHSTUB(GetPropertyCase                        ,0xff88d700) //102
 213 NHSTUB(GetSystemTime                          ,0xffaa3750) //120
 214 NHSTUB(GetVRAMHPixelsSize                     ,0xff850b08) //120
 215 NHSTUB(GetVRAMVPixelsSize                     ,0xff850b14) //120
 216 NHSTUB(GetZoomLensCurrentPoint                ,0xff95efc8) //120
 217 NHSTUB(GetZoomLensCurrentPosition             ,0xffa9695c) //102
 218 NHSTUB(GiveSemaphore                          ,0xff838e38) //120
 219 NHSTUB(IsStrobeChargeCompleted                ,0xff8db440) //102
 220 NHSTUB(LEDDrive                               ,0xff85f674) //120
 221 NHSTUB(LocalTime                              ,0xff8872c8) //115
 222 NHSTUB(LockMainPower                          ,0xff895394) //120
 223 NHSTUB(MakeDirectory_Fut                      ,0xff8353b0) //116
 224 NHSTUB(MoveFocusLensToDistance                ,0xffb03388) //102
 225 NHSTUB(MoveIrisWithAv                         ,0xffaa0604) //120
 226 NHSTUB(MoveZoomLensWithPoint                  ,0xffaa0d1c) //120
 227 NHSTUB(Open                                   ,0xff835958) //120
 228 NHSTUB(PB2Rec                                 ,0xff8984b0) //104
 229 NHSTUB(PT_MoveDigitalZoomToWide               ,0xff8781c8) //120
 230 NHSTUB(PT_MoveOpticalZoomAt                   ,0xff8781a0) //120
 231 NHSTUB(PT_PlaySound                           ,0xff882464) //102
 232 NHSTUB(PostLogicalEventForNotPowerType        ,0xff8931c0) //120
 233 NHSTUB(PostLogicalEventToUI                   ,0xff89320c) //120
 234 NHSTUB(PutInNdFilter                          ,0xffaa0b80) //102
 235 NHSTUB(PutOutNdFilter                         ,0xffaa0ba4) //102
 236 NHSTUB(Read                                   ,0xff81ab78) //120
 237 NHSTUB(ReadFastDir                            ,0xffa8442c) //  3
 238 NHSTUB(Rec2PB                                 ,0xff8984f0) //104
 239 NHSTUB(RefreshPhysicalScreen                  ,0xffa10094) //104
 240 NHSTUB(RenameFile_Fut                         ,0xff8352a8) //116
 241 NHSTUB(Restart                                ,0xff83ab70) //122
 242 NHSTUB(ScreenLock                             ,0xffa112c4) //117
 243 NHSTUB(ScreenUnlock                           ,0xffa112ec) //117
 244 NHSTUB(SetAE_ShutterSpeed                     ,0xffb05b2c) //102
 245 NHSTUB(SetAutoShutdownTime                    ,0xff895408) //120
 246 NHSTUB(SetCurrentCaptureModeType              ,0xff89cb6c) //120
 247 NHSTUB(SetFileAttributes                      ,0xff835c80) //  3
 248 NHSTUB(SetFileTimeStamp                       ,0xff835c3c) //  3
 249 NHSTUB(SetLogicalEventActive                  ,0xff8950e4) //120
 250 NHSTUB(SetParameterData                       ,0xff996914) //101
 251 NHSTUB(SetPropertyCase                        ,0xff88d5fc) //102
 252 NHSTUB(SleepTask                              ,0xff8390a0) //120
 253 NHSTUB(TakeSemaphore                          ,0xff838d68) //120
 254 NHSTUB(TurnOnBackLight                        ,0xff8a34c4) //104
 255 NHSTUB(TurnOnDisplay                          ,0xff85a6c4) //120
 256 NHSTUB(TurnOffDisplay                         ,0xff85a6d4) //120
 257 NHSTUB(UIFS_WriteFirmInfoToFile               ,0xff98071c) //120
 258 NHSTUB(UnlockAE                               ,0xff837504) //120
 259 NHSTUB(UnlockAF                               ,0xff837190) //120
 260 NHSTUB(UnlockMainPower                        ,0xff8952e8) //120
 261 NHSTUB(UnsetZoomForMovie                      ,0xff99cfe4) //104
 262 NHSTUB(UpdateMBROnFlash                       ,0xff86fb00) //105
 263 NHSTUB(VbattGet                               ,0xff831e08) //120
 264 NHSTUB(Write                                  ,0xff835a40) //120
 265 NHSTUB(WriteSDCard                            ,0xff94b804) //108
 266 NHSTUB(_log                                   ,0xffb3e048) //111
 267 NHSTUB(_log10                                 ,0xffb3cf8c) //112
 268 NHSTUB(_pow                                   ,0xffb3d0fc) //121
 269 NHSTUB(_sqrt                                  ,0xffb3f3b0) //  1
 270 NHSTUB(add_ptp_handler                        ,0xffa4e04c) //121
 271 NHSTUB(apex2us                                ,0xffa14a7c) //121
 272 NHSTUB(close                                  ,0xff81a990) //109
 273 NHSTUB(err_init_task                          ,0xff815f28) //111
 274 NHSTUB(exmem_alloc                            ,0xff888188) //103
 275 NHSTUB(exmem_free                             ,0xff888200) //103
 276 NHSTUB(free                                   ,0xff814138) //112
 277 NHSTUB(get_nd_value                           ,0xffa94770) //122
 278 NHSTUB(get_current_nd_value                   ,0xffa9472c) //122
 279 NHSTUB(kbd_p1_f                               ,0xff833600) //109
 280 NHSTUB(kbd_p1_f_cont                          ,0xff83360c) //109
 281 NHSTUB(kbd_p2_f                               ,0xff832ec0) //109
 282 NHSTUB(kbd_read_keys                          ,0xff833584) //109
 283 NHSTUB(kbd_read_keys_r2                       ,0xff85fb94) //109
 284 NHSTUB(lseek                                  ,0xff835acc) //120
 285 NHSTUB(malloc                                 ,0xff8140dc) //112
 286 NHSTUB(memcmp                                 ,0xff8203ec) //120
 287 NHSTUB(memcpy                                 ,0xff83ea1c) //120
 288 NHSTUB(memset                                 ,0xffa13acc) //120
 289 NHSTUB(mkdir                                  ,0xff835e24) //109
 290 NHSTUB(mktime_ext                             ,0xff8ab0a0) //  1
 291 NHSTUB(open                                   ,0xff81a8e0) //109
 292 NHSTUB(OpenFastDir                            ,0xffa842f8) //  3
 293 NHSTUB(closedir                               ,0xffa842b4) //  3
 294 NHSTUB(get_fstype                             ,0xff86fd04) //122
 295 NHSTUB(qsort                                  ,0xffaf3a98) //  1
 296 NHSTUB(rand                                   ,0xff8204f4) //121
 297 NHSTUB(realloc                                ,0xffa13b48) //115
 298 NHSTUB(reboot_fw_update                       ,0xffa8993c) //106
 299 NHSTUB(set_control_event                      ,0xff894d38) //111
 300 NHSTUB(srand                                  ,0xff8204e8) //122
 301 NHSTUB(stat                                   ,0xff835b08) //109
 302 NHSTUB(strcat                                 ,0xff8aa85c) //  1
 303 NHSTUB(strchr                                 ,0xff813fc0) //  1
 304 NHSTUB(strcmp                                 ,0xff8203a8) //120
 305 NHSTUB(strcpy                                 ,0xff820390) //120
 306 NHSTUB(strftime                               ,0xff8aaaa8) //  1
 307 NHSTUB(strlen                                 ,0xff81400c) //120
 308 NHSTUB(strncmp                                ,0xff813f74) //  1
 309 NHSTUB(strncpy                                ,0xff813f38) //  1
 310 NHSTUB(strrchr                                ,0xff813fe4) //  1
 311 NHSTUB(strtol                                 ,0xff83ecfc) //101
 312 NHSTUB(strtolx                                ,0xff83eb00) //109
 313    DEF(task_CaptSeq                           ,0xff87b18c) //120
 314    DEF(task_DvlpSeqTask                       ,0xff87c94c) //120
 315    DEF(task_ExpDrv                            ,0xff8bfbf8) //120
 316    DEF(task_FileWrite                         ,0xffa7fc84) //120
 317    DEF(task_InitFileModules                   ,0xff898fd8) //120
 318    DEF(task_MovieRecord                       ,0xff962cb0) //120
 319    DEF(task_PhySw                             ,0xff8331f0) //120
 320    DEF(task_RotaryEncoder                     ,0xff860554) //120
 321 NHSTUB(time                                   ,0xff887840) //109
 322 NHSTUB(vsprintf                               ,0xff820354) //115
 323 NHSTUB(EngDrvRead                             ,0xff834448) //102
 324 NHSTUB(PTM_GetCurrentItem                     ,0xff895df8) //105
 325 NHSTUB(DisableISDriveError                    ,0xffaa1538) //120
 326 NHSTUB(CancelHPTimer                          ,0xff88903c) //119
 327 NHSTUB(SetHPTimerAfterNow                     ,0xff888f34) //119
 328 NHSTUB(PT_MFOn                                ,0xff878258) //120
 329 NHSTUB(PT_MFOff                               ,0xff878268) //120
 330 NHSTUB(GetAdChValue                           ,0xff85bef0) //120
 331 NHSTUB(get_ptp_buf_size                       ,0xff900c34) //122
 332 NHSTUB(get_ptp_file_buf                       ,0xffa4fa34) //121

/* [<][>][^][v][top][bottom][index][help] */