1*61c4878aSAndroid Build Coastguard Worker// Copyright 2023 The Pigweed Authors 2*61c4878aSAndroid Build Coastguard Worker// 3*61c4878aSAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License"); you may not 4*61c4878aSAndroid Build Coastguard Worker// use this file except in compliance with the License. You may obtain a copy of 5*61c4878aSAndroid Build Coastguard Worker// the License at 6*61c4878aSAndroid Build Coastguard Worker// 7*61c4878aSAndroid Build Coastguard Worker// https://www.apache.org/licenses/LICENSE-2.0 8*61c4878aSAndroid Build Coastguard Worker// 9*61c4878aSAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software 10*61c4878aSAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 11*61c4878aSAndroid Build Coastguard Worker// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 12*61c4878aSAndroid Build Coastguard Worker// License for the specific language governing permissions and limitations under 13*61c4878aSAndroid Build Coastguard Worker// the License. 14*61c4878aSAndroid Build Coastguard Workersyntax = "proto3"; 15*61c4878aSAndroid Build Coastguard Worker 16*61c4878aSAndroid Build Coastguard Workerpackage pw.i2c; 17*61c4878aSAndroid Build Coastguard Worker 18*61c4878aSAndroid Build Coastguard Workermessage I2cWriteRequest { 19*61c4878aSAndroid Build Coastguard Worker // Which I2C initiator bus to communicate on. 20*61c4878aSAndroid Build Coastguard Worker uint32 bus_index = 1; 21*61c4878aSAndroid Build Coastguard Worker // 7-bit I2C target address to write to. 22*61c4878aSAndroid Build Coastguard Worker uint32 target_address = 2; 23*61c4878aSAndroid Build Coastguard Worker // Register address to write. Follow the endianness required by the 24*61c4878aSAndroid Build Coastguard Worker // responder for multi-byte address. 25*61c4878aSAndroid Build Coastguard Worker bytes register_address = 3; 26*61c4878aSAndroid Build Coastguard Worker // Value to write. Follow the endianness required by the responder. 27*61c4878aSAndroid Build Coastguard Worker bytes value = 4; 28*61c4878aSAndroid Build Coastguard Worker} 29*61c4878aSAndroid Build Coastguard Worker 30*61c4878aSAndroid Build Coastguard Workermessage I2cWriteResponse {} 31*61c4878aSAndroid Build Coastguard Worker 32*61c4878aSAndroid Build Coastguard Workermessage I2cReadRequest { 33*61c4878aSAndroid Build Coastguard Worker // Which I2C initiator bus to communicate on. 34*61c4878aSAndroid Build Coastguard Worker uint32 bus_index = 1; 35*61c4878aSAndroid Build Coastguard Worker // 7-bit I2C target address to read from. 36*61c4878aSAndroid Build Coastguard Worker uint32 target_address = 2; 37*61c4878aSAndroid Build Coastguard Worker // Register address to write. Follow the endianness required by the 38*61c4878aSAndroid Build Coastguard Worker // responder for multi-byte address. 39*61c4878aSAndroid Build Coastguard Worker bytes register_address = 3; 40*61c4878aSAndroid Build Coastguard Worker // Expected number of bytes from the responder. 41*61c4878aSAndroid Build Coastguard Worker uint32 read_size = 4; 42*61c4878aSAndroid Build Coastguard Worker} 43*61c4878aSAndroid Build Coastguard Worker 44*61c4878aSAndroid Build Coastguard Workermessage I2cReadResponse { 45*61c4878aSAndroid Build Coastguard Worker bytes value = 1; 46*61c4878aSAndroid Build Coastguard Worker} 47*61c4878aSAndroid Build Coastguard Worker 48*61c4878aSAndroid Build Coastguard Workerservice I2c { 49*61c4878aSAndroid Build Coastguard Worker // Enable access to I2C devices implementing register read/writes. 50*61c4878aSAndroid Build Coastguard Worker rpc I2cWrite(I2cWriteRequest) returns (I2cWriteResponse) {} 51*61c4878aSAndroid Build Coastguard Worker rpc I2cRead(I2cReadRequest) returns (I2cReadResponse) {} 52*61c4878aSAndroid Build Coastguard Worker} 53