## Learning Objectives
* Learn about the USM data management model
* Learn about the benefits of USM and when to use it
* Learn about the variations of USM
* Learn about the kinds of USM memory allocations
#### What is USM?
Unified shared memory (USM) provides an alternative pointer-based data management model to the accessor-buffer model
* Unified virtual address space
* Pointer-based structures
* Explicit memory management
* Shared memory allocations
#### Unified virtual address space
data:image/s3,"s3://crabby-images/88769/88769f6282b750a7e84ed1bdd55c8369a9ea7c7b" alt="SYCL"
* USM memory allocations return pointers which are consistent between the host application and kernel functions on a device
* Representing data between the host and device(s) does not require creating accessors
* Pointer-based API more familiar to C or C++ programmers
#### Pointer based structures
data:image/s3,"s3://crabby-images/9ee53/9ee53ba59eeaaef455d41b1a7e5f605a258fb89e" alt="SYCL"
* Data is moved between the host and device(s) in a span of memory in bytes rather than a buffer of a specific type
* Pointers within that region of memory can freely point to any other address in that region
* Easier to port existing C or C++ code to use SYCL
#### Explicit memory management
data:image/s3,"s3://crabby-images/5f1f7/5f1f722c0ecebb2278b6fd6939e73114966b3e1c" alt="SYCL"
* Memory is allocated and data is moved using explicit routines
* Moving data between the host and device(s) does not require accessors or submitting command groups
* The SYCL runtime will not perform any data dependency analysis, dependencies between commands must be managed manually
#### Shared memory allocations
data:image/s3,"s3://crabby-images/e9a2e/e9a2e83bfc286770417b910b721335ab6bb0b766" alt="SYCL"
* Some platforms will support variants of USM where memory allocations share the same memory region between the host and device(s)
* No explicit routines are required to move the data between the host and device(s)
#### USM allocation types
USM has three different kinds of memory allocation
* A **host** allocation is allocated in host memory
* A **device** allocation is allocation in device memory
* A **shared** allocation is allocated in shared memory and can migrate back and forth
#### USM variants
USM has four variants which a platform can support with varying levels of support
data:image/s3,"s3://crabby-images/6065e/6065e5cd67f3e9d05b69c838b8a41a399cb1b429" alt="SYCL"
#### Querying for support
Each SYCL platform and its device(s) will support
different variants of USM and different kinds of memory allocation
if (dev.has(sycl::aspect::usm_device_allocations))
#### Buffer/accessor vs USM
So when should you use the accessor/buffer mode and
when should you use the USM model?
* The **buffer/accessor** provides guaranteed
consistency and automatically manages dependencies
* Recommended when you need to iterate over or
prototype your application
* Recommended for maximum performance portability
* Provides a lot of information to the SYCL runtime which can perform many optimizations automatically
* The **USM** model provides a lower-level pointer-based
solution with fine grained control
* Recommended when porting existing C++ applications
or using pointer-based structures
* User has responsibility for certain aspects relevant for performance (e.g. data transfers or data prefetches)
#### Exercise
Code_Exercises/Introduction_to_USM/source
Implement a device selector that chooses a device in your system which supports explicit USM and device allocations