For the complete documentation index, see llms.txt. Markdown versions of all pages are available by appending .md to any URL (e.g. /max/get-started.md).
Mojo struct
ContinuousBatchingKVCache
struct ContinuousBatchingKVCache[dtype_: DType, kv_params_: KVCacheStaticParams, blocks_origin: MutOrigin, cache_lengths_origin: ImmutOrigin, lookup_table_origin: ImmutOrigin]
Wrapper for the ContinuousKVCache of a given layer in the transformer model.
This abstracts the Pointer indirection for accessing the ContinuousKVCache for a given batch entry.
THIS IS THE TYPE THAT IS PASSED TO KV PROJECTION AND FLASH ATTENTION KERNELS.
Parametersβ
- βdtype_ (
DType): The dtype of the kv-cache. - βkv_params_ (
KVCacheStaticParams): The kv-cache static parameters. - βblocks_origin (
MutOrigin): Origin of the KV cache blocks buffer. - βcache_lengths_origin (
ImmutOrigin): Origin of the cache lengths buffer. - βlookup_table_origin (
ImmutOrigin): Origin of the lookup table buffer.
Fieldsβ
- βblocks (
ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].blocks_tt_type): - βcache_lengths (
ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].cache_lengths_tt_type): - βlookup_table (
ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].lookup_table_tt_type): - βmax_seq_length (
UInt32): - βmax_cache_length (
UInt32):
Implemented traitsβ
AnyType,
Copyable,
DevicePassable,
ImplicitlyCopyable,
ImplicitlyDeletable,
KVCacheT,
Movable,
RegisterPassable,
TrivialRegisterPassable
comptime membersβ
blocks_layoutβ
comptime blocks_layout = Layout.row_major(ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].blocks_shape)
blocks_shapeβ
comptime blocks_shape = IntTuple(Int(-1), Int(-1), kv_params_, kv_params_)
blocks_tt_layoutβ
comptime blocks_tt_layout = Layout[*?, *?]
blocks_tt_typeβ
comptime blocks_tt_type = TileTensor[ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].dtype, Layout[*?, *?], blocks_origin]
cache_lengths_tt_layoutβ
comptime cache_lengths_tt_layout = Layout[*?, *?]
cache_lengths_tt_typeβ
comptime cache_lengths_tt_type = TileTensor[DType.uint32, Layout[*?, *?], cache_lengths_origin]
device_typeβ
comptime device_type = ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin]
dtypeβ
comptime dtype = dtype_
kv_paramsβ
comptime kv_params = kv_params_
lookup_table_tt_layoutβ
comptime lookup_table_tt_layout = Layout[*?, *?]
lookup_table_tt_typeβ
comptime lookup_table_tt_type = TileTensor[DType.uint32, Layout[*?, *?], lookup_table_origin]
page_size_β
comptime page_size_ = 0
quantization_enabledβ
comptime quantization_enabled = False
quantization_granularityβ
comptime quantization_granularity = 1
scale_dtypeβ
comptime scale_dtype = DType.float32
Methodsβ
__init__β
def __init__(blocks: TileTensor[Self.dtype, Layout[*?, *?], blocks_origin], cache_lengths: TileTensor[DType.uint32, Layout[*?, *?], cache_lengths_origin], lookup_table: TileTensor[DType.uint32, Layout[*?, *?], lookup_table_origin], max_seq_length: UInt32, max_cache_length: UInt32) -> Self
get_type_nameβ
static def get_type_name() -> String
Returns:
String
max_tile_sizeβ
cache_lengths_ndβ
def cache_lengths_nd(self) -> Self.cache_lengths_tt_type
Returns:
Self.cache_lengths_tt_type
cache_lengthβ
loadβ
def load[width: Int, output_dtype: DType = ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].dtype](self, bs: Int, head_idx: Int, tok_idx: Int, head_dim_idx: Int) -> SIMD[output_dtype, width]
Returns:
storeβ
def store(self, bs: Int, head_idx: Int, tok_idx: Int, head_dim_idx: Int, val: SIMD[Self.dtype])
load_scaleβ
def load_scale[width: Int](self, bs: Int, head_idx: Int, tok_idx: Int, head_dim_idx: Int) -> SIMD[DType.float32, width]
Loads a quantization scale from the given index.
Note: ContinuousBatchingKVCache does not support KVCache quantization.
Returns:
store_scaleβ
def store_scale(self, bs: Int, head_idx: Int, tok_idx: Int, head_dim_idx: Int, scales: SIMD[DType.float32])
Stores the quantization scales at the given index.
Note: ContinuousBatchingKVCache does not support KVCache quantization.
load_quantizedβ
def load_quantized[width: Int](self, bs: Int, head_idx: Int, tok_idx: Int, head_dim_idx: Int) -> SIMD[Self.dtype, width]
Loads a quantized element from the given index.
Note: ContinuousBatchingKVCache does not support KVCache quantization.
Returns:
empty_cacheβ
def empty_cache(self) -> Bool
Returns true if the cache_lengths for all requests is 0, false otherwise.
Returns:
max_prompt_lengthβ
def max_prompt_length(self) -> UInt32
Returns the maximum sequence length across all batches of the current request.
Returns:
max_context_lengthβ
def max_context_length(self) -> UInt32
Returns the maximum cache length used across all batches of the current request.
Returns:
get_tma_rowβ
def get_tma_row(self, encoded_index: Int32) -> Int32
Convert an encoded sparse index to a physical TMA row.
For non-paged caches the encoded index is already the row, so this is an identity operation.
Returns:
num_kv_rowsβ
def num_kv_rows(self) -> Int
Returns the total number of virtual rows in this KV cache view.
Returns:
row_idxβ
def row_idx(self, batch_idx: UInt32, tok_idx: UInt32) -> UInt32
Returns the row idx when viewing the memory as a matrix.
Returns:
create_tma_tileβ
def create_tma_tile[swizzle_mode: TensorMapSwizzle, *, BN: Int, BK: Int = padded_depth[dtype_, swizzle_mode, kv_params_.head_size]()](self, ctx: DeviceContext) -> TMATensorTile[Self.dtype, Int(3), _padded_shape[Int(3), Self.dtype, IndexList(BN, Int(1), BK, __list_literal__=NoneType(None)), swizzle_mode](), _ragged_shape[Int(3), Self.dtype, IndexList(BN, Int(1), BK, __list_literal__=NoneType(None)), swizzle_mode]()]
Creates a TMA tile for this KV cache.
Returns:
create_gather4_tma_tileβ
def create_gather4_tma_tile[*, tile_height: Int = Int(4), tile_width: Int, tile_stride: Int = tile_width, swizzle_mode: TensorMapSwizzle = TensorMapSwizzle.SWIZZLE_NONE, tma_dtype: DType = ContinuousBatchingKVCache[dtype_, kv_params_, blocks_origin, cache_lengths_origin, lookup_table_origin].dtype, l2_promotion: TensorMapL2Promotion = TensorMapL2Promotion.NONE](self, ctx: DeviceContext) -> TMATensorTile[tma_dtype, Int(2), IndexList(tile_height, _gather4_box_width[tma_dtype, tile_width, swizzle_mode](), __list_literal__=NoneType(None)), IndexList(Int(1), _gather4_box_width[tma_dtype, tile_width, swizzle_mode](), __list_literal__=NoneType(None))]
Creates a 2D TMA gather4 descriptor for this KV cache.
The descriptor views the KV cache as a flat 2D matrix of
[num_kv_rows, tile_width] and is configured for gather4 operations
that load 4 non-contiguous rows per TMA instruction. The box width
is derived from the swizzle mode; for SWIZZLE_NONE it equals
tile_width.
When tma_dtype differs from Self.dtype, the underlying data
pointer is bitcast to tma_dtype at descriptor creation time.
Parameters:
- βtile_height (
Int): Number of rows in the tile. Must be a multiple of 4. Defaults to 4 for backward compatibility. - βtile_width (
Int): Number of elements per row to load (box width) intma_dtypeelements. - βtile_stride (
Int): Row stride in elements in global memory. Defaults totile_width. Use a larger value when the global row is wider than the portion to load. - βswizzle_mode (
TensorMapSwizzle): TMA swizzle mode for shared memory access pattern. Defaults to SWIZZLE_NONE. - βtma_dtype (
DType): The data type used for the TMA descriptor. Defaults toSelf.dtype. When different, the pointer is bitcast. - βl2_promotion (
TensorMapL2Promotion): L2 cache promotion hint for TMA loads. Defaults to NONE.
Args:
- βctx (
DeviceContext): The CUDA device context used to create the TMA descriptor.
Returns:
TMATensorTile[tma_dtype, Int(2), IndexList(tile_height, _gather4_box_width[tma_dtype, tile_width, swizzle_mode](), __list_literal__=NoneType(None)), IndexList(Int(1), _gather4_box_width[tma_dtype, tile_width, swizzle_mode](), __list_literal__=NoneType(None))]: A TMATensorTile with box width derived from the swizzle mode.
create_ragged_tma_tileβ
def create_ragged_tma_tile[swizzle_mode: TensorMapSwizzle, *, BN: Int, BK: Int = padded_depth[dtype_, swizzle_mode, kv_params_.head_size]()](self, ctx: DeviceContext, out tma: RaggedTMA3DTile[Self.dtype, swizzle_mode, BM=BN, BN=BK])
Returns:
create_rope_tma_tileβ
def create_rope_tma_tile[swizzle_mode: TensorMapSwizzle, *, BN: Int, BK: Int, padded_depth: Int](self, ctx: DeviceContext, out tma: TMATensorTile[DType.bfloat16, Int(3), _padded_shape[Int(3), DType.bfloat16, IndexList(BN, Int(1), BK, __list_literal__=NoneType(None)), swizzle_mode](), _ragged_shape[Int(3), DType.bfloat16, IndexList(BN, Int(1), BK, __list_literal__=NoneType(None)), swizzle_mode]()])
Not supported for ContinuousBatchingKVCache.
Returns:
create_rope_gather4_tma_tileβ
def create_rope_gather4_tma_tile[*, tile_height: Int = Int(4), tile_width: Int, padded_depth: Int, swizzle_mode: TensorMapSwizzle = TensorMapSwizzle.SWIZZLE_NONE, l2_promotion: TensorMapL2Promotion = TensorMapL2Promotion.NONE](self, ctx: DeviceContext) -> TMATensorTile[DType.bfloat16, Int(2), IndexList(tile_height, _gather4_box_width[DType.bfloat16, tile_width, swizzle_mode](), __list_literal__=NoneType(None)), IndexList(Int(1), _gather4_box_width[DType.bfloat16, tile_width, swizzle_mode](), __list_literal__=NoneType(None))]
Not supported for ContinuousBatchingKVCache.
Returns:
block_paged_ptrβ
def block_paged_ptr[tile_size: Int](self, batch_idx: Int, start_tok_idx: Int, head_idx: Int, head_dim_idx: Int = Int(0)) -> UnsafePointer[Scalar[Self.dtype], MutAnyOrigin]
Returns:
scales_block_paged_ptrβ
def scales_block_paged_ptr(self, batch_idx: Int, start_tok_idx: Int, head_idx: Int, head_dim_idx: Int = Int(0)) -> UnsafePointer[Float32, MutAnyOrigin]
Returns a pointer to the scales block at the requested indices.
Note: ContinuousBatchingKVCache does not support KVCache quantization. This function returns a dangling pointer.
Returns:
scales_raw_ptrβ
def scales_raw_ptr(self) -> UnsafePointer[Float32, MutAnyOrigin]
Returns a dangling pointer. ContinuousBatchingKVCache does not support quantization.
Returns:
Was this page helpful?
Thank you! We'll create more content like this.
Thank you for helping us improve!