19d4fa1a1SMauro Carvalho Chehab /* 29d4fa1a1SMauro Carvalho Chehab * Support for Intel Camera Imaging ISP subsystem. 39d4fa1a1SMauro Carvalho Chehab * Copyright (c) 2015, Intel Corporation. 49d4fa1a1SMauro Carvalho Chehab * 59d4fa1a1SMauro Carvalho Chehab * This program is free software; you can redistribute it and/or modify it 69d4fa1a1SMauro Carvalho Chehab * under the terms and conditions of the GNU General Public License, 79d4fa1a1SMauro Carvalho Chehab * version 2, as published by the Free Software Foundation. 89d4fa1a1SMauro Carvalho Chehab * 99d4fa1a1SMauro Carvalho Chehab * This program is distributed in the hope it will be useful, but WITHOUT 109d4fa1a1SMauro Carvalho Chehab * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 119d4fa1a1SMauro Carvalho Chehab * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 129d4fa1a1SMauro Carvalho Chehab * more details. 139d4fa1a1SMauro Carvalho Chehab */ 149d4fa1a1SMauro Carvalho Chehab 159d4fa1a1SMauro Carvalho Chehab #ifndef __GP_DEVICE_PUBLIC_H_INCLUDED__ 169d4fa1a1SMauro Carvalho Chehab #define __GP_DEVICE_PUBLIC_H_INCLUDED__ 179d4fa1a1SMauro Carvalho Chehab 18f90e73ceSMauro Carvalho Chehab #include "system_local.h" 199d4fa1a1SMauro Carvalho Chehab 209d4fa1a1SMauro Carvalho Chehab typedef struct gp_device_state_s gp_device_state_t; 219d4fa1a1SMauro Carvalho Chehab 229d4fa1a1SMauro Carvalho Chehab /*! Read the state of GP_DEVICE[ID] 239d4fa1a1SMauro Carvalho Chehab 249d4fa1a1SMauro Carvalho Chehab \param ID[in] GP_DEVICE identifier 259d4fa1a1SMauro Carvalho Chehab \param state[out] gp device state structure 269d4fa1a1SMauro Carvalho Chehab 279d4fa1a1SMauro Carvalho Chehab \return none, state = GP_DEVICE[ID].state 289d4fa1a1SMauro Carvalho Chehab */ 299d4fa1a1SMauro Carvalho Chehab void gp_device_get_state( 309d4fa1a1SMauro Carvalho Chehab const gp_device_ID_t ID, 319d4fa1a1SMauro Carvalho Chehab gp_device_state_t *state); 329d4fa1a1SMauro Carvalho Chehab 339d4fa1a1SMauro Carvalho Chehab /*! Write to a control register of GP_DEVICE[ID] 349d4fa1a1SMauro Carvalho Chehab 359d4fa1a1SMauro Carvalho Chehab \param ID[in] GP_DEVICE identifier 369d4fa1a1SMauro Carvalho Chehab \param reg_addr[in] register byte address 379d4fa1a1SMauro Carvalho Chehab \param value[in] The data to be written 389d4fa1a1SMauro Carvalho Chehab 399d4fa1a1SMauro Carvalho Chehab \return none, GP_DEVICE[ID].ctrl[reg] = value 409d4fa1a1SMauro Carvalho Chehab */ 419d4fa1a1SMauro Carvalho Chehab STORAGE_CLASS_GP_DEVICE_H void gp_device_reg_store( 429d4fa1a1SMauro Carvalho Chehab const gp_device_ID_t ID, 439d4fa1a1SMauro Carvalho Chehab const unsigned int reg_addr, 449d4fa1a1SMauro Carvalho Chehab const hrt_data value); 459d4fa1a1SMauro Carvalho Chehab 469d4fa1a1SMauro Carvalho Chehab /*! Read from a control register of GP_DEVICE[ID] 479d4fa1a1SMauro Carvalho Chehab 489d4fa1a1SMauro Carvalho Chehab \param ID[in] GP_DEVICE identifier 499d4fa1a1SMauro Carvalho Chehab \param reg_addr[in] register byte address 509d4fa1a1SMauro Carvalho Chehab \param value[in] The data to be written 519d4fa1a1SMauro Carvalho Chehab 529d4fa1a1SMauro Carvalho Chehab \return GP_DEVICE[ID].ctrl[reg] 539d4fa1a1SMauro Carvalho Chehab */ 549d4fa1a1SMauro Carvalho Chehab STORAGE_CLASS_GP_DEVICE_H hrt_data gp_device_reg_load( 559d4fa1a1SMauro Carvalho Chehab const gp_device_ID_t ID, 569d4fa1a1SMauro Carvalho Chehab const hrt_address reg_addr); 579d4fa1a1SMauro Carvalho Chehab 589d4fa1a1SMauro Carvalho Chehab #endif /* __GP_DEVICE_PUBLIC_H_INCLUDED__ */ 59