aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/lscript/lscript_execute/lscript_execute.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:45:11 -0500
committerJacek Antonelli2008-08-15 23:45:11 -0500
commit215f423cbe18fe9ca14a26caef918d303bad28ff (patch)
tree0743442b286216cc8e19aa487c26f4e9345ffd64 /linden/indra/lscript/lscript_execute/lscript_execute.cpp
parentSecond Life viewer sources 1.18.3.5-RC (diff)
downloadmeta-impy-215f423cbe18fe9ca14a26caef918d303bad28ff.zip
meta-impy-215f423cbe18fe9ca14a26caef918d303bad28ff.tar.gz
meta-impy-215f423cbe18fe9ca14a26caef918d303bad28ff.tar.bz2
meta-impy-215f423cbe18fe9ca14a26caef918d303bad28ff.tar.xz
Second Life viewer sources 1.18.4.0-RC
Diffstat (limited to 'linden/indra/lscript/lscript_execute/lscript_execute.cpp')
-rw-r--r--linden/indra/lscript/lscript_execute/lscript_execute.cpp163
1 files changed, 113 insertions, 50 deletions
diff --git a/linden/indra/lscript/lscript_execute/lscript_execute.cpp b/linden/indra/lscript/lscript_execute/lscript_execute.cpp
index 9e8be15..5bbbc47 100644
--- a/linden/indra/lscript/lscript_execute/lscript_execute.cpp
+++ b/linden/indra/lscript/lscript_execute/lscript_execute.cpp
@@ -2,6 +2,8 @@
2 * @file lscript_execute.cpp 2 * @file lscript_execute.cpp
3 * @brief classes to execute bytecode 3 * @brief classes to execute bytecode
4 * 4 *
5 * $LicenseInfo:firstyear=2002&license=viewergpl$
6 *
5 * Copyright (c) 2002-2007, Linden Research, Inc. 7 * Copyright (c) 2002-2007, Linden Research, Inc.
6 * 8 *
7 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
@@ -24,6 +26,7 @@
24 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO 26 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
25 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, 27 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
26 * COMPLETENESS OR PERFORMANCE. 28 * COMPLETENESS OR PERFORMANCE.
29 * $/LicenseInfo$
27 */ 30 */
28 31
29#include "linden_common.h" 32#include "linden_common.h"
@@ -265,6 +268,32 @@ void LLScriptExecute::init()
265 268
266} 269}
267 270
271
272// Utility routine for when there's a boundary error parsing bytecode
273void LLScriptExecute::recordBoundaryError( const LLUUID &id )
274{
275 set_fault(mBuffer, LSRF_BOUND_CHECK_ERROR);
276 llwarns << "Script boundary error for ID " << id << llendl;
277}
278
279
280// set IP to the event handler with some error checking
281void LLScriptExecute::setStateEventOpcoodeStartSafely( S32 state, LSCRIPTStateEventType event, const LLUUID &id )
282{
283 S32 opcode_start = get_state_event_opcoode_start( mBuffer, state, event );
284 if ( opcode_start == -1 )
285 {
286 recordBoundaryError( id );
287 }
288 else
289 {
290 set_ip( mBuffer, opcode_start );
291 }
292}
293
294
295
296
268S32 lscript_push_variable(LLScriptLibData *data, U8 *buffer); 297S32 lscript_push_variable(LLScriptLibData *data, U8 *buffer);
269 298
270U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &state_transition) 299U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &state_transition)
@@ -373,14 +402,20 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &
373 402
374 // now, push any additional stack space 403 // now, push any additional stack space
375 S32 additional_size = get_event_stack_size(mBuffer, current_state, LSTT_STATE_EXIT); 404 S32 additional_size = get_event_stack_size(mBuffer, current_state, LSTT_STATE_EXIT);
376 lscript_pusharge(mBuffer, additional_size); 405 if ( additional_size == -1 )
377 406 {
378 sp = get_register(mBuffer, LREG_SP); 407 recordBoundaryError( id );
379 sp += additional_size; 408 }
380 set_bp(mBuffer, sp); 409 else
381 // set IP to the event handler 410 {
382 S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, LSTT_STATE_EXIT); 411 lscript_pusharge(mBuffer, additional_size);
383 set_ip(mBuffer, opcode_start); 412
413 sp = get_register(mBuffer, LREG_SP);
414 sp += additional_size;
415 set_bp(mBuffer, sp);
416 // set IP to the event handler
417 setStateEventOpcoodeStartSafely( current_state, LSTT_STATE_EXIT, id );
418 }
384 return NO_DELETE_FLAG; 419 return NO_DELETE_FLAG;
385 } 420 }
386 } 421 }
@@ -431,20 +466,27 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &
431 current_events &= ~LSCRIPTStateBitField[event]; 466 current_events &= ~LSCRIPTStateBitField[event];
432 set_event_register(mBuffer, LREG_CE, current_events, major_version); 467 set_event_register(mBuffer, LREG_CE, current_events, major_version);
433// now, push any additional stack space 468// now, push any additional stack space
434 S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; 469 S32 additional_size = get_event_stack_size(mBuffer, current_state, event);
435 lscript_pusharge(mBuffer, additional_size); 470 if ( additional_size == -1 )
471 { // b_done will be set, so we'll exit the loop at the bottom
472 recordBoundaryError( id );
473 }
474 else
475 {
476 additional_size -= size;
477 lscript_pusharge(mBuffer, additional_size);
436 478
437// now set the bp correctly 479// now set the bp correctly
438 sp = get_register(mBuffer, LREG_SP); 480 sp = get_register(mBuffer, LREG_SP);
439 sp += additional_size + size; 481 sp += additional_size + size;
440 set_bp(mBuffer, sp); 482 set_bp(mBuffer, sp);
441// set IP to the function 483// set IP to the function
442 S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); 484 setStateEventOpcoodeStartSafely( current_state, event, id );
443 set_ip(mBuffer, opcode_start); 485 }
444 b_done = TRUE; 486 b_done = TRUE;
445 } 487 }
446 else if ( (current_events & LSCRIPTStateBitField[LSTT_REZ]) 488 else if ( (current_events & LSCRIPTStateBitField[LSTT_REZ])
447 &&(current_events & event_register)) 489 &&(current_events & event_register))
448 { 490 {
449 for (eventdata = mEventData.mEventDataList.getFirstData(); eventdata; eventdata = mEventData.mEventDataList.getNextData()) 491 for (eventdata = mEventData.mEventDataList.getFirstData(); eventdata; eventdata = mEventData.mEventDataList.getNextData())
450 { 492 {
@@ -469,17 +511,24 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &
469 data++; 511 data++;
470 } 512 }
471 // now, push any additional stack space 513 // now, push any additional stack space
472 S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; 514 S32 additional_size = get_event_stack_size(mBuffer, current_state, event);
473 lscript_pusharge(mBuffer, additional_size); 515 if ( additional_size == -1 )
474 516 { // b_done will be set, so we'll exit the loop at the bottom
475 // now set the bp correctly 517 recordBoundaryError( id );
476 sp = get_register(mBuffer, LREG_SP); 518 }
477 sp += additional_size + size; 519 else
478 set_bp(mBuffer, sp); 520 {
479 // set IP to the function 521 additional_size -= size;
480 S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); 522 lscript_pusharge(mBuffer, additional_size);
481 set_ip(mBuffer, opcode_start); 523
482 mEventData.mEventDataList.deleteCurrentData(); 524 // now set the bp correctly
525 sp = get_register(mBuffer, LREG_SP);
526 sp += additional_size + size;
527 set_bp(mBuffer, sp);
528 // set IP to the function
529 setStateEventOpcoodeStartSafely( current_state, event, id );
530 mEventData.mEventDataList.deleteCurrentData();
531 }
483 b_done = TRUE; 532 b_done = TRUE;
484 break; 533 break;
485 } 534 }
@@ -516,16 +565,23 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &
516 } 565 }
517 b_done = TRUE; 566 b_done = TRUE;
518 // now, push any additional stack space 567 // now, push any additional stack space
519 S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; 568 S32 additional_size = get_event_stack_size(mBuffer, current_state, event);
520 lscript_pusharge(mBuffer, additional_size); 569 if ( additional_size == -1 )
521 570 { // b_done was just set, so we'll exit the loop at the bottom
522 // now set the bp correctly 571 recordBoundaryError( id );
523 sp = get_register(mBuffer, LREG_SP); 572 }
524 sp += additional_size + size; 573 else
525 set_bp(mBuffer, sp); 574 {
526 // set IP to the function 575 additional_size -= size;
527 S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); 576 lscript_pusharge(mBuffer, additional_size);
528 set_ip(mBuffer, opcode_start); 577
578 // now set the bp correctly
579 sp = get_register(mBuffer, LREG_SP);
580 sp += additional_size + size;
581 set_bp(mBuffer, sp);
582 // set IP to the function
583 setStateEventOpcoodeStartSafely( current_state, event, id );
584 }
529 } 585 }
530 else 586 else
531 { 587 {
@@ -550,23 +606,30 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &
550 current_events &= ~LSCRIPTStateBitField[event]; 606 current_events &= ~LSCRIPTStateBitField[event];
551 set_event_register(mBuffer, LREG_CE, current_events, major_version); 607 set_event_register(mBuffer, LREG_CE, current_events, major_version);
552 // now, push any additional stack space 608 // now, push any additional stack space
553 S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; 609 S32 additional_size = get_event_stack_size(mBuffer, current_state, event);
554 lscript_pusharge(mBuffer, additional_size); 610 if ( additional_size == -1 )
555 611 { // b_done will be set, so we'll exit the loop at the bottom
556 // now set the bp correctly 612 recordBoundaryError( id );
557 sp = get_register(mBuffer, LREG_SP); 613 }
558 sp += additional_size + size; 614 else
559 set_bp(mBuffer, sp); 615 {
560 // set IP to the function 616 additional_size -= size;
561 S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); 617 lscript_pusharge(mBuffer, additional_size);
562 set_ip(mBuffer, opcode_start); 618
619 // now set the bp correctly
620 sp = get_register(mBuffer, LREG_SP);
621 sp += additional_size + size;
622 set_bp(mBuffer, sp);
623 // set IP to the function
624 setStateEventOpcoodeStartSafely( current_state, event, id );
625 }
563 } 626 }
564 b_done = TRUE; 627 b_done = TRUE;
565 } 628 }
566 } 629 } // while (!b_done)
630 } // end of else ... in state processing code
567 631
568 return NO_DELETE_FLAG; 632 return NO_DELETE_FLAG;
569 }
570} 633}
571 634
572BOOL run_noop(U8 *buffer, S32 &offset, BOOL b_print, const LLUUID &id) 635BOOL run_noop(U8 *buffer, S32 &offset, BOOL b_print, const LLUUID &id)