162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Virtual EISA root driver.
462306a36Sopenharmony_ci * Acts as a placeholder if we don't have a proper EISA bridge.
562306a36Sopenharmony_ci *
662306a36Sopenharmony_ci * (C) 2003 Marc Zyngier <maz@wild-wind.fr.eu.org>
762306a36Sopenharmony_ci * modified for SNI usage by Thomas Bogendoerfer
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include <linux/kernel.h>
1162306a36Sopenharmony_ci#include <linux/platform_device.h>
1262306a36Sopenharmony_ci#include <linux/eisa.h>
1362306a36Sopenharmony_ci#include <linux/init.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci/* The default EISA device parent (virtual root device).
1662306a36Sopenharmony_ci * Now use a platform device, since that's the obvious choice. */
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_cistatic struct platform_device eisa_root_dev = {
1962306a36Sopenharmony_ci	.name = "eisa",
2062306a36Sopenharmony_ci	.id   = 0,
2162306a36Sopenharmony_ci};
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_cistatic struct eisa_root_device eisa_bus_root = {
2462306a36Sopenharmony_ci	.dev	       = &eisa_root_dev.dev,
2562306a36Sopenharmony_ci	.bus_base_addr = 0,
2662306a36Sopenharmony_ci	.res	       = &ioport_resource,
2762306a36Sopenharmony_ci	.slots	       = EISA_MAX_SLOTS,
2862306a36Sopenharmony_ci	.dma_mask      = 0xffffffff,
2962306a36Sopenharmony_ci	.force_probe   = 1,
3062306a36Sopenharmony_ci};
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ciint __init sni_eisa_root_init(void)
3362306a36Sopenharmony_ci{
3462306a36Sopenharmony_ci	int r;
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci	r = platform_device_register(&eisa_root_dev);
3762306a36Sopenharmony_ci	if (!r)
3862306a36Sopenharmony_ci		return r;
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci	dev_set_drvdata(&eisa_root_dev.dev, &eisa_bus_root);
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci	if (eisa_root_register(&eisa_bus_root)) {
4362306a36Sopenharmony_ci		/* A real bridge may have been registered before
4462306a36Sopenharmony_ci		 * us. So quietly unregister. */
4562306a36Sopenharmony_ci		platform_device_unregister(&eisa_root_dev);
4662306a36Sopenharmony_ci		return -1;
4762306a36Sopenharmony_ci	}
4862306a36Sopenharmony_ci	return 0;
4962306a36Sopenharmony_ci}
50