[PATCH v4 0/4] mailbox: hisilicon: add Hi6220 mailbox driver

From: Leo Yan
Date: Mon Oct 12 2015 - 12:32:44 EST


Hi6220 mailbox supports up to 32 channels. Each channel is unidirectional
with a maximum message size of 8 words. I/O is performed using register
access (there is no DMA) and the cell raises an interrupt when messages
are received.

This patch series is to implement Hi6220 mailbox driver. It registers
two channels into framework for communication with MCU, one is tx channel
and another is rx channel. Now mailbox driver is used to send message to
MCU to control dynamic voltage and frequency scaling for CPU, GPU and DDR.

Changes from v3:
* The patch series for enabling idle state for Hi6220 has reserved memory
regions, so this series will not include it anymore
* Refined mailbox driver according to Jassi's suggestion;
Removed kfifo from mailbox driver;
Removed spinlock for ipc registers accessing, due every channel has its
own dedicated bit in ipc register and readl/writel will introduce memory
barrier, so don't need spinlock to protect ipc registers accessing
* After mailbox driver is ready, can use patch 4 to enable CPU's OPPs and
stub clock driver; finally can enable CPUFreq driver for CPU frequency
scaling

Changes from v2:
* Get rid of unused memory regions from memory node in DT, and don't use
reserved-memory node according to Mark and Leif's suggestion; Haojian also
has updated UEFI for efi memory info

Changes from v1:
* Correct lock usage for SMP scenario

Changes from RFC:
* According to Jassi's review, totally remove the abstract common driver
layer and only commit driver dedicated for Hi6220
* According to Paul Bolle's review, fix typo issue for Kconfig and remove
unnecessary dependency with OF and fix minor for mailbox driver
* Refine a little for dts nodes


Leo Yan (4):
dt-bindings: mailbox: Document Hi6220 mailbox driver
mailbox: Hi6220: add mailbox driver
arm64: dts: add mailbox node for Hi6220
arm64: dts: add Hi6220's stub clock node

.../bindings/mailbox/hisilicon,hi6220-mailbox.txt | 57 ++++
arch/arm64/boot/dts/hisilicon/hi6220.dtsi | 31 ++
drivers/mailbox/Kconfig | 8 +
drivers/mailbox/Makefile | 2 +
drivers/mailbox/hi6220-mailbox.c | 371 +++++++++++++++++++++
5 files changed, 469 insertions(+)
create mode 100644 Documentation/devicetree/bindings/mailbox/hisilicon,hi6220-mailbox.txt
create mode 100644 drivers/mailbox/hi6220-mailbox.c

--
1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/