162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0+ */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * PCI Hot Plug Controller Driver for RPA-compliant PPC64 platform.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2003 Linda Xie <lxie@us.ibm.com>
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * All rights reserved.
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Send feedback to <lxie@us.ibm.com>,
1062306a36Sopenharmony_ci *
1162306a36Sopenharmony_ci */
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#ifndef _PPC64PHP_H
1462306a36Sopenharmony_ci#define _PPC64PHP_H
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci#include <linux/pci.h>
1762306a36Sopenharmony_ci#include <linux/pci_hotplug.h>
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci#define DR_INDICATOR 9002
2062306a36Sopenharmony_ci#define DR_ENTITY_SENSE 9003
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci#define POWER_ON	100
2362306a36Sopenharmony_ci#define POWER_OFF	0
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci#define LED_OFF		0
2662306a36Sopenharmony_ci#define LED_ON		1	/* continuous on */
2762306a36Sopenharmony_ci#define LED_ID		2	/* slow blinking */
2862306a36Sopenharmony_ci#define LED_ACTION	3	/* fast blinking */
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci/* Sensor values from rtas_get-sensor */
3162306a36Sopenharmony_ci#define EMPTY           0	/* No card in slot */
3262306a36Sopenharmony_ci#define PRESENT         1	/* Card in slot */
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci#define MY_NAME "rpaphp"
3562306a36Sopenharmony_ciextern bool rpaphp_debug;
3662306a36Sopenharmony_ci#define dbg(format, arg...)					\
3762306a36Sopenharmony_ci	do {							\
3862306a36Sopenharmony_ci		if (rpaphp_debug)				\
3962306a36Sopenharmony_ci			printk(KERN_DEBUG "%s: " format,	\
4062306a36Sopenharmony_ci				MY_NAME, ## arg);		\
4162306a36Sopenharmony_ci	} while (0)
4262306a36Sopenharmony_ci#define err(format, arg...) printk(KERN_ERR "%s: " format, MY_NAME, ## arg)
4362306a36Sopenharmony_ci#define info(format, arg...) printk(KERN_INFO "%s: " format, MY_NAME, ## arg)
4462306a36Sopenharmony_ci#define warn(format, arg...) printk(KERN_WARNING "%s: " format, MY_NAME, ## arg)
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci/* slot states */
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci#define	NOT_VALID	3
4962306a36Sopenharmony_ci#define	NOT_CONFIGURED	2
5062306a36Sopenharmony_ci#define	CONFIGURED	1
5162306a36Sopenharmony_ci#define	EMPTY		0
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci/* DRC constants */
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci#define MAX_DRC_NAME_LEN 64
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci/*
5862306a36Sopenharmony_ci * struct slot - slot information for each *physical* slot
5962306a36Sopenharmony_ci */
6062306a36Sopenharmony_cistruct slot {
6162306a36Sopenharmony_ci	struct list_head rpaphp_slot_list;
6262306a36Sopenharmony_ci	int state;
6362306a36Sopenharmony_ci	u32 index;
6462306a36Sopenharmony_ci	u32 type;
6562306a36Sopenharmony_ci	u32 power_domain;
6662306a36Sopenharmony_ci	u8 attention_status;
6762306a36Sopenharmony_ci	char *name;
6862306a36Sopenharmony_ci	struct device_node *dn;
6962306a36Sopenharmony_ci	struct pci_bus *bus;
7062306a36Sopenharmony_ci	struct list_head *pci_devs;
7162306a36Sopenharmony_ci	struct hotplug_slot hotplug_slot;
7262306a36Sopenharmony_ci};
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ciextern const struct hotplug_slot_ops rpaphp_hotplug_slot_ops;
7562306a36Sopenharmony_ciextern struct list_head rpaphp_slot_head;
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_cistatic inline struct slot *to_slot(struct hotplug_slot *hotplug_slot)
7862306a36Sopenharmony_ci{
7962306a36Sopenharmony_ci	return container_of(hotplug_slot, struct slot, hotplug_slot);
8062306a36Sopenharmony_ci}
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ci/* function prototypes */
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_ci/* rpaphp_pci.c */
8562306a36Sopenharmony_ciint rpaphp_enable_slot(struct slot *slot);
8662306a36Sopenharmony_ciint rpaphp_get_sensor_state(struct slot *slot, int *state);
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci/* rpaphp_core.c */
8962306a36Sopenharmony_ciint rpaphp_add_slot(struct device_node *dn);
9062306a36Sopenharmony_ciint rpaphp_check_drc_props(struct device_node *dn, char *drc_name,
9162306a36Sopenharmony_ci		char *drc_type);
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci/* rpaphp_slot.c */
9462306a36Sopenharmony_civoid dealloc_slot_struct(struct slot *slot);
9562306a36Sopenharmony_cistruct slot *alloc_slot_struct(struct device_node *dn, int drc_index, char *drc_name, int power_domain);
9662306a36Sopenharmony_ciint rpaphp_register_slot(struct slot *slot);
9762306a36Sopenharmony_ciint rpaphp_deregister_slot(struct slot *slot);
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci#endif				/* _PPC64PHP_H */
100