High Level Assembler for Z/OS & Z/VM & Z/VSE: Language Reference

Total Page:16

File Type:pdf, Size:1020Kb

High Level Assembler for Z/OS & Z/VM & Z/VSE: Language Reference High Level Assembler for z/OS & z/VM & z/VSE Language Reference Version 1 Release 6 SC26-4940-06 Note Before using this information and the product it supports, be sure to read the general information under “Notices” on page 379. This edition applies to IBM High Level Assembler for z/OS & z/VM & z/VSE, Release 6, Program Number 5696-234 and to any subsequent releases until otherwise indicated in new editions. Make sure that you are using the correct edition for the level of the product. Order publications through your IBM representative or the IBM branch office serving your locality. IBM welcomes your comments. For information on how to send comments, see “How to send your comments to IBM” on page xvii. © Copyright IBM Corporation 1992, 2013. US Government Users Restricted Rights – Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp. Contents Figures ..............vii Overview of assembler language structure . 19 Machine instructions ..........20 Tables ...............ix Assembler instructions .........21 Conditional assembly instructions ......22 Macro instructions ...........23 About this document .........xi Mnemonic tags ............23 Who should use this manual.........xi Terms, literals, and expressions ........24 Programming interface information ......xi Terms ...............24 Organization of this manual .........xi Literals ...............35 High Level Assembler documents .......xii Expressions .............38 Documents .............xii Collection kits ............xiii Chapter 3. Program structures and Related publications ...........xiii Syntax notation .............xiii addressing .............43 Object program structures .........43 How to send your comments to IBM xvii Source program structures .........44 Source module ............44 If you have a technical problem .......xvii Sections, elements, and parts .......45 Sections ..............46 Summary of changes ........xix Reference control sections ........48 Classes (z/OS and CMS) .........50 Chapter 1. Introduction ........1 Parts (z/OS and CMS)..........52 Language compatibility ...........1 Location counter setting .........52 Assembler language ............2 Addressing ..............54 Machine instructions...........2 Addressing within source modules: establishing Assembler instructions ..........2 addressability.............54 Macro instructions ...........3 Base register instructions .........56 Assembler program ............3 Qualified addressing ..........56 Basic functions.............3 Dependent addressing ..........57 Associated data ............3 Relative addressing ...........57 Controlling the assembly .........3 Literal pools .............58 Processing sequence ...........4 Establishing residence and addressing mode . 58 Relationship of assembler to operating system . 5 Symbolic linkages ...........58 Coding made easier ............6 External symbol dictionary entries......61 Symbolic representation of program elements . 6 Summary of source and object program Variety in data representation........6 structures ..............62 Controlling address assignment .......6 Relocatability .............6 Chapter 4. Machine instruction Sectioning a program ..........6 statements .............65 Linkage between source modules ......7 General instructions ...........65 Program listings ............7 Decimal instructions ...........65 Multiple source modules .........7 Floating-point instructions .........66 Double-byte character set notation .......7 Control instructions ...........66 Input/output operations ..........66 Chapter 2. Coding and structure ....9 Branching with extended mnemonic codes ....67 Character set ..............9 Alternative mnemonics for some branch relative Standard character set ..........9 instructions .............69 Double-byte character set .........10 Statement formats ............70 Translation table ............11 Symbolic operation codes..........70 Assembler language coding conventions .....11 Operand entries .............71 Field boundaries............12 Registers ..............72 Continuation lines ...........13 Addresses ..............73 Blank lines .............15 Lengths...............75 Comment statement format ........15 Immediate data ............76 Instruction statement format........15 Examples of coded machine instructions.....76 Assembler language structure ........17 RI format ..............76 © Copyright IBM Corp. 1992, 2013 iii RR format ..............78 ORG instruction ............177 RS format ..............78 POP instruction ............180 RSI format..............79 PRINT instruction ............181 RX format ..............80 Process statement ............184 SI format ..............81 PUNCH instruction ...........184 SS format ..............81 PUSH instruction ............185 REPRO instruction ...........186 Chapter 5. Assembler instruction RMODE instruction ...........187 statements .............83 RSECT instruction ............188 SPACE instruction ............189 64 bit addressing mode ..........84 START instruction ............189 *PROCESS statement ...........84 TITLE instruction ............190 ACONTROL instruction ..........85 Deck ID in object records ........191 ADATA instruction ............92 Printing the heading ..........191 AINSERT instruction ...........92 Printing the TITLE statement .......191 ALIAS instruction ............93 Sample program using the TITLE instruction 191 AMODE instruction ...........95 Page ejects .............192 CATTR instruction (z/OS and CMS) ......96 Valid characters ...........192 CCW and CCW0 instructions ........99 USING instruction............193 CCW1 instruction ............100 Base address ............193 CEJECT instruction ...........101 How to use the USING instruction .....193 CNOP instruction ............102 Base registers for absolute addresses.....194 COM instruction ............104 Ordinary USING instruction .......194 COPY instruction ............105 Labeled USING instruction ........197 CSECT instruction............106 Dependent USING instruction .......200 CXD instruction ............108 WXTRN instruction ...........202 DC instruction .............109 XATTR instruction (z/OS and CMS)......203 Rules for DC operands .........111 Association of code and data areas (z/OS and General information about constants.....111 CMS) ...............205 Padding and truncation of values......113 Subfield 1: Duplication Factor .......114 Subfield 2: Type ...........115 Chapter 6. Introduction to macro Subfield 3: Type Extension ........116 language .............207 Subfield 4: Program type ........117 Using macros .............207 Subfield 5: Modifier ..........118 Macro definition ............207 Subfield 6: Nominal Value ........121 Model statements ...........208 DROP instruction ............152 Processing statements .........208 Labeled USING ...........152 Comment statements ..........209 Dependent USING ..........153 Macro instruction ............209 DS instruction .............154 Source and library macro definitions .....210 Bytes skipped for alignment .......155 Macro library ............210 How to use the DS instruction.......155 System macro instructions ........210 DSECT instruction............157 Conditional assembly language .......210 DXD instruction ............159 EJECT instruction ............160 Chapter 7. How to specify macro END instruction ............160 definitions.............213 ENTRY instruction ...........162 Where to define a macro in a source module . 213 EQU instruction ............162 Format of a macro definition ........214 Using conditional assembly values .....165 Macro definition header and trailer ......214 EXITCTL instruction ...........166 MACRO statement ..........214 EXTRN instruction ...........167 MEND statement ...........214 ICTL instruction ............168 Macro instruction prototype ........215 ISEQ instruction ............168 Alternative formats for the prototype statement 216 LOCTR instruction ...........169 Body of a macro definition .........217 LTORG instruction ...........171 Model statements ............217 Literal pool .............172 Variable symbols as points of substitution . 217 Addressing considerations ........172 Listing of generated fields ........218 Duplicate literals ...........173 Rules for concatenation .........218 MNOTE instruction ...........173 Rules for model statement fields ......220 Remarks ..............174 Symbolic parameters ...........222 OPSYN instruction ...........175 Positional parameters..........223 Redefining conditional assembly instructions 177 iv High Level Assembler for z/OS & z/VM & z/VSE: Language Reference Keyword parameters ..........223 &SYSSTMT System Variable Symbol.....254 Combining positional and keyword parameters 223 &SYSSTYP System Variable Symbol .....254 Subscripted symbolic parameters ......223 &SYSTEM_ID System Variable Symbol ....255 Processing statements ..........224 &SYSTERM_DSN System Variable Symbol . 255 Conditional assembly instructions .....224 &SYSTERM_MEMBER System Variable Symbol 256 Inner macro instructions.........224 &SYSTERM_VOLUME System Variable Symbol 256 Other conditional assembly instructions . 224 &SYSTIME System Variable Symbol .....257 AEJECT instruction ..........225 &SYSVER System Variable Symbol .....257 AINSERT instruction ..........225 AREAD instruction ..........225 Chapter 8. How to write macro ASPACE instruction ..........227 instructions ............259 COPY instruction ...........228 Macro instruction format .........259 MEXIT instruction...........228 Alternative formats for a macro instruction
Recommended publications
  • Pdp11-40.Pdf
    processor handbook digital equipment corporation Copyright© 1972, by Digital Equipment Corporation DEC, PDP, UNIBUS are registered trademarks of Digital Equipment Corporation. ii TABLE OF CONTENTS CHAPTER 1 INTRODUCTION 1·1 1.1 GENERAL ............................................. 1·1 1.2 GENERAL CHARACTERISTICS . 1·2 1.2.1 The UNIBUS ..... 1·2 1.2.2 Central Processor 1·3 1.2.3 Memories ........... 1·5 1.2.4 Floating Point ... 1·5 1.2.5 Memory Management .............................. .. 1·5 1.3 PERIPHERALS/OPTIONS ......................................... 1·5 1.3.1 1/0 Devices .......... .................................. 1·6 1.3.2 Storage Devices ...................................... .. 1·6 1.3.3 Bus Options .............................................. 1·6 1.4 SOFTWARE ..... .... ........................................... ............. 1·6 1.4.1 Paper Tape Software .......................................... 1·7 1.4.2 Disk Operating System Software ........................ 1·7 1.4.3 Higher Level Languages ................................... .. 1·7 1.5 NUMBER SYSTEMS ..................................... 1-7 CHAPTER 2 SYSTEM ARCHITECTURE. 2-1 2.1 SYSTEM DEFINITION .............. 2·1 2.2 UNIBUS ......................................... 2-1 2.2.1 Bidirectional Lines ...... 2-1 2.2.2 Master-Slave Relation .. 2-2 2.2.3 Interlocked Communication 2-2 2.3 CENTRAL PROCESSOR .......... 2-2 2.3.1 General Registers ... 2-3 2.3.2 Processor Status Word ....... 2-4 2.3.3 Stack Limit Register 2-5 2.4 EXTENDED INSTRUCTION SET & FLOATING POINT .. 2-5 2.5 CORE MEMORY . .... 2-6 2.6 AUTOMATIC PRIORITY INTERRUPTS .... 2-7 2.6.1 Using the Interrupts . 2-9 2.6.2 Interrupt Procedure 2-9 2.6.3 Interrupt Servicing ............ .. 2-10 2.7 PROCESSOR TRAPS ............ 2-10 2.7.1 Power Failure ..............
    [Show full text]
  • Embedded C Programming I (Ecprogrami)
    To our customers, Old Company Name in Catalogs and Other Documents On April 1st, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding. Renesas Electronics website: http://www.renesas.com April 1st, 2010 Renesas Electronics Corporation Issued by: Renesas Electronics Corporation (http://www.renesas.com) Send any inquiries to http://www.renesas.com/inquiry. Notice 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website. 2. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others. 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples.
    [Show full text]
  • Operating Systems What Is an Operating System Real-Time
    Operating Systems Babak Kia Adjunct Professor Boston University College of Engineering Email: bkia -at- bu.edu ENG SC757 - Advanced Microprocessor Design What is an Operating System z Operating System handles • Memory Addressing & Management • Interrupt & Exception Handling • Process & Task Management • File System • Timing • Process Scheduling & Synchronization z Examples of Operating Systems • RTOS – Real-Time Operating System • Single-user, Single-task: example PalmOS • Single-user, Multi-task: MS Windows and MacOS • Multi-user, Multi-task: UNIX 2 Real-Time Operating Systems z Operating systems come in two flavors, real-time versus non real-time z The difference between the two is characterized by the consequences which result if functional correctness and timing parameters are not met in the case of real-time operating systems z Real-time operating systems themselves have two varieties, soft real-time systems and hard real- time systems z Examples of real-time systems: • Food processing • Engine Controls • Anti-lock breaking systems 3 1 Soft versus Hard Real-Time z In a soft real-time system, tasks are completed as fast as possible without having to be completed within a specified timeframe z In a hard real-time operating system however, not only must tasks be completed within the specified timeframe, but they must also be completed correctly 4 Foreground/Background Systems z The simplest forms of a non real-time operating systems are comprised of super-loops and are called foreground/background systems z Essentially this is an application
    [Show full text]
  • Reentrant Code
    Reentrant Code a reentrant procedure can have several calls open to it at the same time in an interrupt environment, different ISRs may call the same routine in a multitasking or multiuser or multithreaded environment, a single copy of a subroutine may be shared by more than one task/user/thread Reentrant Task subroutine A Task B Reentrant Code Characteristics requirements: 1. any parameters or local variables must be on the stack frame 2. registers may be used for parameters and local variables but must be saved on or restored from the stack at beginning/end of the subroutine 3. guarantee that each call of the subroutine will create a separate stack frame to maintain data integrity 4. no self-modifying code Recursion recursive code must be reentrant recursive reentrant but reentrant recursive e.g. calculating 3! using recursion main move.w number,D0 pass the number jsr fact start recursive rtn move.w D0,result store the factorial stop #$2700 number dc.w 3 result ds.w 1 fact link A6,#-2 Stack structure move.w D0,-2(A6) subq.w #1,D0 bne push move.w -2(A6),D0 bra return push jsr fact mulu -2(A6),D0 return unlk A6 rts end main SP ->/////// A much more complex example: X: array [0..30] of words Y: longword Z, ALPHA, N: byte call order is S/R demo(X, Y, Z, ALPHA, N ) N is passed/returned by value, all others are passed by reference demo(X[w:31], Y[l], Z[b], ALPHA[b], N[b]) main CLR.W D2 zero entire word MOVE.B N,D2 N to low byte MOVE.W D2,-(SP) N on stack PEA ALPHA push arguments PEA Z in reverse order PEA Y PEA X JSR demo call
    [Show full text]
  • Java Concurrency in Practice
    Java Concurrency in practice Chapters: 1,2, 3 & 4 Bjørn Christian Sebak ([email protected]) Karianne Berg ([email protected]) INF329 – Spring 2007 Chapter 1 - Introduction Brief history of concurrency Before OS, a computer executed a single program from start to finnish But running a single program at a time is an inefficient use of computer hardware Therefore all modern OS run multiple programs (in seperate processes) Brief history of concurrency (2) Factors for running multiple processes: Resource utilization: While one program waits for I/O, why not let another program run and avoid wasting CPU cycles? Fairness: Multiple users/programs might have equal claim of the computers resources. Avoid having single large programs „hog“ the machine. Convenience: Often desirable to create smaller programs that perform a single task (and coordinate them), than to have one large program that do ALL the tasks What is a thread? A „lightweight process“ - each process can have many threads Threads allow multiple streams of program flow to coexits in a single process. While a thread share process-wide resources like memory and files with other threads, they all have their own program counter, stack and local variables Benefits of threads 1) Exploiting multiple processors 2) Simplicity of modeling 3) Simplified handling of asynchronous events 4) More responsive user interfaces Benefits of threads (2) Exploiting multiple processors The processor industry is currently focusing on increasing number of cores on a single CPU rather than increasing clock speed. Well-designed programs with multiple threads can execute simultaneously on multiple processors, increasing resource utilization.
    [Show full text]
  • AN10381 Nesting of Interrupts in the LPC2000 Rev
    AN10381 Nesting of interrupts in the LPC2000 Rev. 01 — 6 June 2005 Application note Document information Info Content Keywords nested, reentrant, interrupts, LPC2000 Abstract Details on reentrant interrupt handlers and code examples for the same is provided Philips Semiconductors AN10381 Nesting of interrupts in the LPC2000 Revision history Rev Date Description 01 20050606 Initial version Contact information For additional information, please visit: http://www.semiconductors.philips.com For sales office addresses, please send an email to: [email protected] © Koninklijke Philips Electronics N.V. 2005. All rights reserved. Application note Rev. 01 — 6 June 2005 2 of 14 Philips Semiconductors AN10381 Nesting of interrupts in the LPC2000 1. Introduction This application note provides code examples for effectively handling reentrant interrupt handlers in the LPC2000 devices. The following organization is been adopted for this application note. 1. Interrupt handling overview 2. Nesting of Interrupts 3. Code examples It is assumed for this application note, that the user is familiar with the ARM7TDMI-S architecture. Also, for code examples relating to simple interrupt handling using FIQ and IRQ, please refer to the AN10254_1 application note available online. All the code examples provided in this application note were built on the Keil MicroVision3 ARM compiler (an evaluation version of which is free for download at www.keil.com) 2. Interrupt handling overview 2.1 Interrupt levels in the ARM7 core The ARM7 processor supports two levels of interrupts: Interrupt Request (IRQ) and Fast Interrupt Request (FIQ). ARM recommends only one interrupt source to be classified as an FIQ. All other interrupt sources could be classified as IRQ’s and they could be programmed for reentrancy.
    [Show full text]
  • Threads, IPC, and Synchronization CS 111 Operating Systems Peter Reiher
    Operating System Principles: Threads, IPC, and Synchronization CS 111 Operating Systems Peter Reiher CS 111 Lecture 7 Fall 2016 Page 1 Outline • Threads • Interprocess communications • Synchronization – Critical sections – Asynchronous event completions CS 111 Lecture 7 Fall 2016 Page 2 Threads • Why not just processes? • What is a thread? • How does the operating system deal with threads? CS 111 Lecture 7 Fall 2016 Page 3 Why Not Just Processes? • Processes are very expensive – To create: they own resources – To dispatch: they have address spaces • Different processes are very distinct – They cannot share the same address space – They cannot (usually) share resources • Not all programs require strong separation – Multiple activities working cooperatively for a single goal CS 111 – Mutually trusting elements of a system Lecture 7 Fall 2016 Page 4 What Is a Thread? • Strictly a unit of execution/scheduling – Each thread has its own stack, PC, registers – But other resources are shared with other threads • Multiple threads can run in a process – They all share the same code and data space – They all have access to the same resources – This makes the cheaper to create and run • Sharing the CPU between multiple threads – User level threads (with voluntary yielding) CS 111 – Scheduled system threads (with preemption) Lecture 7 Fall 2016 Page 5 When Should You Use Processes? • To run multiple distinct programs • When creation/destruction are rare events • When running agents with distinct privileges • When there are limited interactions and shared resources • To prevent interference between executing interpreters • To firewall one from failures of the other CS 111 Lecture 7 Fall 2016 Page 6 When Should You Use Threads? • For parallel activities in a single program • When there is frequent creation and destruction • When all can run with same privileges • When they need to share resources • When they exchange many messages/signals • When you don’t need to protect them from each other CS 111 Lecture 7 Fall 2016 Page 7 Processes vs.
    [Show full text]
  • CS 33 Week 8 Section 1G, Spring 2015 Prof
    CS 33 Week 8 Section 1G, Spring 2015 Prof. Eggert (TA: Eric Kim) v1.0 Announcements ● Midterm 2 scores out now ○ Check grades on my.ucla.edu ○ Mean: 60.7, Std: 15 Median: 61 ● HW 5 due date updated ○ Due: May 26th (Tuesday) ● Lab 4 released soon ○ OpenMP Lab ○ Tutorial on OpenMP ■ http://openmp.org/mp-documents/omp-hands-on-SC08.pdf Overview ● More concurrency ● File I/O ● MT 2 Example: sum int result = 0; void sum_n(int n) { Suppose Louis if (n == 0) { Reasoner tries to result = n; make this code } else { thread safe... sum_n(n-1); result = result + n; } } Example: fib Question: Is there anything wrong with this code? int result = 0; sem_t s; // sem_init(&s,1); void sum_n(int n) { if (n == 0) { P(&s); result = n; V(&s); } else { P(&s); Answer: Yes, deadlock! sum_n(5) calls sum_n(n-1); sum_n(4), but sum_n(4) can't acquire result = result + n; mutex. sum_n(5) can't make progress V(&s); without sum_n(4) - thread is stuck. } } Thread-safe functions Definition: A function is thread-safe if functions correctly during simultaneous execution by multiple threads. [http: //stackoverflow.com/questions/261683/what-is-meant-by-thread-safe-code] Alt: In computer programming, thread-safe describes a program portion or routine that can be called from multiple programming threads without unwanted interaction between the threads. [http://whatis.techtarget.com/definition/thread-safe] Thread-safe functions Typically achieve thread-safety by mechanisms: - Synchronization (ie semaphores/mutexes) - Careful handling of shared data "To write code that will run stably for weeks takes extreme paranoia." (Not actually said by Nixon) Reentrant Functions A "stronger" version of thread-safe (in a sense).
    [Show full text]
  • "Effectively Callback Freeness" for Smart Contracts
    Analysis of “Effectively Callback Freeness” for Smart Contracts Trabajo de Fin de Máster Curso 2019–2020 Autor Clara Rodríguez Núñez Directores Elvira Albert Albiol Albert Rubio Gimeno Máster en Métodos Formales en Ingeniería Informática Facultad de Informática Universidad Complutense de Madrid Convocatoria: Julio 2020 Calificación: 10 Analysis of “Effectively Callback Freeness” for Smart Contracts Trabajo de Fin de Máster en Métodos Formales en Ingeniería Informática Autor Clara Rodríguez Núñez Directores Elvira Albert Albiol Albert Rubio Gimeno Máster en Métodos Formales en Ingeniería Informática Facultad de Informática Universidad Complutense de Madrid Dedicatoria A mi abuela, por enseñarme tanto en cada llamada v Agradecimientos En primer lugar, a Elvira y Albert. Gracias por todo lo que he aprendido y disfru- tado estos meses, por el apoyo cuando las cosas no iban bien y por soportarme en cientos de videollamadas, incluso cuando me pasa un tren por encima. Formar parte de un proyecto como este ha sido un autentico privilegio. Gracias también a todos los miembros del grupo COSTA por recibirme tan bien y estar siempre dispuestos a echarme una mano. Gracias a todas las personas que me han hecho disfrutar de las matemáticas y la informática. A los profesores que he tenido durante estos años, gracias por vuestro esfuerzo y pasión por enseñar, habéis sacado una versión de mí que nunca pensé que existiera. A los amigos que he hecho en esta universidad, gracias por ser los mejores compañeros de viaje. Aun nos quedan muchas locuras por hacer, montañas que escalar y partidos donde no tirar. Gracias a mi familia. Cuando era una niña y soñaba con ser investigadora me acompañabais cada fin de semana a buscar fósiles a la montaña de detrás de casa.
    [Show full text]
  • Embedded (Real Time) Operating Systems
    Real Time Operating Systems q What is the basic thing we want the OS to do to help us improve worst case latency? Enable multithreading q How? Define an OS time-slice (tick) at which highest priority ‘runnable’ task is continued. Priority function determines response behavior. q Simplest Scheduling algorithm: each task gets at most 1 tick at a time to run. Round Robin Scheduling. Worst case task latency = #tasks*tick. Worst case run time = ticks/task * #tasks q Some properties of such system: liveness, safety, fairness, latency, overhead. q Other niceties: Device Drivers, Synchronization, Message passing, Memory Management CSE466 Autumn ‘00- 1 Features of an Embedded Operating System q Interrupt latency q System call overhead (Various functions…task switch, signal, create, delete) q Memory overhead q Tasks (threads) q Scheduling Algorithms q Communication and synchronization primitives (tools) q Memory Management CSE466 Autumn ‘00- 2 Comparative Real Time OSes Compare to uClinux at ~400Kbytes. what for? What is this? 38us – 280us why the variable? actually 16 semaphores CSE466 Autumn ‘00- 3 Stack Management CSE466 Autumn ‘00- 4 Multitasking – state maintained for each task time slice only Running Runnable one task time slice in this state at a time wait() delete() signal() create() delete() Blocked Deleted system calls CSE466 Autumn ‘00- 5 Programmers View of Tiny OS void tone_isr(void) interrupt … { Advantages: process_tones(); if (!--sliceCount) { •Deterministic response time updateToneParameters(); sliceCount = SliceSize even w/ non deterministic isr_send_signal(MUSIC); } tasks lengths. } void serial_isr(void) interrupt …{ • Incremental development timeCritical(); os_send_signal(SERIAL); } void play(void) _task_ MUSIC { Resources: os_create(SERIAL); while (1) {os_wait(); •Task switching overhead process_next_event();} } •Memory overhead void serial(void) _task_ SERIAL { while (1) {os_wait(); •Use of system timer process_serial_data();} // os_create(MUSIC)? } •Degrades best case response time.
    [Show full text]
  • Exploiting the Laws of Order in Smart Contracts
    Exploiting The Laws of Order in Smart Contracts Aashish Kolluri ∗, Ivica Nikolic´ ∗, Ilya Sergey y, Aquinas Hobor ∗ z, Prateek Saxena ∗ ∗School Of Computing, NUS, Singapore zYale-NUS College, Singapore yUniversity College London, United Kingdom Abstract—We investigate a family of bugs in blockchain-based smart contracts have been deployed to Ethereum’s blockchain. smart contracts, which we call event-ordering (or EO) bugs. These Numerous publicly reported attacks have resulted in hundreds bugs are intimately related to the dynamic ordering of contract of millions dollars’ worth of Ether being stolen or otherwise events, i.e., calls of its functions on the blockchain, and enable potential exploits of millions of USD worth of Ether. Known lost [10], [22]. Further, contracts cannot be patched once examples of such bugs and prior techniques to detect them have deployed. This emphasizes the importance of pre-deployment been restricted to a small number of event orderings, typicall 1 security audit and analysis of smart contracts. or 2. Our work provides a new formulation of this general class This paper investigates a class of vulnerabilities in smart of EO bugs as finding concurrency properties arising in long contracts that arise due to their inherent concurrent execution permutations of such events. The technical challenge in detecting our formulation of EO model. Contracts can be invoked by multiple users concur- bugs is the inherent combinatorial blowup in path and state space rently, and the ordering of multiple submitted transactions is analysis, even for simple contracts. We propose the first use of non-deterministically decided by miners through a consensus partial-order reduction techniques, using happen-before relations protocol.
    [Show full text]
  • West Coast Computer Faire Programs
    FIFTH PROGRAM 1980 March 14, 15, 16, Friday Saturday Sunday 9am-6pm 9am-6pm Noon-5pm (415)851-7075 COMPUTER FAIRE 333 Swett Road, Woodside CA 94062 CALL FOR PAPERS, TALKS, DEMONSTRATIONS, & EXHIBITS for the SIXTH WEST COAST COMPUTER FAIRE San Francisco's Gvic Auditorium & Brooks Hall April 3 - 5, 1981 Everyone interested in participating in the 6th West Coast Computer Faire should contact Computer Faire 333 Swett Road, Woodside CA 94062; (415) 851-7075. Those wishing to propose a talk or demonstration, or wishing to organize a Conference Section, should immediately request Speaker's Kits. DEADLINE for completion of Conference Program organization, talks, & papers: Dec. 1st, 1980. CONFERENCE PROGRAM of the 5TH WEST COAST COMPUTER FAIRE L.„. FRIDAY, MARCH 1 4T I SATURDAY, MARCH 15 T H SUNDAY, MARCH 1 6T H 9 am POLK 1 POLK 2 LARKIN 1 LARKIN 2 POLK 1 POLK 2 LARKIN 1 LARKIN 2 9am - 6pm: RTTY Repeater Group, 9 am - 6 pm: RTTY Repeater Group, (open seminar); ROOM 302 9am - 6pm: RTTY Repeater Group, (open seminar) 9 am - 6 pm: Apple Core Meetings; ROOMS 406 - 410 (open seminar) ROOM 302 1 pm - 4 pm: Personal Computer/Telecommunications, ROOM 302 (open seminar); ROOM 204 10 am Teaching Personal Computer Pascal, & Digital Group About Communications Music Pascal Machines Users Computers & & (open meeting) Programming Microcomputers 11 am Noon Computer Business & • Retailers Low-Cost (open meeting) Computing Osborne's 3rd 1 pm Annual Award How to Hold a Low-Cost Tutorials for Potpourri Significant Medical Seminar for Computing for the Novice Software
    [Show full text]