This reverts commit438ada5aa5
, reapplying05a5379458
. Note that the commit now being reverted is technically correct; the only reason we're reverting it is because it should not have been pushed past the Soft Feature Freeze for the edk2-stable201811 tag. Cc: Anthony Perard <anthony.perard@citrix.com> Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org> Cc: Jordan Justen <jordan.l.justen@intel.com> Cc: Julien Grall <julien.grall@linaro.org> Cc: Philippe Mathieu-Daudé <philmd@redhat.com> Cc: yuchenlin <yuchenlin@synology.com> Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=1319 Signed-off-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Acked-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Reviewed-by: yuchenlin <yuchenlin@synology.com>
67 lines
1.8 KiB
C
67 lines
1.8 KiB
C
/** @file
|
|
Unaligned port I/O dummy implementation for platforms which do not support it.
|
|
|
|
Copyright (c) 2017, Phil Dennis-Jordan.<BR>
|
|
This program and the accompanying materials are licensed and made available
|
|
under the terms and conditions of the BSD License which accompanies this
|
|
distribution. The full text of the license may be found at
|
|
http://opensource.org/licenses/bsd-license.php.
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
**/
|
|
|
|
|
|
#include <Library/DebugLib.h>
|
|
#include "UnalignedIoInternal.h"
|
|
|
|
/**
|
|
Performs a 32-bit write to the specified, possibly unaligned I/O-type
|
|
address.
|
|
|
|
Writes the 32-bit I/O port specified by Port with the value specified by
|
|
Value and returns Value. This function must guarantee that all I/O read and
|
|
write operations are serialized.
|
|
|
|
If 32-bit unaligned I/O port operations are not supported, then ASSERT().
|
|
|
|
@param[in] Port I/O port address
|
|
@param[in] Value 32-bit word to write
|
|
|
|
@return The value written to the I/O port.
|
|
|
|
**/
|
|
UINT32
|
|
UnalignedIoWrite32 (
|
|
IN UINTN Port,
|
|
IN UINT32 Value
|
|
)
|
|
{
|
|
ASSERT (FALSE);
|
|
return Value;
|
|
}
|
|
|
|
/**
|
|
Reads a 32-bit word from the specified, possibly unaligned I/O-type address.
|
|
|
|
Reads the 32-bit I/O port specified by Port. The 32-bit read value is
|
|
returned. This function must guarantee that all I/O read and write operations
|
|
are serialized.
|
|
|
|
If 32-bit unaligned I/O port operations are not supported, then ASSERT().
|
|
|
|
@param[in] Port The I/O port to read.
|
|
|
|
@return The value read.
|
|
|
|
**/
|
|
UINT32
|
|
UnalignedIoRead32 (
|
|
IN UINTN Port
|
|
)
|
|
{
|
|
ASSERT (FALSE);
|
|
return 0;
|
|
}
|