Download presentation
Presentation is loading. Please wait.
Published bySharon Washington Modified over 9 years ago
1
Software Based Memory Protection For Sensor Nodes Ram Kumar, Eddie Kohler, Mani Srivastava (ram@ee.ucla.edu) CENS Technical Seminar Series
2
10/20/06 CENS Seminar 2 Memory Corruption Run-time Stack Sensor Node Address Space Globals and Heap (Apps., drivers, OS) No Protection 0x0000 0x0200 Single address space CPU Shared by apps., drivers and OS Most bugs in deployed systems come from memory corruption Corrupted nodes trigger network- wide failures Memory protection is an enabling technology for building robust software for motes
3
10/20/06 CENS Seminar 3 Why is Memory Protection hard ? No MMU in embedded micro-controllers MMU hardware requires lot of RAM Increases area and power consumption CoreMMUCach e Area (mm 2 ) 0.13u Tech. mW per MHz ARM7- TDMI No 0.250.1 ARM720TYes8 Kb2.40 (~10x)0.2 (~2x)
4
10/20/06 CENS Seminar 4 Software-based Approaches Software-based Fault Isolation (Sandbox) Coarse grained protection Check all memory accesses at run-time Introduce low-overhead inline checks Application Specific Virtual Machine (ASVM) Interpreted code is safe and efficient ASVM instructions are not type-safe
5
10/20/06 CENS Seminar 5 Software-based Approaches Type safe languages Language semantics prevent illegal memory accesses Fine grained memory protection Challenge is to interface with non type-safe software Ignores large existing code-base Output of type-safe compiler is harder to verify Especially with performance optimizations Ccured - Type-safe retrofitting of C code Combines static analysis and run-time checks Provides fine-grained memory safety Difficult to interface to pre-compiled libraries Different representation of pointer types
6
10/20/06 CENS Seminar 6 Overview Ideal: Combination of software based approaches For e.g.: Sandbox for ASVM instructions Software-based Fault Isolation (SFI) Building block for providing coarse-grained protection Enhanced using other approaches (e.g. static analysis) Memory Map Manager Ensure integrity of memory accesses Control Flow Manager Ensure integrity of control flow
7
10/20/06 CENS Seminar 7 SOS Operating System Tree Routing Module Tree Routing Module Data Collector Application Data Collector Application Photosensor Module Photosensor Module Dynamically Loaded modules Dynamic Memory Dynamic Memory Message Scheduler Message Scheduler Dynamic Linker Dynamic Linker Kernel Components Sensor Manager Sensor Manager Messaging I/O Messaging I/O System Timer System Timer SOS Services Radio I2C ADC Device Drivers Static SOS Kernel
8
10/20/06 CENS Seminar 8 Design Goals Provide coarse-grained memory protection Protect OS from applications Protect applications from one another Targeted for resource constrained systems Low RAM usage Acceptable performance overhead Memory safety verifiable on the node
9
10/20/06 CENS Seminar 9 Outline Introduction System Components Memory Map Control Flow Manager Binary Re-Writer Binary Verifier Evaluation
10
10/20/06 CENS Seminar 10 System Overview Binary Re-Writer Binary Re-Writer Sandbox Binary Raw Binary Memory Map Memory Map Control Flow Mgr. Control Flow Mgr. Memory Safe Binary Binary Verifier Binary Verifier Desktop Sensor Node
11
10/20/06 CENS Seminar 11 System Components Re-writer Introduce run-time checks Verifier Scans for unsafe operations before admission Memory Map Manager Tracks fine-grained memory layout and ownership info. Control Flow Manager Handles context switch within single address space
12
10/20/06 CENS Seminar 12 Classical SFI (Sandboxing) Partition address space of a process into contiguous domains Applications extensions loaded onto separate domains Run-time checks force memory accesses to own domain Checks have very low overhead Run-time Stack Kernel Module #1Operating SystemKernel Module #2
13
10/20/06 CENS Seminar 13 Challenges - SFI on a mote Partitioning address space is impractical Total available memory is severely limited Static partitioning further reduces memory Our approach Permit arbitrary memory layout But maintain a fine-grained map of layout Verify valid accesses through run-time checks
14
10/20/06 CENS Seminar 14 Memory Map 0x0200 0x0000 Fine-grained layout and ownership information Encoded information per block Ownership - Kernel/Free or User Layout - Start of segment bit User Domain Kernel Domain Partition address space into blocks Allocate memory in segments (Set of contiguous blocks)
15
10/20/06 CENS Seminar 15 Memmap in Action: User-Kernel Protection Blocks Size on Mica2 - 8 bytes Efficiently encoded using 2 bits per block 00 - Free / Start of Kernel Allocated Segment 01 - Later portion of Kernel Allocated Segment 10 - Start of User Allocated Segment 11 - Later Portion of User Allocated Segment User Kernel pA = malloc(KERN, 16); pB = malloc(USER, 30); mem_chown(pA, USER); Free
16
10/20/06 CENS Seminar 16 Memmap API Updates Memory Map Blk_ID: ID of starting block in a segment Num_blk: Number of blocks in a segment Dom_ID: Domain ID of owner (e.g. USER / KERN) memmap_set(Blk_ID, Num_blk, Dom_ID) Dom_ID = memmap_get(Blk_ID) Returns domain ID of owner for a memory block API accessible only from trusted domain (e.g. Kernel) Property verified before loading
17
10/20/06 CENS Seminar 17 Using memory map for protection Protection Model Write access to a block is granted only to its owner Systems using memory map need to ensure: 1.Ownership information in memory map is current 2.Only block owner can free/transfer ownership 3.Single trusted domain has access to memory map API 4.Store memory map in protected memory Easy to incorporate into existing systems Modify dynamic memory allocator - malloc, free Track function calls that pass memory from one domain to other Changes to SOS Kernel ~ 1% 103 lines in SOS memory manager 12720 lines in kernel
18
10/20/06 CENS Seminar 18 Memmap Checker Enforce a protection model Checker invoked before EVERY write access Protection Model Write access to block granted only to owner Checker Operations Lookup memory map based on write address Verify current executing domain is block owner
19
10/20/06 CENS Seminar 19 Address Memory Map Lookup Address (bits 15-0) Memmap Table 1 Byte has 4 memmap records 7 2 Block Number (bits 11-3) Block Offset (bits 2-0) 9 bits
20
10/20/06 CENS Seminar 20 Optimizing Memmap Checker Minimize performance overhead of checks Address Memory Map Lookup Requires multiple complex bit-shift operations Micro-controllers support single bit-shift operations Use FLASH based look-up table 4x Speed up - From 32 to 8 clock cycles Overall overhead of a check - 66 cycles
21
10/20/06 CENS Seminar 21 Memory Map is Tunable Number of memmap bits per block More Bits Multiple protection domains Address range of protected memory Protect only a small portion of total memory Block size Match block size to size of memory objects Mica2 - 8 bytes, Cyclops - 128 bytes Addr. Range Bits / Block 0B - 4096B256B - 3072B 2128 B (~3%)88 B (~2%) 4256 B (~6%)176 B (~4%) Memory Map Overhead - 8 Byte Blocks
22
10/20/06 CENS Seminar 22 Outline Introduction System Components Memory Map Control Flow Manager Binary Re-Writer Binary Verifier Evaluation
23
10/20/06 CENS Seminar 23 What about Control Flow ? State within domain can become corrupt Memory map protects one domain from other Function pointers in data memory Calls to arbitrary locations in code memory Return Address on Stack Single stack for entire system Returns to arbitrary locations in code memory
24
10/20/06 CENS Seminar 24 Control Flow Manager Program Memory DOMAIN A call foo DOMAIN B foo: … call local_fn ret Ensure control flow integrity Control flow enters domain at designated entry point Control flow leaves domain to correct return address Track current active domain Required for memmap checker Require Binary Modularity Program memory is partitioned Only one domain per partition
25
10/20/06 CENS Seminar 25 Ensuring control flow integrity Check all CALL and RETURN instructions CALL Check If address within bounds of current domain then CALL Else transfer to Cross Domain Call Handler RETURN Check If address on stack within bounds of current domain then RETURN Else transfer to Cross Domain Return Handler Checks are optimized for performance
26
10/20/06 CENS Seminar 26 Cross Domain Control Flow Function call from one domain to other Determine callee domain identity Verify valid entry point in callee domain Save current return address
27
10/20/06 CENS Seminar 27 Program Memory Domain A call fooJT Domain B foo: … ret Jump Table Register exported function fooJT:jmp foo Cross Domain Call Cross Domain Call Stub Verify call into jump table Get callee domain ID from call address Store return address Verify call into jump table Get callee domain ID from call address Store return address
28
10/20/06 CENS Seminar 28 Cross Domain Return Program Memory call foo foo: … ret Verify return address Restore caller domain ID Restore prev. return addr Return Verify return address Restore caller domain ID Restore prev. return addr Return Cross Domain Return Stub
29
10/20/06 CENS Seminar 29 Stack Protection Data Memory Stack Grows Down Stack Bounds Stack bound set at cross domain calls and returns Protection Model No writes beyond latest stack bound Limits corruption to current stack frame Enforced by memmap_checker Check all write address Single stack shared by all domains User Kernel
30
10/20/06 CENS Seminar 30 Outline Introduction System Components Memory Map Control Flow Manager Binary Re-Writer Binary Verifier Evaluation
31
10/20/06 CENS Seminar 31 Binary Re-Writer Re-writer is a C program running on PC Input is raw binary output by cross-compiler Performs basic block analysis Insert inline checks e.g. Memory Accesses Preserve original control flow e.g. Branch targets Binary Re-Writer Binary Re-Writer Sandbox Binary Raw Binary PC
32
10/20/06 CENS Seminar 32 Memory Write Checks st Z, Rsrc push X push R0 movw X, Z mov R0, Rsrc call memmap_checker pop R0 pop X push X push R0 movw X, Z mov R0, Rsrc call memmap_checker pop R0 pop X Actual sequence depends upon addressing mode Sequence is re-entrant, works in presence of interrupts Can be improved by using dedicated registers
33
10/20/06 CENS Seminar 33 Control Flow Checks ret jmp ret_checker call foo ldi Z, foo call call_checker ldi Z, foo call call_checker Return Instruction Direct Call Instruction icall call call_checker In-Direct Call Instruction
34
10/20/06 CENS Seminar 34 Outline Introduction System Components Memory Map Control Flow Manager Binary Re-Writer Binary Verifier Evaluation
35
10/20/06 CENS Seminar 35 Binary Verifier Verification done at every node Correctness of scheme depends upon correctness of verifier Verifier is very simple to implement Single in-order pass over instr. sequence No state maintained by verifier Verifier Line Count: 205 lines Re-Writer Line Count: 3037 lines
36
10/20/06 CENS Seminar 36 Verified Properties All store instructions to data memory are sandboxed Store instructions to program memory are not permitted Static jump/call/branch targets lie within domain bounds Indirect jumps and calls are sandboxed All return instructions are sandboxed
37
10/20/06 CENS Seminar 37 Outline Introduction System Components Memory Map Cross Domain Calls Binary Re-Writer Binary Verifier Evaluation
38
10/20/06 CENS Seminar 38 Resource Utilization TypeNormalProtecte d Overhea d Prog. Mem 41690 B47232 B13% Data Mem2892 B3040 B5% Implemented scheme in SOS operating system Compiling blank SOS kernel for Mica2 sensor platform Size of Memory Map - 128 Bytes Additional memory used for storing parameters Stack Bound, Return Address etc.
39
10/20/06 CENS Seminar 39 Memory Map Overhead API modification overhead (CPU cycles) APINormalProtecte d Increas e ker_malloc 36362282% ker_free 138446238% change_own 55270418% Overhead of setting and clearing memory map bits
40
10/20/06 CENS Seminar 40 Control Flow Checks and Transfers OPERATIONCYCLES cross_domain_call 38 (9x) cross_domain_ret 38 (9x) ker_ret_check 14 ker_icall_check 8 Inline checks occur most frequently ker_ret_check: Push and Pop of return address Module verification ~ 175 ms for 2600 byte module
41
10/20/06 CENS Seminar 41 Impact on Module Size Code size increase due to inline checks Can be reduced if performance is not critical True for most sensor network apps Increased cost for module distribution No change in data memory used NameNorma l ProtectInc.# Instr. Blink246 B342 B39%10 Surge688 B1170 B70%41 Tree Routing2616 B4584 B75%136 Time Sync1070 B1992 B86%53
42
10/20/06 CENS Seminar 42 Performance Impact Experiment Setup 3-hop linear network simulated in Avrora Simulation executed for 30 minutes Tree Routing and Surge modules inserted into network Data pkts. transmitted every 4 seconds Control packets transmitted every 20 seconds 1.7% increase in relative CPU utilization Absolute increase in CPU - 8.41% to 8.56% 164 run-time checks introduced Checks executed ~20000 times Can be reduced by introducing fewer checks
43
10/20/06 CENS Seminar 43 Deployment Experience Run-time checker signaled violation in Surge Offending source code in Surge: hdr_size = SOS_CALL(s->get_hdr_size, proto); s->smsg = (SurgeMsg*)(pkt + hdr_size); s->smsg->type = SURGE_TYPE_SENSORREADING; SOS_CALL fails in some conditions, returns - 1 Unchecked return value used as buffer offset Protection mechanism prevents such corruption
44
10/20/06 CENS Seminar 44 Conclusion Software-based Memory Protection Enabling technology for reliable software systems Memory Map and Cross Domain Calls Building blocks for software based fault isolation Low resource utilization Minimal performance overhead Widely applicable SOS kernel with dynamic modules TinyOS components using dynamic memory Natively implemented ASVM instructions
45
10/20/06 CENS Seminar 45 Future Work Explore CPU architecture extensions Prototype AVR implementation in progress Static analysis of binary Reduce number of inline checks Improve overall system performance Increase complexity of verifier
46
Thank You ! http://nesl.ee.ucla.edu/projects/sos- 1.x Ram Kumar CENS Seminar October 20, 2006
47
10/20/06 CENS Seminar 47 SOS Memory Layout Static Kernel State Accessed only by kernel Heap Dynamically allocated Shared by kernel and applications Stack Shared by kernel and applications Run-time Stack Static Kernel State Dynamically Allocated Heap 0x0200 0x0000
48
10/20/06 CENS Seminar 48 Reliable Sensor Networks Reliability is a broad and challenging goal Data Integrity How do we trust data from our sensors ? Network Integrity How to make network resilient to failures ? System Integrity How to develop robust software for sensors ?
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.