pokeys-lib 1.0.4

Pure Rust core library for PoKeys device control - USB/Network connectivity, I/O, PWM, encoders, SPI/I2C protocols
Documentation
---
import '../../styles/global.css';
---

<html lang="en">
	<head>
		<meta charset="utf-8" />
		<link rel="icon" type="image/svg+xml" href="/favicon.svg" />
		<meta name="viewport" content="width=device-width" />
		<meta name="generator" content={Astro.generator} />
		<title>SPI Protocol API - PoKeys Core Library</title>
		<style>
			aside .sidebar-nav a {
				display: block !important;
				width: 100% !important;
			}
			aside .sidebar-nav {
				display: flex !important;
				flex-direction: column !important;
			}
		</style>
	</head>
	<body class="bg-gray-900 text-white">
		<!-- Navigation -->
		<nav class="fixed top-0 left-0 right-0 z-50 bg-gray-900/80 backdrop-blur-md border-b border-gray-800 h-16">
			<div class="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8 h-full">
				<div class="flex justify-between items-center h-full">
					<a href="/core/" class="text-2xl font-bold bg-gradient-to-r from-blue-400 to-purple-500 bg-clip-text text-transparent">
						PoKeys
					</a>
					<div class="hidden md:flex space-x-8">
						<a href="/core/" class="text-gray-300 hover:text-white transition-colors">Home</a>
						<a href="/core/getting-started" class="text-gray-300 hover:text-white transition-colors">Getting Started</a>
						<a href="/core/examples/" class="text-gray-300 hover:text-white transition-colors">Examples</a>
						<a href="/core/api/" class="text-white font-semibold">API Reference</a>
					</div>
				</div>
			</div>
		</nav>

		<!-- Main Content -->
		<div class="flex min-h-screen pt-16">
			<!-- Sidebar -->
			<aside class="w-80 bg-gray-800/50 border-r border-gray-700 overflow-y-auto flex-shrink-0">
				<div class="p-6">
					<a href="/core/api/" class="text-blue-400 hover:text-blue-300 mb-4 inline-block">← Back to API Reference</a>
					<h2 class="text-xl font-bold mb-6 text-white">API Reference</h2>
					
					<!-- Core APIs -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Core APIs</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/device" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Device Management
							</a>
							<a href="/core/api/connection" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Connection & Enumeration
							</a>
							<a href="/core/api/models" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Device Models
							</a>
						</div>
					</div>

					<!-- I/O Operations -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">I/O Operations</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/digital-io" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Digital I/O
							</a>
							<a href="/core/api/analog-io" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Analog I/O
							</a>
							<a href="/core/api/pin-functions" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Pin Functions
							</a>
						</div>
					</div>

					<!-- Control Systems -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Control Systems</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/pwm" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								PWM Control
							</a>
							<a href="/core/api/encoders" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Encoders
							</a>
							<a href="/core/api/pulse-engine" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Pulse Engine v2
							</a>
							<a href="/core/api/servo-control" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Servo Control
							</a>
						</div>
					</div>

					<!-- Communication -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Communication</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/spi" class="block px-3 py-2 text-white bg-gray-700/50 rounded-md transition-colors">
								SPI Protocol
							</a>
							<a href="/core/api/i2c" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								I2C Protocol
							</a>
							<a href="/core/api/uart" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								UART Serial
							</a>
							<a href="/core/api/can" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								CAN Bus
							</a>
							<a href="/core/api/onewire" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								1-Wire Protocol
							</a>
						</div>
					</div>

					<!-- Matrix Operations -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Matrix Operations</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/matrix-keyboard" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Matrix Keyboard
							</a>
							<a href="/core/api/led-matrix" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								LED Matrix
							</a>
						</div>
					</div>

					<!-- Display & Sensors -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Display & Sensors</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/lcd" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								LCD Display
							</a>
							<a href="/core/api/sensors" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								EasySensors
							</a>
							<a href="/core/api/rtc" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Real-Time Clock
							</a>
						</div>
					</div>

					<!-- Error Handling -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Error Handling</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/errors" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Error Types
							</a>
							<a href="/core/api/result-handling" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Result Handling
							</a>
						</div>
					</div>

					<!-- Types & Utilities -->
					<div class="mb-6">
						<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider mb-3">Types & Utilities</h3>
						<div class="space-y-1 sidebar-nav">
							<a href="/core/api/types" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Core Types
							</a>
							<a href="/core/api/constants" class="block px-3 py-2 text-gray-300 hover:text-white hover:bg-gray-700/50 rounded-md transition-colors">
								Constants
							</a>
						</div>
					</div>
				</div>
			</aside>

			<!-- Main Content Area -->
			<main class="flex-1 p-8 min-h-screen">
				<div class="max-w-4xl">
					<!-- Header -->
					<div class="mb-12">
						<div class="flex items-center gap-4 mb-6">
							<span class="px-3 py-1 bg-yellow-600/20 text-yellow-300 text-sm rounded-full">SPI Protocol</span>
						</div>
						<h1 class="text-4xl font-bold mb-4 bg-gradient-to-r from-yellow-400 to-orange-500 bg-clip-text text-transparent">
							SPI Protocol API
						</h1>
						<p class="text-xl text-gray-400">
							SPI master operations with multiple chip select support and automatic pin reservation
						</p>
					</div>

					<!-- Overview -->
					<section class="mb-12">
						<h2 class="text-2xl font-bold mb-4 text-white">Overview</h2>
						<div class="bg-gray-800 rounded-lg p-6">
							<p class="text-gray-300 mb-4">
								The SPI Protocol API provides full SPI master support with automatic pin reservation and multiple chip select management. 
								PoKeys devices support 31-33 chip select capable pins depending on the model.
							</p>
							<div class="grid md:grid-cols-2 gap-6">
								<div>
									<h3 class="text-lg font-semibold mb-2 text-yellow-400">Key Features</h3>
									<ul class="text-gray-300 space-y-1 text-sm">
										<li>• Full SPI master support</li>
										<li>• Multiple chip select pins (31-33 per device)</li>
										<li>• Automatic pin reservation (MOSI, CLK)</li>
										<li>• Configurable clock speed and mode</li>
										<li>• Hardware constraint enforcement</li>
									</ul>
								</div>
								<div>
									<h3 class="text-lg font-semibold mb-2 text-orange-400">Pin Assignments</h3>
									<ul class="text-gray-300 space-y-1 text-sm font-mono">
										<li><strong>Pin 23 (MOSI)</strong> - Master Out Slave In</li>
										<li><strong>Pin 24 (MISO)</strong> - Master In Slave Out</li>
										<li><strong>Pin 25 (CLK)</strong> - Clock signal</li>
										<li><strong>CS Pins</strong> - Various pins support chip select</li>
									</ul>
								</div>
							</div>
						</div>
					</section>

					<!-- Pin Reservation -->
					<section class="mb-12">
						<h2 class="text-2xl font-bold mb-6 text-white">Automatic Pin Reservation</h2>
						<div class="bg-red-900/20 border border-red-500/30 rounded-lg p-6">
							<h3 class="text-red-400 font-semibold mb-3">Important: Hardware Constraints</h3>
							<ul class="text-gray-300 space-y-2 text-sm">
								<li><strong>Pin 23 (MOSI)</strong> and <strong>Pin 25 (CLK)</strong> are automatically reserved when SPI is enabled</li>
								<li>• These pins cannot be used for other functions while SPI is active</li>
								<li>• Configuration validation prevents conflicts</li>
								<li>• Use <code>is_pin_capability_supported()</code> to check CS pin availability</li>
							</ul>
						</div>
					</section>

					<!-- Basic SPI Operations -->
					<section class="mb-12">
						<h2 class="text-2xl font-bold mb-6 text-white">Basic SPI Operations</h2>
						<div class="bg-gray-800 rounded-lg p-6">
							<div class="bg-gray-900 rounded p-4">
								<h4 class="font-semibold text-yellow-400 mb-2">Example Usage</h4>
								<pre class="text-gray-300"><code>use pokeys_lib::*;

fn main() -> Result&lt;()&gt; {`{`}
    let mut device = connect_to_device(0)?;

    // Initialize SPI (automatically reserves pins 23 and 25)
    device.spi_init()?;

    // Configure chip select pin
    let cs_pin = 10;
    device.validate_pin_capability(cs_pin, "SPI_CS")?;

    // SPI transaction
    let tx_data = vec![0x01, 0x02, 0x03];
    let rx_data = device.spi_transfer(cs_pin, &tx_data)?;

    println!(\"Received: {`{`}:?{`}`}\", rx_data);
    Ok(())
{`}`}</code></pre>
							</div>
						</div>
					</section>

					<!-- Device Model Support -->
					<section class="mb-12">
						<h2 class="text-2xl font-bold mb-6 text-white">Device Model Support</h2>
						<div class="bg-gray-800 rounded-lg p-6 overflow-x-auto">
							<table class="w-full text-sm">
								<thead>
									<tr class="border-b border-gray-600">
										<th class="text-left py-2 text-yellow-400">Device Model</th>
										<th class="text-left py-2 text-orange-400">Total Pins</th>
										<th class="text-left py-2 text-green-400">CS Capable Pins</th>
										<th class="text-left py-2 text-blue-400">Reserved Pins</th>
									</tr>
								</thead>
								<tbody class="text-gray-300">
									<tr class="border-b border-gray-700">
										<td class="py-2 font-semibold">PoKeys56U/56E</td>
										<td class="py-2">55</td>
										<td class="py-2">31</td>
										<td class="py-2">23 (MOSI), 25 (CLK)</td>
									</tr>
									<tr class="border-b border-gray-700">
										<td class="py-2 font-semibold">PoKeys57U/57E</td>
										<td class="py-2">57</td>
										<td class="py-2">33</td>
										<td class="py-2">23 (MOSI), 25 (CLK)</td>
									</tr>
								</tbody>
							</table>
						</div>
					</section>

					<!-- Best Practices -->
					<section class="mb-12">
						<h2 class="text-2xl font-bold mb-4 text-white">Best Practices</h2>
						<div class="bg-gray-800 rounded-lg p-6">
							<div class="space-y-4">
								<div>
									<h3 class="text-lg font-semibold mb-2 text-green-400">Pin Planning</h3>
									<ul class="text-gray-300 space-y-1 text-sm">
										<li>• Reserve pins 23 and 25 for SPI before other pin assignments</li>
										<li>• Validate CS pin capability before configuration</li>
										<li>• Plan peripheral connections based on available CS pins</li>
									</ul>
								</div>
								<div>
									<h3 class="text-lg font-semibold mb-2 text-blue-400">Performance</h3>
									<ul class="text-gray-300 space-y-1 text-sm">
										<li>• Use appropriate clock speeds for your peripherals</li>
										<li>• Minimize CS transitions for better performance</li>
										<li>• Consider using bulk transfers for large data</li>
									</ul>
								</div>
							</div>
						</div>
					</section>
				</div>
			</main>
		</div>
	</body>
</html>