Memory Allocation II CSE 351 Autumn 2017

Slides:



Advertisements
Similar presentations
Dynamic Memory Allocation II
Advertisements

1. Dynamic Memory Allocation. Dynamic Memory Allocation Programmers use dynamic memory allocators (such as malloc ) to acquire VM at run time.  For data.
1 Binghamton University Dynamic Memory Allocation: Advanced Concepts CS220: Computer Systems II.
Dynamic Memory Allocation I October 16, 2008 Topics Simple explicit allocators Data structures Mechanisms Policies lecture-15.ppt “The course that.
1 Dynamic Memory Allocation: Basic Concepts Andrew Case Slides adapted from Jinyang Li, Randy Bryant and Dave O’Hallaro.
1 Optimizing Malloc and Free Professor Jennifer Rexford COS 217 Reading: Section 8.7 in K&R book
Malloc Recitation Section K (Kevin Su) November 5 th, 2012.
Carnegie Mellon Introduction to Computer Systems /18-243, spring th Lecture, Mar. 31 st Instructors: Gregory Kesden and Markus Püschel.
Lab 3: Malloc Lab. “What do we need to do?”  Due 11/26  One more assignment after this one  Partnering  Non-Honors students may work with one other.
Memory Management Memory Areas and their use Memory Manager Tasks:
Dynamic Memory Allocation I Nov 5, 2002 Topics Simple explicit allocators Data structures Mechanisms Policies class21.ppt “The course that gives.
1 Optimizing Malloc and Free Professor Jennifer Rexford
Dynamic Memory Allocation I November 1, 2006 Topics Simple explicit allocators Data structures Mechanisms Policies class18.ppt “The course that.
Explicit Free Lists Use data space for link pointers –Typically doubly linked –Still need boundary tags for coalescing –It is important to realize that.
1 Dynamic Memory Allocation: Basic Concepts. 2 Today Basic concepts Implicit free lists.
Writing You Own malloc() March 29, 2003 Topics Explicit Allocation Data structures Mechanisms Policies class19.ppt “The course that gives CMU its.
Carnegie Mellon /18-243: Introduction to Computer Systems Instructors: Bill Nace and Gregory Kesden (c) All Rights Reserved. All work.
Dynamic Memory Allocation II Topics Explicit doubly-linked free lists Segregated free lists Garbage collection.
Consider Starting with 160 k of memory do: Starting with 160 k of memory do: Allocate p1 (50 k) Allocate p1 (50 k) Allocate p2 (30 k) Allocate p2 (30 k)
Dynamic Memory Allocation II
Carnegie Mellon 1 Bryant and O’Hallaron, Computer Systems: A Programmer’s Perspective, Third Edition Dynamic Memory Allocation: Basic Concepts :
Dynamic Memory Allocation April 9, 2002 Topics Simple explicit allocators Data structures Mechanisms Policies Reading: 10.9 Problems: and class21.ppt.
University of Washington Today More memory allocation!
Malloc Lab : Introduction to Computer Systems Recitation 11: Nov. 4, 2013 Marjorie Carlson Recitation A.
Carnegie Mellon 1 Dynamic Memory Allocation: Basic Concepts Instructors: Adapted from CMU course
CS 241 Discussion Section (12/1/2011). Tradeoffs When do you: – Expand Increase total memory usage – Split Make smaller chunks (avoid internal fragmentation)
CSE 351 Dynamic Memory Allocation 1. Dynamic Memory Dynamic memory is memory that is “requested” at run- time Solves two fundamental dilemmas: How can.
University of Washington Implementation Issues How do we know how much memory to free given just a pointer? How do we keep track of the free blocks? How.
Carnegie Mellon 1 Malloc Recitation Ben Spinelli Recitation 11: November 9, 2015.
Memory Management What if pgm mem > main mem ?. Memory Management What if pgm mem > main mem ? Overlays – program controlled.
Chapter 17 Free-Space Management
Instructor: Phil Gibbons
Dynamic Memory Allocation II
Section 10: Memory Allocation Topics
Memory Management Memory Areas and their use Memory Manager Tasks:
CS 3214 Introduction to Computer Systems
Dynamic Memory Allocation I
Dynamic Memory Allocation
Memory, Data, & Addressing II CSE 351 Autumn 2017
Instructor: Haryadi Gunawi
Memory Management I: Dynamic Storage Allocation Oct 7, 1999
Memory Management Memory Areas and their use Memory Manager Tasks:
Caches III CSE 351 Autumn 2017 Instructor: Justin Hsia
Dynamic Memory Allocation I October 28, 2003
Dynamic Memory Allocation: Basic Concepts CS220: Computer Systems II
Memory Allocation I CSE 351 Spring 2017
CMSC 341 Lecture 10 B-Trees Based on slides from Dr. Katherine Gibson.
Optimizing Malloc and Free
Memory Management I: Dynamic Storage Allocation March 2, 2000
CS Introduction to Operating Systems
Memory Allocation I CSE 351 Spring 2017
User-Level Dynamic Memory Allocation: Malloc and Free
B- Trees D. Frey with apologies to Tom Anastasio
Dynamic Memory Allocation I
CS703 - Advanced Operating Systems
Dynamic Memory Allocation
Dynamic Memory Allocation I
Dynamic Memory Allocation: Basic Concepts /18-213/14-513/15-513: Introduction to Computer Systems 19th Lecture, October 30, 2018.
Optimizing Dynamic Memory Management
Memory Allocation II CSE 351 Winter 2018
Dynamic Memory Allocation November 2, 2000
Memory Allocation II CSE 351 Winter 2018
Dynamic Memory Allocation: Basic Concepts CSCI 380: Operating Systems
Malloc Lab CSCI 380: Operating Systems
Dynamic Memory Allocation I
Memory Management Memory Areas and their use Memory Manager Tasks:
Instructors: Majd Sakr and Khaled Harras
CS703 - Advanced Operating Systems
Memory Allocation I CSE 351 Autumn 2018
Presentation transcript:

Memory Allocation II CSE 351 Autumn 2017 Instructor: Justin Hsia Teaching Assistants: Lucas Wotton Michael Zhang Parker DeWilde Ryan Wong Sam Gehman Sam Wolfson Savanna Yee Vinny Palaniappan http://xkcd.com/1909/

Administrivia Homework 5 due Friday (12/1) Lab 5 due next Friday (12/8) Final Exam: Wed, Dec. 13 @ 12:30pm in KNE 120 Same seating chart as Midterm Review Session: Mon, Dec. 11 @ 5:00pm in EEB 105 Cumulative (midterm clobber policy applies) You get TWO double-sided handwritten 8.5×11” cheat sheets Recommended that you reuse or remake your midterm cheat sheet

Peer Instruction Question 11/29/2017 Peer Instruction Question Which allocation strategy and requests remove external fragmentation in this Heap? B3 was the last fulfilled request. http://PollEv.com/justinh payload size B1 B3 B2 10 50 30 Best-fit: malloc(50), malloc(50) (A) First-fit: malloc(50), malloc(30) (B) Next-fit: malloc(30), malloc(50) (C) Next-fit: malloc(50), malloc(30) (D) Start of heap

Implicit List: Allocating in a Free Block 11/29/2017 Implicit List: Allocating in a Free Block Allocating in a free block: splitting Since allocated space might be smaller than free space, we might want to split the block Assume ptr points to a free block and has unscaled pointer arithmetic void split(ptr b, int bytes) { // bytes = desired block size int newsize = ((bytes+7) >> 3) << 3; // round up to multiple of 8 int oldsize = *b; // why not mask out low bit? *b = newsize; // initially unallocated if (newsize < oldsize) *(b+newsize) = oldsize - newsize; // set length in remaining } // part of block (UNSCALED +) Note that we add 4 to the malloc request size to account for the header Why not mask out? Bit must be 0, otherwise it's not a free block! malloc(12): ptr b = find(12+4) split(b, 12+4) allocate(b) Free box Allocated box Newly-allocated box 8|1 24|0 b 8|0 16|1

Implicit List: Freeing a Block 11/29/2017 Implicit List: Freeing a Block Simplest implementation just clears “allocated” flag void free(ptr p) {*(p-BOX) &= -2;} But can lead to “false fragmentation” 8|0 8|1 16|1 Free box Allocated box Block of interest p 8|0 8|1 16|0 free(p) malloc(20) Oops! There is enough free space, but the allocator won’t be able to find it

Implicit List: Coalescing with Next 11/29/2017 Implicit List: Coalescing with Next Join (coalesce) with next block if also free How do we coalesce with the previous block? 8|0 8|1 16|1 Free box Allocated box Block of interest p 8|0 8|1 24|0 free(p) logically gone void free(ptr p) { // p points to payload ptr b = p – BOX; // b points to block header *b &= -2; // clear allocated bit ptr next = b + *b; // find next block (UNSCALED +) if ((*next & 1) == 0) // if next block is not allocated, *b += *next; // add its size to this block }

Implicit List: Bidirectional Coalescing 11/29/2017 Implicit List: Bidirectional Coalescing Boundary tags [Knuth73] Replicate header at “bottom” (end) of free blocks Allows us to traverse backwards, but requires extra space Important and general technique! 16/0 16/1 24/0 Format of allocated and free blocks: Header size payload and padding a a = 1: allocated block a = 0: free block size: block size (in bytes) payload: application data (allocated blocks only) Boundary tag (footer)

Constant Time Coalescing 11/29/2017 Constant Time Coalescing Case 1 Case 2 Case 3 Case 4 Allocated Allocated Free Free Block being freed Allocated Free Allocated Free

Constant Time Coalescing 11/29/2017 Constant Time Coalescing Case 1 m1 1 n m2 m1 1 n m2 Case 2 m1 1 n m2 m1 1 n+m2 Case 3 m1 n 1 m2 n+m1 m2 1 Case 4 m1 n 1 m2 n+m1+m2

Implicit Free List Review Questions What is the block header? What do we store and how? What are boundary tags and why do we need them? When we coalesce free blocks, how many neighboring blocks do we need to check on either side? Why is this? If I want to check the size of the 𝑛-th block forward from the current block, how many memory accesses do I make? 16/0 16/1 24/0

Keeping Track of Free Blocks 11/29/2017 Keeping Track of Free Blocks = 4-byte box (free) = 4-byte box (allocated) Implicit free list using length – links all blocks using math No actual pointers, and must check each block if allocated or free Explicit free list among only the free blocks, using pointers Segregated free list Different free lists for different size “classes” Blocks sorted by size Can use a balanced binary tree (e.g. red-black tree) with pointers within each free block, and the length used as a key 20 16 8 24 20 16 8 24

(same as implicit free list) 11/29/2017 Explicit Free Lists size payload and padding a Allocated block: (same as implicit free list) size a next prev Free block: Storing pointers in the “payload” section of a free block could require a larger minimum block size, possibly increasing internal fragmentation. Use list(s) of free blocks, rather than implicit list of all blocks The “next” free block could be anywhere in the heap So we need to store next/previous pointers, not just sizes Since we only track free blocks, so we can use “payload” for pointers Still need boundary tags (header/footer) for coalescing

Doubly-Linked Lists Linear ⋅⋅⋅ Circular ⋅⋅⋅ Needs head/root pointer First node prev pointer is NULL Last node next pointer is NULL Good for first-fit, best-fit Circular Still have pointer to tell you which node to start with No NULL pointers (term condition is back at starting point) Good for next-fit, best-fit Root ⋅⋅⋅ Start ⋅⋅⋅

Explicit Free Lists Logically: doubly-linked list Physically: blocks can be in any order A B C 16 24 Forward (next) links Back (prev) links A B C

Allocating From Explicit Free Lists 11/29/2017 Allocating From Explicit Free Lists Note: These diagrams are not very specific about where inside a block a pointer points. In reality we would always point to one place (e.g. start/header of a block). Before 4 pointers updated, same number of list nodes. Don’t forget to update boundary tags for both the allocated and new free blocks! After (with splitting) = malloc(…)

Allocating From Explicit Free Lists 11/29/2017 Allocating From Explicit Free Lists Note: These diagrams are not very specific about where inside a block a pointer points. In reality we would always point to one place (e.g. start/header of a block). Before 2 pointers updated, one fewer list node. Don’t forget to create the boundary tags for the allocated block! After (fully allocated) = malloc(…)

Freeing With Explicit Free Lists Insertion policy: Where in the free list do you put the newly freed block? LIFO (last-in-first-out) policy Insert freed block at the beginning (head) of the free list Pro: simple and constant time Con: studies suggest fragmentation is worse than the alternative Address-ordered policy Insert freed blocks so that free list blocks are always in address order: address(previous) < address(current) < address(next) Con: requires linear-time search Pro: studies suggest fragmentation is better than the alternative

Coalescing in Explicit Free Lists 11/29/2017 Coalescing in Explicit Free Lists Block being freed Allocated Case 1 Free Case 2 Case 3 Case 4 Neighboring free blocks are already part of the free list Remove old block from free list Create new, larger coalesced block Add new block to free list (insertion policy) How do we tell if a neighboring block if free?

Freeing with LIFO Policy (Case 1) 11/29/2017 Boundary tags not shown, but don’t forget about them! Freeing with LIFO Policy (Case 1) Before free( ) Root Note: all blue “next” pointers and red “previous” pointers should probably point to either the header or footer of the next/previous block – it shouldn’t matter which (I think), as long as it’s done consistently. The diagrams on this slide and on the next few do not always show pointers to the exact word for the block header/footer. Insert the freed block at the root of the list After Root

Freeing with LIFO Policy (Case 2) 11/29/2017 Boundary tags not shown, but don’t forget about them! Freeing with LIFO Policy (Case 2) Before free( ) Root Note: all blue “next” pointers and red “previous” pointers should probably point to either the header or footer of the next/previous block – it shouldn’t matter which (I think), as long as it’s done consistently. The diagrams on this slide and on the next few do not always show pointers to the exact word for the block header/footer. Splice successor block out of list, coalesce both memory blocks, and insert the new block at the root of the list After Root

Freeing with LIFO Policy (Case 3) 11/29/2017 Boundary tags not shown, but don’t forget about them! Freeing with LIFO Policy (Case 3) Before free( ) Root Note: all blue “next” pointers and red “previous” pointers should probably point to either the header or footer of the next/previous block – it shouldn’t matter which (I think), as long as it’s done consistently. The diagrams on this slide and on the next few do not always show pointers to the exact word for the block header/footer. Splice predecessor block out of list, coalesce both memory blocks, and insert the new block at the root of the list After Root

Freeing with LIFO Policy (Case 4) Boundary tags not shown, but don’t forget about them! Freeing with LIFO Policy (Case 4) Before free( ) Root Splice predecessor and successor blocks out of list, coalesce all 3 memory blocks, and insert the new block at the root of the list After Root

Do we always need the boundary tags? size payload and padding a Allocated block: (same as implicit free list) size a next prev Free block: Lab 5 suggests no…

Explicit List Summary Comparison with implicit list: Block allocation is linear time in number of free blocks instead of all blocks Much faster when most of the memory is full Slightly more complicated allocate and free since we need to splice blocks in and out of the list Some extra space for the links (2 extra pointers needed for each free block) Increases minimum block size, leading to more internal fragmentation Most common use of explicit lists is in conjunction with segregated free lists Keep multiple linked lists of different size classes, or possibly for different types of objects