dynamo-llm 1.0.2

Dynamo LLM Library
// SPDX-FileCopyrightText: Copyright (c) 2024-2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
// SPDX-License-Identifier: Apache-2.0

use super::*;
use crate::block_manager::events::DynamoEventManager;

impl Resources {
    /// Create a new [`Resources`] instance
    pub async fn new(config: KvBlockManagerConfig) -> Result<Self> {
        config
            .runtime
            .validate()
            .context("Validating runtime config")?;

        config.model.validate().context("Validating model config")?;

        let worker_id = config.runtime.worker_id;
        let cancellation_token = config.runtime.cancellation_token.clone();

        let global_registry = GlobalRegistry::default();

        // Create event manager based on configuration:
        // 1. If explicit event_manager provided, use it
        // 2. Else if consolidator_config provided, create DynamoEventManager with consolidator
        // 3. Else use NullEventManager (no event reporting)
        let event_manager = if let Some(ref event_mgr) = config.event_manager {
            tracing::info!("Using explicit event_manager from config");
            event_mgr.clone()
        } else if let Some(consolidator_config) = config.consolidator_config.clone() {
            tracing::info!(
                "Creating DynamoEventManager with kv event consolidator config: engine={}, source={:?}",
                consolidator_config.engine_event_endpoint,
                consolidator_config.engine_source
            );
            // Create DynamoEventManager with consolidator config (async)
            match DynamoEventManager::new_with_config(consolidator_config).await {
                Ok(manager) => manager as Arc<dyn EventManager>,
                Err(e) => {
                    tracing::error!(
                        "Failed to create DynamoEventManager with consolidator: {}, fallback to NullEventManager",
                        e
                    );
                    NullEventManager::new()
                }
            }
        } else {
            tracing::info!("Using NullEventManager");
            NullEventManager::new()
        };

        let mut nixl_backends: HashMap<String, Arc<nixl_sys::Backend>> = HashMap::new();

        let nixl_agent = Arc::new(match &config.runtime.nixl {
            NixlOptions::Enabled => {
                tracing::debug!("Creating NIXL agent");
                let agent = NixlAgent::new(&worker_id.to_string())?;

                tracing::debug!("Creating NIXL backends");

                if config.disk_layout.is_some() {
                    if let Ok((_, gds_mt_params)) = agent.get_plugin_params("GDS_MT") {
                        let backend = agent.create_backend("GDS_MT", &gds_mt_params)?;
                        nixl_backends.insert("GDS_MT".to_string(), Arc::new(backend));
                    } else {
                        tracing::warn!("No GDS_MT plugin found; will not create GDS_MT backend");
                    }
                }

                Some(agent)
            }
            NixlOptions::EnabledWithAgent(agent) => Some(agent.clone()),
            NixlOptions::Disabled => None,
        });

        let async_rt_handle = match &config.runtime.async_runtime {
            Some(rt) => rt.handle().clone(),
            None => match Handle::try_current() {
                Ok(handle) => handle,
                Err(e) => anyhow::bail!(e),
            },
        };

        Ok(Self {
            worker_id,
            cancellation_token,
            async_rt_handle,
            nixl_agent,
            nixl_backends,
            global_registry,
            event_manager,
            config,
        })
    }

    /// Create a new [`LayoutConfigBuilder`] with the model configuration
    pub fn layout_builder(&self) -> LayoutConfigBuilder {
        let mut layout_builder = LayoutConfig::builder();

        let model = &self.config.model;

        layout_builder
            .num_layers(model.num_layers)
            .outer_dim(model.outer_dim)
            .page_size(model.page_size)
            .inner_dim(model.inner_dim)
            .dtype_width_bytes(model.dtype_width_bytes);

        layout_builder
    }
}