The Inference.net Staking Protocol is being tested on Solana Devnet with test
tokens. These tokens have no monetary value and should not be used for
real-world transactions or bought or sold by anyone.
Security Overview
We employ various internal inference verification mechanisms to ensure honest behavior among all GPU operators. Some of these scores are surfaced to users through our dashboards as Verification Scores. GPU operators who fail inference verification checks, or who are identified by other security mechanisms, may be halted or slashed.Inference verifications are currently only produced by workers running Docker
(see instructions here). This may become required in the
future.
Protocol Security Features
To maintain network reliability and prevent malicious behavior, the protocol supports two primary security mechanisms:- Halting: Temporary suspension of certain actions to allow investigation
- Slashing: Permanent penalty for severe violations, affecting only operator stake
Delegated tokens are always protected from slashing. Only an operator’s own
stake can be penalized for violations.
Halting Mechanism
Halting allows authorities to temporarily restrict actions while investigating potential issues. This prevents further harm without permanent penalties.Types of Halts
- 
Global Halts
- Controlled via the PoolOverviewaccount
- Can halt:
- All staking operations (is_staking_halted)
- All withdrawals/unstaking (is_withdrawal_halted)
- Reward accruals (is_accrue_reward_halted)
- New pool creation (allow_pool_creation)
 
- All staking operations (
- Used for network-wide emergencies or maintenance
 
- Controlled via the 
- 
Pool-Specific Halts
- Sets halted_attimestamp on individual OperatorPool
- Restricts operator actions like:
- Staking/unstaking
- Claiming rewards
- Withdrawing commissions
- Closing the pool
 
- Delegators can still unstake and withdraw their funds
- Initiated by program halt authorities
 
- Sets 
Halt Process
- Halt authorities invoke set_halt_statusinstruction
- For pool halts, sets current timestamp as halted_at
- Halts can be reversed by setting halted_atto None
- Used to freeze suspicious pools during investigation
Slashing Mechanism
Slashing is a permanent penalty for confirmed violations, designed to economically disincentivize malicious behavior.What Gets Slashed
- Only the operator’s self-stake (from their staking record)
- Accrued but unclaimed:
- Token commissions
- USDC commissions
- USDC earnings
 
- Delegated tokens are never slashed
Slashing Process
- 
Prerequisite: Pool Must Be Halted
- Pool must already be halted
- Minimum delay period must elapse (at least 1 day, configurable via slashing_delay_seconds)
 
- 
Invocation
- Slashing authorities call slash_stakeinstruction
- Specify amount of shares to slash
- Settles any pending USDC earnings first
 
- Slashing authorities call 
- 
Effects
- Reduces operator’s shares and corresponding tokens
- Confiscates all pending commissions and USDC
- Transfers slashed assets to designated protocol accounts
- Emits SlashStakeEventwith details
 
- 
Destination
- Slashed tokens go to slashing_destination_token_account
- Slashed USDC goes to slashing_destination_usdc_account
 
- Slashed tokens go to 
Slashing is irreversible. Authorities follow strict protocols and evidence
requirements before invoking slashes.
Violation Examples
Potential reasons for halting/slashing include:- Malicious job processing
- Network attacks or spam
- Protocol violations
- Hardware misrepresentation
Authorities and Controls
Security operations are managed by separate authority sets to distribute power:- Halt Authorities (halt_authorities): Can halt/unhalt pools
- Slashing Authorities (slashing_authorities): Can execute slashes on halted pools
- Program Admin: Can update authority lists and global settings
Protections for Participants
The protocol includes several safeguards:- 
Delegator Protection
- Delegated tokens immune to slashing
- Can always unstake from halted pools
- Protected from operator misconduct
 
- 
Delay Periods
- Minimum 1-day delay between halt and slash
- Configurable via slashing_delay_seconds
- Allows time for appeals/investigation
 
- 
Transparency
- All halts and slashes emit events
- On-chain timestamps track actions
- Public authority keys
 
- 
Reversibility
- Halts can be lifted
- Global halts are temporary controls
 
Best Practices for Operators
To avoid security actions:- Maintain honest job processing
- Ensure high uptime and performance
- Follow all protocol rules
- Monitor your pool status
- Respond promptly to any warnings
- Keep your hardware secure
- Contact support immediately
- Provide any requested evidence
- Do not attempt restricted actions
- Delegators can still withdraw
FAQ
Q: Can delegators lose funds from slashing?A: No. Only operator self-stake is at risk. Delegators are fully protected. Q: How long after halting can slashing occur?
A: At least 1 day (86,400 seconds), configurable but never less than minimum. Q: Who controls the authorities?
A: Authority keys are managed by Inference.net governance. Lists are public and on-chain. Q: What happens to slashed funds?
A: Transferred to protocol-controlled accounts to fund network security initiatives. Q: Can I unstake from a halted pool?
A: Delegators can unstake from a halted pool, but operators cannot. Q: How are violations detected?
A: Through inference and network verification mechanisms. For questions or concerns about network security, join our Discord community.