blob: d462eb57e948c80b8371678cd7c1f54532a7f3f4 [file] [log] [blame] [edit]
/**
* Copyright © 2016 Google Inc.
* Copyright © 2016 IBM Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __GPIO_CONFIGS_H__
#define __GPIO_CONFIGS_H__
#include <stddef.h>
#include <glib.h>
#include "gpio.h"
typedef struct PowerGpio {
/* Optional active high pin enabling writes to latched power_up pins. */
GPIO latch_out; /* NULL name if not used. */
/* Active high pin that is asserted following successful host power up. */
GPIO power_good_in;
/* Selectable polarity pins enabling host power rails. */
size_t num_power_up_outs;
GPIO *power_up_outs;
/* TRUE for active high */
gboolean *power_up_pols;
/* Selectable polarity pins holding system complexes in reset. */
size_t num_reset_outs;
GPIO *reset_outs;
/* TRUE for active high */
gboolean *reset_pols;
size_t num_pci_reset_outs;
GPIO *pci_reset_outs;
/* TRUE for active high */
gboolean *pci_reset_pols;
gboolean *pci_reset_holds;
} PowerGpio;
typedef struct GpioConfigs {
PowerGpio power_gpio;
} GpioConfigs;
/* Read system configuration for GPIOs. */
gboolean read_gpios(GpioConfigs *gpios);
/* Frees internal buffers. Does not free parameter. Does not close GPIOs. */
void free_gpios(GpioConfigs *gpios);
#endif