telltale-machine 17.0.0

Protocol machine for choreographic session type protocols
Documentation
//! Threaded ProtocolMachine backend (feature-gated, adapter runtime).
//!
//! Executes one coroutine per session per round in parallel, preserving
//! per-session trace equivalence with the cooperative ProtocolMachine.
//!
//! Semantic ownership remains in the canonical `ProtocolMachineKernel` contract.

use rayon::prelude::*;
use rayon::{ThreadPool, ThreadPoolBuilder};
use serde::{Deserialize, Serialize};
use serde_json::json;
use std::collections::{BTreeMap, BTreeSet, VecDeque};
use std::sync::atomic::{AtomicUsize, Ordering};
use std::sync::{Arc, Mutex, RwLock, TryLockError};
use std::time::Duration;

use telltale_types::{LocalTypeR, ValType};

use crate::buffer::{BufferConfig, EnqueueResult};
use crate::clock::SimClock;
use crate::commit_common::{apply_output_condition_gate, effect_trace_entry_for_event};
use crate::communication_replay::{
    CommunicationConsumption, CommunicationConsumptionArtifact, CommunicationReplayError,
    CommunicationStepKind, DefaultCommunicationConsumption,
};
use crate::coroutine::{BlockReason, CoroStatus, Coroutine, Fault, ProgressToken, Value};
use crate::effect::{
    infer_effect_interface_and_operation, CorruptionType, EffectExchangeRecord, EffectFailure,
    EffectHandler, EffectOutcome, EffectRequest, EffectResponse, EffectResult, EffectTraceEntry,
    ReplayEffectHandler, SendDecision, TopologyPerturbation,
};
use crate::engine::{
    runtime_value_matches_val_type, runtime_value_val_type, runtime_value_wire_size_bytes,
    EffectTraceCaptureMode, MonitorMode, ObsEvent, ProgramStore, ProtocolMachineConfig,
    ProtocolMachineError, ResourceState, RunStatus, SiteId, StepResult, ThreadedRoundSemantics,
};
use crate::faults::{
    speculation_fault_abort_requires_active, speculation_fault_disabled,
    speculation_fault_join_requires_active, transfer_fault_delegation_guard_violation,
};
use crate::instr::{Endpoint, Instr, InvokeAction, PC};
use crate::instruction_semantics::{
    decode_branch_label_payload, decode_endpoint_fact, endpoint_from_reg,
};
use crate::intern::{EdgeId, EdgeSymbolTable, StringId, SymbolTable};
use crate::kernel::{KernelMachine, ProtocolMachineKernel};
use crate::loader::CodeImage;
use crate::output_condition::{OutputConditionCheck, OutputConditionHint};
use crate::owned::OwnedSession;
use crate::refinement::{
    block_reason_tag, coro_status_tag, ProtocolMachineRefinementSlice, RefinementSliceError,
    SchedulerRefinementSlice, SessionRefinementSlice,
};
use crate::scheduler::Scheduler;
use crate::semantic_objects::{
    protocol_machine_semantic_objects, OperationInstance, OperationPhase, OutstandingEffect,
    OutstandingEffectStatus, ProgressContract, ProgressState, ProgressTransition,
    ProtocolMachineSemanticObjects,
};
use crate::serialization::{
    canonical_replay_fragment_v1, semantic_audit_log_v1, CanonicalReplayFragmentV1,
    SemanticAuditRecord,
};
use crate::session::{
    unfold_if_var_with_scope, Edge, OwnershipCapability, OwnershipError, OwnershipScope, SessionId,
    SessionOpenPlan, SessionState, SessionStatus,
};
use crate::transfer_semantics::{
    decode_transfer_request, delegation_receipt, move_endpoint_bundle,
    validate_delegation_coherence, DelegationAuditRecord, DelegationReceipt, DelegationStatus,
};

// Lane identifier in the threaded runtime.

struct OutputHintObservation {
    request: EffectRequest,
    outcome: EffectOutcome,
    hint: Option<OutputConditionHint>,
}

#[derive(Clone)]
struct EffectObservation {
    request: EffectRequest,
    outcome: EffectOutcome,
}

struct ThreadedExecSuccess {
    pack: StepPack,
    effect_observations: Vec<EffectObservation>,
    output_observation: Option<OutputHintObservation>,
}

struct ThreadedExecFault {
    fault: Fault,
    effect_observations: Vec<EffectObservation>,
}

impl ThreadedExecFault {
    fn new(fault: Fault) -> Self {
        Self {
            fault,
            effect_observations: Vec::new(),
        }
    }

    fn with_observation(fault: Fault, observation: EffectObservation) -> Self {
        Self {
            fault,
            effect_observations: vec![observation],
        }
    }
}

include!("threaded/prelude.rs");
include!("threaded/runtime_and_scheduling.rs");
include!("threaded/semantic_state.rs");
include!("threaded/runtime_introspection.rs");
include!("threaded/topology_and_planner.rs");
include!("threaded/commit_and_handoff.rs");
include!("threaded/exec_and_validation.rs");
include!("threaded/instructions_send_recv.rs");
include!("threaded/instructions_guard.rs");
include!("threaded/instructions_choice.rs");

#[cfg(test)]
mod tests {
    include!("../tests/unit/threaded_runtime_tests.rs");
}