1 /** 2 * Copyright © 2016 Google Inc. 3 * Copyright © 2016 IBM Corporation 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); 6 * you may not use this file except in compliance with the License. 7 * You may obtain a copy of the License at 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 */ 17 18 #ifndef __GPIO_CONFIGS_H__ 19 #define __GPIO_CONFIGS_H__ 20 21 #include <stddef.h> 22 #include <glib.h> 23 #include "gpio.h" 24 25 typedef struct PowerGpio { 26 /* Optional active high pin enabling writes to latched power_up pins. */ 27 GPIO latch_out; /* NULL name if not used. */ 28 /* Active high pin that is asserted following successful host power up. */ 29 GPIO power_good_in; 30 /* Selectable polarity pins enabling host power rails. */ 31 size_t num_power_up_outs; 32 GPIO *power_up_outs; 33 /* TRUE for active high */ 34 gboolean *power_up_pols; 35 /* Selectable polarity pins holding system complexes in reset. */ 36 size_t num_reset_outs; 37 GPIO *reset_outs; 38 /* TRUE for active high */ 39 gboolean *reset_pols; 40 size_t num_pci_reset_outs; 41 GPIO *pci_reset_outs; 42 /* TRUE for active high */ 43 gboolean *pci_reset_pols; 44 gboolean *pci_reset_holds; 45 } PowerGpio; 46 47 typedef struct GpioConfigs { 48 PowerGpio power_gpio; 49 } GpioConfigs; 50 51 /* Read system configuration for GPIOs. */ 52 gboolean read_gpios(GpioConfigs *gpios); 53 /* Frees internal buffers. Does not free parameter. Does not close GPIOs. */ 54 void free_gpios(GpioConfigs *gpios); 55 56 #endif 57