b895207489
This PR adds the driver for Allwinner A64's MIPI Display Serial Interface (DSI) and MIPI Display Physical Layer (D-PHY). This driver will be used by the upcoming Display Driver for PINE64 PinePhone. - `include/nuttx/crc16.h`: Added 16-bit CRC-CCITT - `libs/libc/misc/Make.defs`: Added 16-bit CRC-CCITT to Makefile - `arch/arm64/src/a64/Kconfig`: Added the Kconfig option for "A64 Peripheral Selection > MIPI DSI" (`CONFIG_A64_MIPI_DSI`), which enables the MIPI DSI Driver - `arch/arm64/src/a64/hardware/a64_memorymap.h`: Added the Base Address for MIPI DSI - `arch/arm64/src/a64/Make.defs`: Added the MIPI DSI Driver to the Makefile - `libs/libc/misc/lib_crc16ccitt.c`: Compute 16-bit CRC-CCITT - `arch/arm64/src/a64/mipi_dsi.c`, `mipi_dsi.h`: Compose MIPI DSI Packets (Long, Short, Short with Parameter) - `arch/arm64/src/a64/a64_mipi_dsi.c`, `a64_mipi_dsi.h`: MIPI DSI Driver for Allwinner A64 - `arch/arm64/src/a64/a64_mipi_dphy.c`, `a64_mipi_dphy.h`: MIPI D-PHY Driver for Allwinner A64 - `platforms/arm/a64/boards/pinephone/index.rst`: Added MIPI DSI as supported peripheral for PinePhone Co-Authored-By: Petro Karashchenko <petro.karashchenko@gmail.com>
100 lines
3.3 KiB
C
100 lines
3.3 KiB
C
/****************************************************************************
|
|
* include/nuttx/crc16.h
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership. The
|
|
* ASF licenses this file to you 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 __INCLUDE_NUTTX_CRC16_H
|
|
#define __INCLUDE_NUTTX_CRC16_H
|
|
|
|
/****************************************************************************
|
|
* Included Files
|
|
****************************************************************************/
|
|
|
|
#include <sys/types.h>
|
|
#include <stdint.h>
|
|
|
|
/****************************************************************************
|
|
* Pre-processor Definitions
|
|
****************************************************************************/
|
|
|
|
/* Append full suffix to avoid the penitential symbol collision */
|
|
|
|
#define crc16 crc16full
|
|
|
|
/****************************************************************************
|
|
* Public Function Prototypes
|
|
****************************************************************************/
|
|
|
|
#ifdef __cplusplus
|
|
#define EXTERN extern "C"
|
|
extern "C"
|
|
{
|
|
#else
|
|
#define EXTERN extern
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: crc16part
|
|
*
|
|
* Description:
|
|
* Continue CRC calculation on a part of the buffer.
|
|
*
|
|
****************************************************************************/
|
|
|
|
uint16_t crc16part(FAR const uint8_t *src, size_t len, uint16_t crc16val);
|
|
|
|
/****************************************************************************
|
|
* Name: crc16
|
|
*
|
|
* Description:
|
|
* Return a 16-bit CRC of the contents of the 'src' buffer, length 'len'
|
|
*
|
|
****************************************************************************/
|
|
|
|
uint16_t crc16(FAR const uint8_t *src, size_t len);
|
|
|
|
/****************************************************************************
|
|
* Name: crc16ccittpart
|
|
*
|
|
* Description:
|
|
* Continue 16-bit CRC-CCITT calculation on a part of the buffer using the
|
|
* polynomial x^16+x^12+x^5+1.
|
|
*
|
|
****************************************************************************/
|
|
|
|
uint16_t crc16ccittpart(FAR const uint8_t *src, size_t len,
|
|
uint16_t crc16val);
|
|
|
|
/****************************************************************************
|
|
* Name: crc16ccitt
|
|
*
|
|
* Description:
|
|
* Return a 16-bit CRC-CCITT of the contents of the 'src' buffer, length
|
|
* 'len' using the polynomial x^16+x^12+x^5+1.
|
|
*
|
|
****************************************************************************/
|
|
|
|
uint16_t crc16ccitt(FAR const uint8_t *src, size_t len);
|
|
|
|
#undef EXTERN
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __INCLUDE_NUTTX_CRC16_H */
|