From nobody Mon Sep 16 20:10:12 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+114061+1787277+3901457@groups.io; arc=fail (BodyHash is different from the expected one) Received: from mail02.groups.io (mail02.groups.io [66.175.222.108]) by mx.zohomail.com with SMTPS id 1705676244225814.9085756074534; Fri, 19 Jan 2024 06:57:24 -0800 (PST) Return-Path: DKIM-Signature: a=rsa-sha256; bh=+19XQniyFdkKNsIHprSXdBGvoBbF0505Cvc5L01ecbk=; c=relaxed/simple; d=groups.io; h=ARC-Seal:ARC-Message-Signature:ARC-Authentication-Results:Received-SPF:From:To:CC:Subject:Date:Message-ID:In-Reply-To:References:MIME-Version:Precedence:List-Subscribe:List-Help:Sender:List-Id:Mailing-List:Delivered-To:Reply-To:List-Unsubscribe-Post:List-Unsubscribe:Content-Transfer-Encoding:Content-Type; s=20140610; t=1705676243; v=1; b=H3pnpel7KsxKMdHCjn7AlmvRgFL450lrQ7juaRVc9jgPwN0u7AAocgRxv0w8mXt6g9aCuZxP +ey6z4x2qtyI8qev/e23S/ZxLj9FSKN5xETG5rrcqMPz23JwB0xlO745Rl2fhhtcaWt7Hj6ADcc S3waEOP7hEetujTsqD9cRPcU= X-Received: by 127.0.0.2 with SMTP id mGOVYY1788612xwtJ7pQKi2E; Fri, 19 Jan 2024 06:57:23 -0800 X-Received: from NAM12-BN8-obe.outbound.protection.outlook.com (NAM12-BN8-obe.outbound.protection.outlook.com [40.107.237.84]) by mx.groups.io with SMTP id smtpd.web11.5897.1705560711498702773 for ; Wed, 17 Jan 2024 22:51:51 -0800 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=CV/IhAuWPKKIfr0E6n3UPOqFqZl0I9+LYjpGB8wGBlX+z1PruD95yELCCRp0pMxBcf68Xz1nKiEKQoV9qm12+P9BGYEps1yvELhqDgbmhpW738Qrivk0/PDnko7OzVBlSA4n2pmYzT7CJ0ZbCZd6cL/P3316Xv1doAfggkBMxmFg2HOFe/HOaAWn8+eqEn0qCuTOV3olx12KkM24gaHUu2h6emhwvqE/wupWk52TrZli6m9YqDAmrmRO+AS0MvkHKb+YRK+E6tA2i62YrhpJf+x+iry9UC9cpnJkxBAGP/clS0UnsNMFmmGhcdNXrAs7uKRGvjm8yDL1HOeTmVmufw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=NruOB0ILlg6LkhL6esS2KXALyTWhJIuIwWgOSBaasVY=; b=hXS7PSgnXOE8fPF4K/drIVvUyEBmyZ/6nXKfAiJySlOg7Mxn+niCH1lF4MRZIW6xPnJ0BYN4SF0dHeBsBcvm+xlyOYxc3BWvpFbMgZG1wrmZ8i7x0pNFKevJ4VyZSJK82EJixOv8H2NKO6EjfEyQTQrzNog13zdOCQ6/ZErpaDG+Ii/FvDDkAHQY36D4lP8WTFtigUZ2DyFEHXyTHy/7DZjwpqOdEPZbj9Yl0K7XzGPTw9zVo+qArDQ8LA/muPL9MPDxLDWsF7tTRJI24XsDDzU5wDBcoRwvTfyPZ0fQjG/NeEE/tsTqK6XSpkkiAqXMD85vQV9tYsjuBgXkWelPOw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=edk2.groups.io smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none (0) X-Received: from CY5PR22CA0060.namprd22.prod.outlook.com (2603:10b6:930:1d::23) by LV3PR12MB9410.namprd12.prod.outlook.com (2603:10b6:408:212::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7202.23; Thu, 18 Jan 2024 06:51:48 +0000 X-Received: from CY4PEPF0000E9D8.namprd05.prod.outlook.com (2603:10b6:930:1d:cafe::db) by CY5PR22CA0060.outlook.office365.com (2603:10b6:930:1d::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7202.24 via Frontend Transport; Thu, 18 Jan 2024 06:51:48 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) client-ip=66.175.222.108; envelope-from=bounce+27952+114061+1787277+3901457@groups.io; helo=mail02.groups.io; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C X-Received: from SATLEXMB04.amd.com (165.204.84.17) by CY4PEPF0000E9D8.mail.protection.outlook.com (10.167.241.83) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7181.14 via Frontend Transport; Thu, 18 Jan 2024 06:51:48 +0000 X-Received: from SATLEXMB08.amd.com (10.181.40.132) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.34; Thu, 18 Jan 2024 00:51:46 -0600 X-Received: from SATLEXMB03.amd.com (10.181.40.144) by SATLEXMB08.amd.com (10.181.40.132) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.32; Wed, 17 Jan 2024 22:51:11 -0800 X-Received: from SHA-LX-MINGXZHA.amd.com (10.180.168.240) by SATLEXMB03.amd.com (10.181.40.144) with Microsoft SMTP Server id 15.1.2507.34 via Frontend Transport; Thu, 18 Jan 2024 00:51:10 -0600 From: "duke.zhai via groups.io" To: CC: Eric Xing , Ken Yao , Igniculus Fu , Abner Chang Subject: [edk2-devel] [PATCH 12/33] AMD/VanGoghBoard: Check in AMD BaseSerialPortLib Date: Thu, 18 Jan 2024 14:50:25 +0800 Message-ID: <20240118065046.961-13-duke.zhai@amd.com> In-Reply-To: <20240118065046.961-1-duke.zhai@amd.com> References: <20240118065046.961-1-duke.zhai@amd.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000E9D8:EE_|LV3PR12MB9410:EE_ X-MS-Office365-Filtering-Correlation-Id: 277b97b7-3a81-409a-3da9-08dc17f1f13c X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Message-Info: Mm3ggMGrgMcfy7+48x8no7P4hw+JpPNxwwb3ilmhzjUUuRVQjhrU5dFs4HXpF/tXq9YoFQDPpUGem7B+Jmt5tvFQbxiZF47G8WSny1zgB6+xfjrvpco62fTHcOZD0Al0+7lKFzAELN7/elDrRzim9uUAjf7HJgMhWOQ1qnSAOeojG8D2mvxfr5ovd+3gx/FaUG0gteJb2nfrOh0StOiux3od49kTvkFjC9zSmcNa6ZFMCdczwTLH0ef9dQrF3wIrYOMFdpNTWFS6ZHQqLiwY9qorYbIM21PbfJoYfdxZrsbbV8DDrDqdWFRYfePiO04qtbNg9wbVmemf0nd4h2JZeM/6fSCqY14q72x42EfyR2CB0qeH6x19tFXWOvBE5QHV7RAQw2lW7d1rmRP2gzT1RHRugwwp94VoV1t4PgDhRmAQSToPd7L5Lrl9SQhG+vMVkAP4GkLVMSk73NHM37n4xsu6szsoIVUnmlZHBa15QEargoGgUVrmrmoI7DCpfP3Vj2h7z9svTXO8G76iqxdVDMaNpKSNN+d+qVcTP/TLY/d29eK68kt28Eh+EukJNpcTv3YcobKvSudp6GeTYQrvboXljXO84sPxHZTgNkFSx3IDAr+FcTpftuaP/xIk+YbrOaVlt7KIOvyhkuXdx2nMRVvLDXQJCASPz7vha8PGFP4gswRkxYoSFKDQgXoWrZO8XOUErHgNObbdIDW9FwFpup1vS7m82dSfcWo2+DpOvnymXNyCpi4bWtMRAT0BHFhld1//UlSGw30Pkblq8yhb+g== X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Jan 2024 06:51:48.0488 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 277b97b7-3a81-409a-3da9-08dc17f1f13c X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: CY4PEPF0000E9D8.namprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: LV3PR12MB9410 Precedence: Bulk List-Subscribe: List-Help: Sender: devel@edk2.groups.io List-Id: Mailing-List: list devel@edk2.groups.io; contact devel+owner@edk2.groups.io Reply-To: devel@edk2.groups.io,duke.zhai@amd.com List-Unsubscribe-Post: List-Unsubscribe=One-Click List-Unsubscribe: X-Gm-Message-State: c6OgUVhvSGNHgcKqNPYXz50Ux1787277AA= Content-Transfer-Encoding: quoted-printable X-ZohoMail-DKIM: pass (identity @groups.io) X-ZM-MESSAGEID: 1705676244960100056 Content-Type: text/plain; charset="utf-8" From: Duke Zhai BZ #:4640 Initial FCH UART port for Serial log output. Chachani board uses this UART for outputting debug log. Signed-off-by: Duke Zhai Cc: Eric Xing Cc: Ken Yao Cc: Igniculus Fu Cc: Abner Chang --- .../BaseSerialPortLib16550AmdFchUart.c | 473 ++++++++++++++++++ .../BaseSerialPortLib16550AmdFchUart.inf | 49 ++ 2 files changed, 522 insertions(+) create mode 100644 Platform/AMD/VanGoghBoard/VanGoghCommonPkg/Library/Base= SerialPortLib16550AmdFchUart/BaseSerialPortLib16550AmdFchUart.c create mode 100644 Platform/AMD/VanGoghBoard/VanGoghCommonPkg/Library/Base= SerialPortLib16550AmdFchUart/BaseSerialPortLib16550AmdFchUart.inf diff --git a/Platform/AMD/VanGoghBoard/VanGoghCommonPkg/Library/BaseSerialP= ortLib16550AmdFchUart/BaseSerialPortLib16550AmdFchUart.c b/Platform/AMD/Van= GoghBoard/VanGoghCommonPkg/Library/BaseSerialPortLib16550AmdFchUart/BaseSer= ialPortLib16550AmdFchUart.c new file mode 100644 index 0000000000..cf97e4109d --- /dev/null +++ b/Platform/AMD/VanGoghBoard/VanGoghCommonPkg/Library/BaseSerialPortLib1= 6550AmdFchUart/BaseSerialPortLib16550AmdFchUart.c @@ -0,0 +1,473 @@ +/** @file + Implements BaseSerialPortLib16550AmdFchUart.c + + Copyright (C) 2024 Advanced Micro Devices, Inc. All rights reserved.
+ SPDX-License-Identifier: BSD-2-Clause-Patent + +**/ + +/* This file includes code originally published under the following licens= e. */ + +/** @file + 16550 UART Serial Port library functions + + (C) Copyright 2014 Hewlett-Packard Development Company, L.P.
+ Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.
+ Copyright (c) 2018, AMD Incorporated. All rights reserved.
+ Copyright (c) 2020, ARM Limited. All rights reserved. + + SPDX-License-Identifier: BSD-2-Clause-Patent + +**/ + +#include +#include +#include +#include +#include + +// +// 16550 UART register offsets and bitfields +// +#define R_UART_RXBUF 0 +#define R_UART_TXBUF 0 +#define R_UART_BAUD_LOW 0 +#define R_UART_BAUD_HIGH 1 +#define R_UART_FCR 2 +#define B_UART_FCR_FIFOE BIT0 +#define B_UART_FCR_FIFO64 BIT5 +#define R_UART_LCR 3 +#define B_UART_LCR_DLAB BIT7 +#define R_UART_MCR 4 +#define B_UART_MCR_RTS BIT1 +#define R_UART_LSR 5 +#define B_UART_LSR_RXRDY BIT0 +#define B_UART_LSR_TXRDY BIT5 +#define B_UART_LSR_TEMT BIT6 +#define R_UART_MSR 6 +#define B_UART_MSR_CTS BIT4 +#define B_UART_MSR_DSR BIT5 + +/** + Read an 8-bit 16550 register. The parameter Offset is added to the base= address of the + 16550 registers that is specified by PcdSerialRegisterBase. + @param Offset The offset of the 16550 register to read. + @return The value read from the 16550 register. +**/ +UINT8 +SerialPortReadRegister ( + UINTN Offset + ) +{ + return MmioRead8 ((UINTN)PcdGet64 (PcdSerialRegisterBase) + Offset * 4); +} + +/** + Write an 8-bit 16550 register. The parameter Offset is added to the base= address of the + 16550 registers that is specified by PcdSerialRegisterBase. + @param Offset The offset of the 16550 register to write. + @param Value The value to write to the 16550 register specified by Of= fset. + @return The value written to the 16550 register. +**/ +UINT8 +SerialPortWriteRegister ( + UINTN Offset, + UINT8 Value + ) +{ + return MmioWrite8 ((UINTN)PcdGet64 (PcdSerialRegisterBase) + Offset * 4,= Value); +} + +/** + Return whether the hardware flow control signal allows writing. + + @retval TRUE The serial port is writable. + @retval FALSE The serial port is not writable. +**/ +BOOLEAN +SerialPortWritable ( + VOID + ) +{ + if (PcdGetBool (PcdSerialUseHardwareFlowControl)) { + if (PcdGetBool (PcdSerialDetectCable)) { + // + // Wait for both DSR and CTS to be set + // DSR is set if a cable is connected. + // CTS is set if it is ok to transmit data + // + // DSR CTS Description Action + // =3D=3D=3D =3D=3D=3D =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D =3D=3D=3D=3D=3D=3D=3D=3D + // 0 0 No cable connected. Wait + // 0 1 No cable connected. Wait + // 1 0 Cable connected, but not clear to send. Wait + // 1 1 Cable connected, and clear to send. Transmit + // + return (BOOLEAN)((SerialPortReadRegister (R_UART_MSR) & (B_UART_MSR_= DSR | B_UART_MSR_CTS)) =3D=3D (B_UART_MSR_DSR | B_UART_MSR_CTS)); + } else { + // + // Wait for both DSR and CTS to be set OR for DSR to be clear. + // DSR is set if a cable is connected. + // CTS is set if it is ok to transmit data + // + // DSR CTS Description Action + // =3D=3D=3D =3D=3D=3D =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D =3D=3D=3D=3D=3D=3D=3D=3D + // 0 0 No cable connected. Transmit + // 0 1 No cable connected. Transmit + // 1 0 Cable connected, but not clear to send. Wait + // 1 1 Cable connected, and clar to send. Transmit + // + return (BOOLEAN)((SerialPortReadRegister (R_UART_MSR) & (B_UART_MSR_= DSR | B_UART_MSR_CTS)) !=3D (B_UART_MSR_DSR)); + } + } + + return TRUE; +} + +/** + RCheck Cable connection. + + @retval TRUE RCheck Cable not connect. + @retval FALSE RCheck Cable connect. +**/ +BOOLEAN +CheckCableConnection ( + ) +{ + UINT32 RetryCount; + + // Check Cable connection + RetryCount =3D 200; + if (PcdGetBool (PcdSerialDetectCable)) { + do { + RetryCount--; + } while (((SerialPortReadRegister (R_UART_MSR) & (B_UART_MSR_DSR | B_U= ART_MSR_CTS)) !=3D (B_UART_MSR_DSR | B_UART_MSR_CTS)) && (RetryCount > 0)); + } + + if (RetryCount =3D=3D 0) { + // Time expired + return FALSE; + } + + return TRUE; +} + +/** + Check Serial Port status. + + @retval TRUE The serial port is enable. + @retval FALSE The serial port is not enable. +**/ +BOOLEAN +CheckSerialPort ( + ) +{ + UINTN Divisor; + UINT32 SerialClkDiv16; + + SerialClkDiv16 =3D 48000000/ 16; + // + // See if the serial port is already initialized + // + if ((SerialPortReadRegister (R_UART_FCR) & (B_UART_FCR_FIFOE | B_UART_FC= R_FIFO64)) !=3D + (PcdGet8 (PcdSerialFifoControl) & (B_UART_FCR_FIFOE | B_UART_FC= R_FIFO64))) + { + return FALSE; + } + + if ((SerialPortReadRegister (R_UART_LCR) & 0x3F) !=3D (PcdGet8 (PcdSeria= lLineControl) & 0x3F)) { + return FALSE; + } + + SerialPortWriteRegister (R_UART_LCR, (UINT8)(SerialPortReadRegister (R_U= ART_LCR) | B_UART_LCR_DLAB)); + Divisor =3D SerialPortReadRegister (R_UART_BAUD_HIGH) << 8; + Divisor |=3D SerialPortReadRegister (R_UART_BAUD_LOW); + SerialPortWriteRegister (R_UART_LCR, (UINT8)(SerialPortReadRegister (R_U= ART_LCR) & ~B_UART_LCR_DLAB)); + if (Divisor !=3D SerialClkDiv16 / PcdGet32 (PcdSerialBaudRate)) { + return FALSE; + } + + return TRUE; +} + +/** + Initial Serial Port. + +**/ +VOID +InitSerialPort ( + ) +{ + UINTN Divisor; + UINT32 SerialClkDiv16; + + SerialClkDiv16 =3D 48000000 / 16; + // + // Configure baud rate + // + Divisor =3D SerialClkDiv16 / PcdGet32 (PcdSerialBaudRate); + SerialPortWriteRegister (R_UART_LCR, B_UART_LCR_DLAB); + SerialPortWriteRegister (R_UART_BAUD_HIGH, (UINT8)(Divisor >> 8)); + SerialPortWriteRegister (R_UART_BAUD_LOW, (UINT8)(Divisor & 0xff)); + + // + // Clear DLAB and configure Data Bits, Parity, and Stop Bits. + // Strip reserved bits from PcdSerialLineControl + // + SerialPortWriteRegister (R_UART_LCR, (UINT8)(PcdGet8 (PcdSerialLineContr= ol) & 0x3F)); + + // + // Enable and reset FIFOs + // Strip reserved bits from PcdSerialFifoControl + // + SerialPortWriteRegister (R_UART_FCR, (UINT8)(PcdGet8 (PcdSerialFifoContr= ol) & 0x27)); + + // + // Put Modem Control Register(MCR) into its reset state of 0x00. + // + SerialPortWriteRegister (R_UART_MCR, 0x00); +} + +/** + Initialize the serial device hardware. + + If no initialization is required, then return RETURN_SUCCESS. + If the serial device was successfully initialized, then return RETURN_SU= CCESS. + If the serial device could not be initialized, then return RETURN_DEVICE= _ERROR. + + @retval RETURN_SUCCESS The serial device was initialized. + @retval RETURN_DEVICE_ERROR The serial device could not be initialized. + +**/ +RETURN_STATUS +EFIAPI +SerialPortInitialize ( + VOID + ) +{ + RETURN_STATUS Status; + + Status =3D PlatformHookSerialPortInitialize (); + if (RETURN_ERROR (Status)) { + return Status; + } + + if (!CheckCableConnection ()) { + return RETURN_DEVICE_ERROR; + } + + if (!CheckSerialPort ()) { + InitSerialPort (); + } + + return RETURN_SUCCESS; +} + +/** + Write data from buffer to serial device. + + Writes NumberOfBytes data bytes from Buffer to the serial device. + The number of bytes actually written to the serial device is returned. + If the return value is less than NumberOfBytes, then the write operation= failed. + + If Buffer is NULL, then ASSERT(). + + If NumberOfBytes is zero, then return 0. + + @param Buffer Pointer to the data buffer to be written. + @param NumberOfBytes Number of bytes to written to the serial device. + + @retval 0 NumberOfBytes is 0. + @retval >0 The number of bytes written to the serial devic= e. + If this value is less than NumberOfBytes, then = the read operation failed. + +**/ +UINTN +EFIAPI +SerialPortWrite ( + IN UINT8 *Buffer, + IN UINTN NumberOfBytes + ) +{ + UINTN Result; + UINTN Index; + UINTN FifoSize; + UINT32 RetryCount; + + if (Buffer =3D=3D NULL) { + return 0; + } + + if (!CheckCableConnection ()) { + return 0; + } + + if (NumberOfBytes =3D=3D 0) { + // + // Flush the hardware + // + + // + // Wait for both the transmit FIFO and shift register empty. + // + RetryCount =3D 2000; + do { + RetryCount--; + } while (((SerialPortReadRegister (R_UART_LSR) & B_UART_LSR_TEMT) =3D= =3D 0) && (RetryCount > 0)); + + if (RetryCount =3D=3D 0) { + InitSerialPort (); + } + + // + // Wait for the hardware flow control signal + // + while (!SerialPortWritable ()) { + } + + return 0; + } + + // + // Compute the maximum size of the Tx FIFO + // + FifoSize =3D 1; + if ((PcdGet8 (PcdSerialFifoControl) & B_UART_FCR_FIFOE) !=3D 0) { + if ((PcdGet8 (PcdSerialFifoControl) & B_UART_FCR_FIFO64) =3D=3D 0) { + FifoSize =3D 16; + } else { + FifoSize =3D 64; + } + } + + Result =3D NumberOfBytes; + while (NumberOfBytes !=3D 0) { + // + // Wait for the serial port to be ready, to make sure both the transmi= t FIFO + // and shift register empty. + // + RetryCount =3D 2000; + do { + RetryCount--; + } while (((SerialPortReadRegister (R_UART_LSR) & B_UART_LSR_TEMT) =3D= =3D 0) && (RetryCount > 0)); + + if (RetryCount =3D=3D 0) { + InitSerialPort (); + } + + // + // Fill then entire Tx FIFO + // + for (Index =3D 0; Index < FifoSize && NumberOfBytes !=3D 0; Index++, N= umberOfBytes--, Buffer++) { + // + // Wait for the hardware flow control signal + // + while (!SerialPortWritable ()) { + } + + // + // Write byte to the transmit buffer. + // + SerialPortWriteRegister (R_UART_TXBUF, *Buffer); + } + } + + return Result; +} + +/** + Reads data from a serial device into a buffer. + + @param Buffer Pointer to the data buffer to store the data re= ad from the serial device. + @param NumberOfBytes Number of bytes to read from the serial device. + + @retval 0 NumberOfBytes is 0. + @retval >0 The number of bytes read from the serial device. + If this value is less than NumberOfBytes, then = the read operation failed. + +**/ +UINTN +EFIAPI +SerialPortRead ( + OUT UINT8 *Buffer, + IN UINTN NumberOfBytes + ) +{ + UINTN Result; + UINT8 Mcr; + + if (NULL =3D=3D Buffer) { + return 0; + } + + Mcr =3D (UINT8)(SerialPortReadRegister (R_UART_MCR) & ~B_UART_MCR_RTS); + + for (Result =3D 0; NumberOfBytes-- !=3D 0; Result++, Buffer++) { + // + // Wait for the serial port to have some data. + // + while ((SerialPortReadRegister (R_UART_LSR) & B_UART_LSR_RXRDY) =3D=3D= 0) { + if (PcdGetBool (PcdSerialUseHardwareFlowControl)) { + // + // Set RTS to let the peer send some data + // + SerialPortWriteRegister (R_UART_MCR, (UINT8)(Mcr | B_UART_MCR_RTS)= ); + } + } + + if (PcdGetBool (PcdSerialUseHardwareFlowControl)) { + // + // Clear RTS to prevent peer from sending data + // + SerialPortWriteRegister (R_UART_MCR, Mcr); + } + + // + // Read byte from the receive buffer. + // + *Buffer =3D SerialPortReadRegister (R_UART_RXBUF); + } + + return Result; +} + +/** + Polls a serial device to see if there is any data waiting to be read. + + Polls aserial device to see if there is any data waiting to be read. + If there is data waiting to be read from the serial device, then TRUE is= returned. + If there is no data waiting to be read from the serial device, then FALS= E is returned. + + @retval TRUE Data is waiting to be read from the serial devi= ce. + @retval FALSE There is no data waiting to be read from the se= rial device. + +**/ +BOOLEAN +EFIAPI +SerialPortPoll ( + VOID + ) +{ + // + // Read the serial port status + // + if ((SerialPortReadRegister (R_UART_LSR) & B_UART_LSR_RXRDY) !=3D 0) { + if (PcdGetBool (PcdSerialUseHardwareFlowControl)) { + // + // Clear RTS to prevent peer from sending data + // + SerialPortWriteRegister (R_UART_MCR, (UINT8)(SerialPortReadRegister = (R_UART_MCR) & ~B_UART_MCR_RTS)); + } + + return TRUE; + } + + if (PcdGetBool (PcdSerialUseHardwareFlowControl)) { + // + // Set RTS to let the peer send some data + // + SerialPortWriteRegister (R_UART_MCR, (UINT8)(SerialPortReadRegister (R= _UART_MCR) | B_UART_MCR_RTS)); + } + + return FALSE; +} diff --git a/Platform/AMD/VanGoghBoard/VanGoghCommonPkg/Library/BaseSerialP= ortLib16550AmdFchUart/BaseSerialPortLib16550AmdFchUart.inf b/Platform/AMD/V= anGoghBoard/VanGoghCommonPkg/Library/BaseSerialPortLib16550AmdFchUart/BaseS= erialPortLib16550AmdFchUart.inf new file mode 100644 index 0000000000..e0eb5c0caf --- /dev/null +++ b/Platform/AMD/VanGoghBoard/VanGoghCommonPkg/Library/BaseSerialPortLib1= 6550AmdFchUart/BaseSerialPortLib16550AmdFchUart.inf @@ -0,0 +1,49 @@ +## @file +# Platform SerialPortLib +# +# Copyright (C) 2024 Advanced Micro Devices, Inc. All rights reserved.
+# SPDX-License-Identifier: BSD-2-Clause-Patent +# +## + +#This file includes code originally published under the following license. + +## @file +# SerialPortLib instance for 16550 UART. +# +# Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.
+# Copyright (c) 2020, ARM Limited. All rights reserved. +# +# SPDX-License-Identifier: BSD-2-Clause-Patent +# +## + +[Defines] + INF_VERSION =3D 0x00010005 + BASE_NAME =3D BaseSerialPortLib16550AmdFchUart + FILE_GUID =3D A66281AD-66E9-4089-9B1C-9CFC84D8A760 + MODULE_TYPE =3D BASE + VERSION_STRING =3D 1.0 + LIBRARY_CLASS =3D SerialPortLib + +[Sources] + BaseSerialPortLib16550AmdFchUart.c + +[Packages] + MdePkg/MdePkg.dec + MdeModulePkg/MdeModulePkg.dec + VanGoghCommonPkg/AmdCommonPkg.dec + +[LibraryClasses] + BaseLib + PcdLib + IoLib + PlatformHookLib + +[Pcd] + gEfiMdeModulePkgTokenSpaceGuid.PcdSerialUseHardwareFlowControl + gEfiMdeModulePkgTokenSpaceGuid.PcdSerialDetectCable + gEfiMdeModulePkgTokenSpaceGuid.PcdSerialRegisterBase + gEfiMdeModulePkgTokenSpaceGuid.PcdSerialBaudRate + gEfiMdeModulePkgTokenSpaceGuid.PcdSerialLineControl + gEfiMdeModulePkgTokenSpaceGuid.PcdSerialFifoControl \ No newline at end of file -- 2.31.1 -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#114061): https://edk2.groups.io/g/devel/message/114061 Mute This Topic: https://groups.io/mt/103831173/1787277 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [importer@patchew.org] -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-