mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-08 10:23:47 +08:00
package: replace conninfra bin blob with netgear wax220 gpl code
source: https://www.downloads.netgear.com/files/GPL/WAX220-V1.0.1.2-gpl-src.zip
This commit is contained in:
parent
cb76fdda41
commit
ad394ccfc5
Binary file not shown.
Binary file not shown.
@ -9,15 +9,6 @@ include $(TOPDIR)/rules.mk
|
||||
include $(INCLUDE_DIR)/kernel.mk
|
||||
|
||||
PKG_NAME:=conninfra
|
||||
|
||||
ifeq ($(CONFIG_MTK_CONNINFRA_APSOC_MT7981),y)
|
||||
PKG_SOURCE:=mt7981_conninfra_20220425-bbf588-obj.tar.xz
|
||||
else
|
||||
ifeq ($(CONFIG_MTK_CONNINFRA_APSOC_MT7986),y)
|
||||
PKG_SOURCE:=mt7986_conninfra-bbf588-obj.tar.xz
|
||||
endif
|
||||
endif
|
||||
|
||||
PKG_VERSION:=bbf588
|
||||
PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/$(PKG_NAME)
|
||||
PKG_MAINTAINER:=Kun-Ze Syue<kun-ze.syue@mediatek.com>
|
||||
|
66
package/mtk/drivers/conninfra/src/Makefile
Normal file
66
package/mtk/drivers/conninfra/src/Makefile
Normal file
@ -0,0 +1,66 @@
|
||||
###############################################################################
|
||||
# Necessary Check
|
||||
|
||||
#ifeq ($(AUTOCONF_H),)
|
||||
# $(error AUTOCONF_H is not defined)
|
||||
#endif
|
||||
|
||||
#ccflags-y += -imacros $(AUTOCONF_H)
|
||||
|
||||
# Force build fail on modpost warning
|
||||
KBUILD_MODPOST_FAIL_ON_WARNINGS := y
|
||||
|
||||
###############################################################################
|
||||
ccflags-y += -Werror
|
||||
ccflags-y += -Wno-error=format
|
||||
ccflags-y += -Wno-error=format-extra-args
|
||||
ccflags-y += -Wframe-larger-than=1024
|
||||
|
||||
###############################################################################
|
||||
MODULE_NAME := conninfra
|
||||
obj-m += $(MODULE_NAME).o
|
||||
|
||||
###############################################################################
|
||||
# common_main
|
||||
###############################################################################
|
||||
ccflags-y += \
|
||||
-I$(SUBDIRS)/include \
|
||||
-I$(SUBDIRS)/base/include \
|
||||
-I$(SUBDIRS)/core/include \
|
||||
-I$(SUBDIRS)/conf/include \
|
||||
-I$(SUBDIRS)/platform/include
|
||||
|
||||
$(MODULE_NAME)-objs += base/ring.o
|
||||
$(MODULE_NAME)-objs += base/osal.o
|
||||
$(MODULE_NAME)-objs += base/msg_thread.o
|
||||
$(MODULE_NAME)-objs += core/conninfra_core.o
|
||||
$(MODULE_NAME)-objs += src/conninfra_dev.o
|
||||
$(MODULE_NAME)-objs += src/conninfra.o
|
||||
$(MODULE_NAME)-objs += platform/consys_hw.o
|
||||
$(MODULE_NAME)-objs += platform/consys_hw_plat_data.o
|
||||
$(MODULE_NAME)-objs += platform/pmic_mng.o
|
||||
$(MODULE_NAME)-objs += platform/emi_mng.o
|
||||
$(MODULE_NAME)-objs += platform/consys_reg_mng.o
|
||||
|
||||
# By Plaftfrom
|
||||
# MT7986
|
||||
ifeq ($(CONFIG_MTK_CONNINFRA_APSOC_MT7986),y)
|
||||
ccflags-y += \
|
||||
-I$(SUBDIRS)/platform/mt7986/include -DCONNINFRA_APSOC_MT7986
|
||||
$(MODULE_NAME)-objs += platform/mt7986/mt7986.o
|
||||
$(MODULE_NAME)-objs += platform/mt7986/mt7986_pmic.o
|
||||
$(MODULE_NAME)-objs += platform/mt7986/mt7986_consys_reg.o
|
||||
$(MODULE_NAME)-objs += platform/mt7986/mt7986_pos.o
|
||||
$(MODULE_NAME)-objs += platform/mt7986/mt7986_emi.o
|
||||
endif
|
||||
|
||||
# MT7981
|
||||
ifeq ($(CONFIG_MTK_CONNINFRA_APSOC_MT7981),y)
|
||||
ccflags-y += \
|
||||
-I$(SUBDIRS)/platform/mt7981/include -DCONNINFRA_APSOC_MT7981
|
||||
$(MODULE_NAME)-objs += platform/mt7981/mt7981.o
|
||||
$(MODULE_NAME)-objs += platform/mt7981/mt7981_pmic.o
|
||||
$(MODULE_NAME)-objs += platform/mt7981/mt7981_consys_reg.o
|
||||
$(MODULE_NAME)-objs += platform/mt7981/mt7981_pos.o
|
||||
$(MODULE_NAME)-objs += platform/mt7981/mt7981_emi.o
|
||||
endif
|
202
package/mtk/drivers/conninfra/src/NOTICE
Normal file
202
package/mtk/drivers/conninfra/src/NOTICE
Normal file
@ -0,0 +1,202 @@
|
||||
The GNU General Public License (GPL)
|
||||
|
||||
Version 2, June 1991
|
||||
|
||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU
|
||||
General Public License is intended to guarantee your freedom to share and change free software--to make sure the
|
||||
software is free for all its users. This General Public License applies to most of the Free Software Foundation's
|
||||
software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is
|
||||
covered by the GNU Library General Public License instead.) You can apply it to your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make
|
||||
sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you
|
||||
receive source code or can get it if you want it, that you can change the software or use pieces of it in new free
|
||||
programs; and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to
|
||||
surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the
|
||||
software, or if you modify it.
|
||||
|
||||
For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all
|
||||
the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them
|
||||
these terms so they know their rights.
|
||||
|
||||
We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal
|
||||
permission to copy, distribute and/or modify the software.
|
||||
|
||||
Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty
|
||||
for this free software. If the software is modified by someone else and passed on, we want its recipients to know that
|
||||
what they have is not the original, so that any problems introduced by others will not reflect on the original authors'
|
||||
reputations.
|
||||
|
||||
Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors
|
||||
of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this,
|
||||
we have made it clear that any patent must be licensed for everyone's free use or not licensed at all.
|
||||
|
||||
The precise terms and conditions for copying, distribution and modification follow.
|
||||
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it
|
||||
may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or
|
||||
work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to
|
||||
say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into
|
||||
another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is
|
||||
addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not covered by this License; they are outside its
|
||||
scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents
|
||||
constitute a work based on the Program (independent of having been made by running the Program). Whether that is true
|
||||
depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided
|
||||
that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of
|
||||
warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other
|
||||
recipients of the Program a copy of this License along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection
|
||||
in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and
|
||||
copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of
|
||||
these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any
|
||||
change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the
|
||||
Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this
|
||||
License.
|
||||
|
||||
c) If the modified program normally reads commands interactively when run, you must cause it, when started running for
|
||||
such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright
|
||||
notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may
|
||||
redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if
|
||||
the Program itself is interactive but does not normally print such an announcement, your work based on the Program is
|
||||
not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the
|
||||
Program, and can be reasonably considered independent and separate works in themselves, then this License, and its
|
||||
terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same
|
||||
sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part
|
||||
regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you;
|
||||
rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the
|
||||
Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the
|
||||
Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form
|
||||
under the terms of Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms
|
||||
of Sections 1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than
|
||||
your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source
|
||||
code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange;
|
||||
or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This
|
||||
alternative is allowed only for noncommercial distribution and only if you received the program in object code or
|
||||
executable form with such an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for making modifications to it. For an executable work,
|
||||
complete source code means all the source code for all modules it contains, plus any associated interface definition
|
||||
files, plus the scripts used to control compilation and installation of the executable. However, as a special exception,
|
||||
the source code distributed need not include anything that is normally distributed (in either source or binary form)
|
||||
with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless
|
||||
that component itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering access to copy from a designated place, then offering
|
||||
equivalent access to copy the source code from the same place counts as distribution of the source code, even though
|
||||
third parties are not compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any
|
||||
attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your
|
||||
rights under this License. However, parties who have received copies, or rights, from you under this License will not
|
||||
have their licenses terminated so long as such parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not signed it. However, nothing else grants you
|
||||
permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do
|
||||
not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you
|
||||
indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or
|
||||
modifying the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a
|
||||
license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You
|
||||
may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not
|
||||
responsible for enforcing compliance by third parties to this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to
|
||||
patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the
|
||||
conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as
|
||||
to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence
|
||||
you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution
|
||||
of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy
|
||||
both it and this License would be to refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the
|
||||
section is intended to apply and the section as a whole is intended to apply in other circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest
|
||||
validity of any such claims; this section has the sole purpose of protecting the integrity of the free software
|
||||
distribution system, which is implemented by public license practices. Many people have made generous contributions to
|
||||
the wide range of software distributed through that system in reliance on consistent application of that system; it is
|
||||
up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee
|
||||
cannot impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted
|
||||
interfaces, the original copyright holder who places the Program under this License may add an explicit geographical
|
||||
distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus
|
||||
excluded. In such case, this License incorporates the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time.
|
||||
Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or
|
||||
concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program specifies a version number of this License which
|
||||
applies to it and "any later version", you have the option of following the terms and conditions either of that version
|
||||
or of any later version published by the Free Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are
|
||||
different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation,
|
||||
write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two
|
||||
goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of
|
||||
software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM
|
||||
"AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
|
||||
PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR
|
||||
CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY
|
||||
WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL,
|
||||
SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT
|
||||
LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF
|
||||
THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY
|
||||
OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
|
||||
|
||||
|
141
package/mtk/drivers/conninfra/src/base/include/msg_thread.h
Normal file
141
package/mtk/drivers/conninfra/src/base/include/msg_thread.h
Normal file
@ -0,0 +1,141 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _BASE_MSG_THREAD_H_
|
||||
#define _BASE_MSG_THREAD_H_
|
||||
|
||||
#include "osal.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
#define MSG_THREAD_OP_DATA_SIZE 8
|
||||
#define MSG_THREAD_OP_BUF_SIZE 64
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct msg_op_data {
|
||||
unsigned int op_id; /* Event ID */
|
||||
unsigned int info_bit; /* Reserved */
|
||||
size_t op_data[MSG_THREAD_OP_DATA_SIZE]; /* OP Data */
|
||||
};
|
||||
|
||||
struct msg_op {
|
||||
struct msg_op_data op;
|
||||
OSAL_SIGNAL signal;
|
||||
int result;
|
||||
atomic_t ref_count;
|
||||
};
|
||||
|
||||
|
||||
struct msg_op_q {
|
||||
OSAL_SLEEPABLE_LOCK lock;
|
||||
unsigned int write;
|
||||
unsigned int read;
|
||||
unsigned int size;
|
||||
struct msg_op *queue[MSG_THREAD_OP_BUF_SIZE];
|
||||
};
|
||||
|
||||
typedef OSAL_OP_DAT msg_evt_op;
|
||||
typedef int(*msg_opid_func) (struct msg_op_data *);
|
||||
|
||||
struct msg_thread_ctx {
|
||||
OSAL_THREAD thread; /* core thread */
|
||||
OSAL_EVENT evt;
|
||||
|
||||
struct msg_op_q free_op_q; /* free op queue */
|
||||
struct msg_op_q active_op_q; /* active op queue */
|
||||
struct msg_op op_q_inst[MSG_THREAD_OP_BUF_SIZE]; /* real op instances */
|
||||
struct msg_op *cur_op; /* current op */
|
||||
|
||||
int op_func_size;
|
||||
const msg_opid_func *op_func;
|
||||
|
||||
struct osal_op_history op_history;
|
||||
};
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define MSG_OP_TIMEOUT 20000
|
||||
|
||||
int msg_thread_init(struct msg_thread_ctx *ctx, const char *name,
|
||||
const msg_opid_func *func, int op_size);
|
||||
int msg_thread_deinit(struct msg_thread_ctx *ctx);
|
||||
|
||||
/* timeout:
|
||||
* 0: default value (by MSG_OP_TIMEOUT define)
|
||||
* >0: cutom timeout (ms)
|
||||
*/
|
||||
int msg_thread_send(struct msg_thread_ctx *ctx, int opid);
|
||||
int msg_thread_send_1(struct msg_thread_ctx *ctx, int opid,
|
||||
size_t param1);
|
||||
int msg_thread_send_2(struct msg_thread_ctx *ctx, int opid,
|
||||
size_t param1, size_t param2);
|
||||
|
||||
int msg_thread_send_wait(struct msg_thread_ctx *ctx, int opid,
|
||||
int timeout);
|
||||
int msg_thread_send_wait_1(struct msg_thread_ctx *ctx, int opid,
|
||||
int timeout, size_t param1);
|
||||
int msg_thread_send_wait_2(struct msg_thread_ctx *ctx, int opid,
|
||||
int timeout, size_t param1, size_t param2);
|
||||
int msg_thread_send_wait_3(struct msg_thread_ctx *ctx, int opid, int timeout, size_t param1,
|
||||
size_t param2,size_t param3);
|
||||
|
||||
int msg_thread_dump(struct msg_thread_ctx *ctx);
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _BASE_MSG_THREAD_H_ */
|
399
package/mtk/drivers/conninfra/src/base/include/osal.h
Normal file
399
package/mtk/drivers/conninfra/src/base/include/osal.h
Normal file
@ -0,0 +1,399 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
|
||||
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _OSAL_H_
|
||||
#define _OSAL_H_
|
||||
|
||||
#include <linux/workqueue.h>
|
||||
#include <linux/mutex.h>
|
||||
#include <linux/completion.h>
|
||||
#include <linux/wait.h>
|
||||
#include "ring.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define OS_BIT_OPS_SUPPORT 1
|
||||
|
||||
#ifndef MTK_CONN_BOOL_TRUE
|
||||
#define MTK_CONN_BOOL_FALSE ((MTK_CONN_BOOL) 0)
|
||||
#define MTK_CONN_BOOL_TRUE ((MTK_CONN_BOOL) 1)
|
||||
#endif
|
||||
|
||||
#define _osal_inline_ inline
|
||||
|
||||
#define MAX_THREAD_NAME_LEN 16
|
||||
#define MAX_HISTORY_NAME_LEN 16
|
||||
#define OSAL_OP_BUF_SIZE 64
|
||||
|
||||
|
||||
#if (defined(CONFIG_MTK_GMO_RAM_OPTIMIZE) && !defined(CONFIG_MTK_ENG_BUILD))
|
||||
#define OSAL_OP_DATA_SIZE 8
|
||||
#else
|
||||
#define OSAL_OP_DATA_SIZE 32
|
||||
#endif
|
||||
|
||||
#define DBG_LOG_STR_SIZE 256
|
||||
|
||||
#define osal_sizeof(x) sizeof(x)
|
||||
|
||||
#define osal_array_size(x) ARRAY_SIZE(x)
|
||||
|
||||
#ifndef NAME_MAX
|
||||
#define NAME_MAX 256
|
||||
#endif
|
||||
|
||||
#define WMT_OP_BIT(x) (0x1UL << x)
|
||||
#define WMT_OP_HIF_BIT WMT_OP_BIT(0)
|
||||
|
||||
#define GET_BIT_MASK(value, mask) ((value) & (mask))
|
||||
#define SET_BIT_MASK(pdest, value, mask) (*(pdest) = (GET_BIT_MASK(*(pdest), ~(mask)) | GET_BIT_MASK(value, mask)))
|
||||
#define GET_BIT_RANGE(data, end, begin) ((data) & GENMASK(end, begin))
|
||||
#define SET_BIT_RANGE(pdest, data, end, begin) (SET_BIT_MASK(pdest, data, GENMASK(end, begin)))
|
||||
|
||||
#define RB_LATEST(prb) ((prb)->write - 1)
|
||||
#define RB_SIZE(prb) ((prb)->size)
|
||||
#define RB_MASK(prb) (RB_SIZE(prb) - 1)
|
||||
#define RB_COUNT(prb) ((prb)->write - (prb)->read)
|
||||
#define RB_FULL(prb) (RB_COUNT(prb) >= RB_SIZE(prb))
|
||||
#define RB_EMPTY(prb) ((prb)->write == (prb)->read)
|
||||
|
||||
#define RB_INIT(prb, qsize) \
|
||||
do { \
|
||||
(prb)->read = (prb)->write = 0; \
|
||||
(prb)->size = (qsize); \
|
||||
} while (0)
|
||||
|
||||
#define RB_PUT(prb, value) \
|
||||
do { \
|
||||
if (!RB_FULL(prb)) { \
|
||||
(prb)->queue[(prb)->write & RB_MASK(prb)] = value; \
|
||||
++((prb)->write); \
|
||||
} \
|
||||
else { \
|
||||
pr_warn("RB is full!"); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define RB_GET(prb, value) \
|
||||
do { \
|
||||
if (!RB_EMPTY(prb)) { \
|
||||
value = (prb)->queue[(prb)->read & RB_MASK(prb)]; \
|
||||
++((prb)->read); \
|
||||
if (RB_EMPTY(prb)) { \
|
||||
(prb)->read = (prb)->write = 0; \
|
||||
} \
|
||||
} \
|
||||
else { \
|
||||
value = NULL; \
|
||||
pr_warn("RB is empty!"); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define RB_GET_LATEST(prb, value) \
|
||||
do { \
|
||||
if (!RB_EMPTY(prb)) { \
|
||||
value = (prb)->queue[RB_LATEST(prb) & RB_MASK(prb)]; \
|
||||
if (RB_EMPTY(prb)) { \
|
||||
(prb)->read = (prb)->write = 0; \
|
||||
} \
|
||||
} \
|
||||
else { \
|
||||
value = NULL; \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
typedef int MTK_CONN_BOOL;
|
||||
|
||||
typedef int(*P_COND) (void *);
|
||||
|
||||
typedef struct _OSAL_UNSLEEPABLE_LOCK_ {
|
||||
spinlock_t lock;
|
||||
unsigned long flag;
|
||||
} OSAL_UNSLEEPABLE_LOCK, *P_OSAL_UNSLEEPABLE_LOCK;
|
||||
|
||||
typedef struct _OSAL_SLEEPABLE_LOCK_ {
|
||||
struct mutex lock;
|
||||
} OSAL_SLEEPABLE_LOCK, *P_OSAL_SLEEPABLE_LOCK;
|
||||
|
||||
typedef struct _OSAL_SIGNAL_ {
|
||||
struct completion comp;
|
||||
unsigned int timeoutValue;
|
||||
unsigned int timeoutExtension; /* max number of timeout caused by thread not able to acquire CPU */
|
||||
} OSAL_SIGNAL, *P_OSAL_SIGNAL;
|
||||
|
||||
typedef struct _OSAL_EVENT_ {
|
||||
wait_queue_head_t waitQueue;
|
||||
unsigned int timeoutValue;
|
||||
int waitFlag;
|
||||
|
||||
} OSAL_EVENT, *P_OSAL_EVENT;
|
||||
|
||||
/* Data collected from sched_entity and sched_statistics */
|
||||
typedef struct _OSAL_THREAD_SCHEDSTATS_ {
|
||||
unsigned long long time; /* when marked: the profiling start time(ms), when unmarked: total duration(ms) */
|
||||
unsigned long long exec; /* time spent in exec (sum_exec_runtime) */
|
||||
unsigned long long runnable; /* time spent in run-queue while not being scheduled (wait_sum) */
|
||||
unsigned long long iowait; /* time spent waiting for I/O (iowait_sum) */
|
||||
} OSAL_THREAD_SCHEDSTATS, *P_OSAL_THREAD_SCHEDSTATS;
|
||||
|
||||
typedef struct _OSAL_THREAD_ {
|
||||
struct task_struct *pThread;
|
||||
void *pThreadFunc;
|
||||
void *pThreadData;
|
||||
char threadName[MAX_THREAD_NAME_LEN];
|
||||
} OSAL_THREAD, *P_OSAL_THREAD;
|
||||
|
||||
|
||||
typedef struct _OSAL_FIFO_ {
|
||||
/*fifo definition */
|
||||
void *pFifoBody;
|
||||
spinlock_t fifoSpinlock;
|
||||
/*fifo operations */
|
||||
int (*FifoInit)(struct _OSAL_FIFO_ *pFifo, unsigned char *buf, unsigned int);
|
||||
int (*FifoDeInit)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoReset)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoSz)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoAvailSz)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoLen)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoIsEmpty)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoIsFull)(struct _OSAL_FIFO_ *pFifo);
|
||||
int (*FifoDataIn)(struct _OSAL_FIFO_ *pFifo, const void *buf, unsigned int len);
|
||||
int (*FifoDataOut)(struct _OSAL_FIFO_ *pFifo, void *buf, unsigned int len);
|
||||
} OSAL_FIFO, *P_OSAL_FIFO;
|
||||
|
||||
typedef struct firmware osal_firmware;
|
||||
|
||||
typedef struct _OSAL_OP_DAT {
|
||||
unsigned int opId; /* Event ID */
|
||||
unsigned int u4InfoBit; /* Reserved */
|
||||
size_t au4OpData[OSAL_OP_DATA_SIZE]; /* OP Data */
|
||||
} OSAL_OP_DAT, *P_OSAL_OP_DAT;
|
||||
|
||||
typedef struct _OSAL_LXOP_ {
|
||||
OSAL_OP_DAT op;
|
||||
OSAL_SIGNAL signal;
|
||||
int result;
|
||||
atomic_t ref_count;
|
||||
} OSAL_OP, *P_OSAL_OP;
|
||||
|
||||
typedef struct _OSAL_LXOP_Q {
|
||||
OSAL_SLEEPABLE_LOCK sLock;
|
||||
unsigned int write;
|
||||
unsigned int read;
|
||||
unsigned int size;
|
||||
P_OSAL_OP queue[OSAL_OP_BUF_SIZE];
|
||||
} OSAL_OP_Q, *P_OSAL_OP_Q;
|
||||
|
||||
typedef struct _OSAL_BIT_OP_VAR_ {
|
||||
unsigned long data;
|
||||
OSAL_UNSLEEPABLE_LOCK opLock;
|
||||
} OSAL_BIT_OP_VAR, *P_OSAL_BIT_OP_VAR;
|
||||
|
||||
typedef unsigned int (*P_OSAL_EVENT_CHECKER) (P_OSAL_THREAD pThread);
|
||||
|
||||
struct osal_op_history_entry {
|
||||
void *opbuf_address;
|
||||
unsigned int op_id;
|
||||
unsigned int opbuf_ref_count;
|
||||
unsigned int op_info_bit;
|
||||
size_t param_0;
|
||||
size_t param_1;
|
||||
size_t param_2;
|
||||
size_t param_3;
|
||||
unsigned long long ts;
|
||||
unsigned long usec;
|
||||
};
|
||||
|
||||
struct osal_op_history {
|
||||
struct ring ring_buffer;
|
||||
struct osal_op_history_entry *queue;
|
||||
spinlock_t lock;
|
||||
struct ring dump_ring_buffer;
|
||||
struct work_struct dump_work;
|
||||
unsigned char name[MAX_HISTORY_NAME_LEN];
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
void FlashRead(char *name,unsigned char *value, unsigned long offset, unsigned long size);
|
||||
void FlashWrite(char *name, unsigned char *p, unsigned long a, unsigned long b);
|
||||
|
||||
unsigned int osal_strlen(const char *str);
|
||||
int osal_strcmp(const char *dst, const char *src);
|
||||
int osal_strncmp(const char *dst, const char *src, unsigned int len);
|
||||
char *osal_strcpy(char *dst, const char *src);
|
||||
char *osal_strncpy(char *dst, const char *src, unsigned int len);
|
||||
char *osal_strcat(char *dst, const char *src);
|
||||
char *osal_strncat(char *dst, const char *src, unsigned int len);
|
||||
char *osal_strchr(const char *str, unsigned char c);
|
||||
char *osal_strsep(char **str, const char *c);
|
||||
int osal_strtol(const char *str, unsigned int adecimal, long *res);
|
||||
char *osal_strstr(char *str1, const char *str2);
|
||||
char *osal_strnstr(char *str1, const char *str2, int n);
|
||||
|
||||
void osal_bug_on(unsigned int val);
|
||||
|
||||
int osal_snprintf(char *buf, unsigned int len, const char *fmt, ...);
|
||||
|
||||
int osal_sprintf(char *str, const char *format, ...);
|
||||
void *osal_malloc(unsigned int size);
|
||||
void osal_free(const void *dst);
|
||||
void *osal_memset(void *buf, int i, unsigned int len);
|
||||
void *osal_memcpy(void *dst, const void *src, unsigned int len);
|
||||
void osal_memcpy_fromio(void *dst, const void *src, unsigned int len);
|
||||
void osal_memcpy_toio(void *dst, const void *src, unsigned int len);
|
||||
int osal_memcmp(const void *buf1, const void *buf2, unsigned int len);
|
||||
|
||||
int osal_sleep_ms(unsigned int ms);
|
||||
int osal_udelay(unsigned int us);
|
||||
int osal_usleep_range(unsigned long min, unsigned long max);
|
||||
|
||||
int osal_fifo_init(P_OSAL_FIFO pFifo, unsigned char *buffer, unsigned int size);
|
||||
void osal_fifo_deinit(P_OSAL_FIFO pFifo);
|
||||
int osal_fifo_reset(P_OSAL_FIFO pFifo);
|
||||
unsigned int osal_fifo_in(P_OSAL_FIFO pFifo, unsigned char *buffer,
|
||||
unsigned int size);
|
||||
unsigned int osal_fifo_out(P_OSAL_FIFO pFifo, unsigned char *buffer,
|
||||
unsigned int size);
|
||||
unsigned int osal_fifo_len(P_OSAL_FIFO pFifo);
|
||||
unsigned int osal_fifo_sz(P_OSAL_FIFO pFifo);
|
||||
unsigned int osal_fifo_avail(P_OSAL_FIFO pFifo);
|
||||
unsigned int osal_fifo_is_empty(P_OSAL_FIFO pFifo);
|
||||
unsigned int osal_fifo_is_full(P_OSAL_FIFO pFifo);
|
||||
|
||||
#if defined(CONFIG_PROVE_LOCKING)
|
||||
#define osal_unsleepable_lock_init(l) { spin_lock_init(&((l)->lock)); }
|
||||
#else
|
||||
int osal_unsleepable_lock_init(P_OSAL_UNSLEEPABLE_LOCK);
|
||||
#endif
|
||||
int osal_lock_unsleepable_lock(P_OSAL_UNSLEEPABLE_LOCK);
|
||||
int osal_unlock_unsleepable_lock(P_OSAL_UNSLEEPABLE_LOCK);
|
||||
int osal_unsleepable_lock_deinit(P_OSAL_UNSLEEPABLE_LOCK);
|
||||
|
||||
#if defined(CONFIG_PROVE_LOCKING)
|
||||
#define osal_sleepable_lock_init(l) { mutex_init(&((l)->lock)); }
|
||||
#else
|
||||
int osal_sleepable_lock_init(P_OSAL_SLEEPABLE_LOCK);
|
||||
#endif
|
||||
int osal_lock_sleepable_lock(P_OSAL_SLEEPABLE_LOCK);
|
||||
int osal_unlock_sleepable_lock(P_OSAL_SLEEPABLE_LOCK);
|
||||
int osal_trylock_sleepable_lock(P_OSAL_SLEEPABLE_LOCK);
|
||||
int osal_sleepable_lock_deinit(P_OSAL_SLEEPABLE_LOCK);
|
||||
|
||||
int osal_signal_init(P_OSAL_SIGNAL);
|
||||
int osal_wait_for_signal(P_OSAL_SIGNAL);
|
||||
int osal_wait_for_signal_timeout(P_OSAL_SIGNAL, P_OSAL_THREAD);
|
||||
int osal_raise_signal(P_OSAL_SIGNAL);
|
||||
int osal_signal_active_state(P_OSAL_SIGNAL pSignal);
|
||||
int osal_signal_deinit(P_OSAL_SIGNAL);
|
||||
|
||||
int osal_event_init(P_OSAL_EVENT);
|
||||
int osal_wait_for_event(P_OSAL_EVENT, P_COND, void*);
|
||||
int osal_wait_for_event_timeout(P_OSAL_EVENT, P_COND, void*);
|
||||
extern int osal_trigger_event(P_OSAL_EVENT);
|
||||
|
||||
int osal_event_deinit(P_OSAL_EVENT);
|
||||
long osal_wait_for_event_bit_set(P_OSAL_EVENT pEvent, unsigned long *pState, unsigned int bitOffset);
|
||||
long osal_wait_for_event_bit_clr(P_OSAL_EVENT pEvent, unsigned long *pState, unsigned int bitOffset);
|
||||
|
||||
int osal_thread_create(P_OSAL_THREAD);
|
||||
int osal_thread_run(P_OSAL_THREAD);
|
||||
int osal_thread_should_stop(P_OSAL_THREAD);
|
||||
int osal_thread_stop(P_OSAL_THREAD);
|
||||
/*int osal_thread_wait_for_event(P_OSAL_THREAD, P_OSAL_EVENT);*/
|
||||
int osal_thread_wait_for_event(P_OSAL_THREAD, P_OSAL_EVENT, P_OSAL_EVENT_CHECKER);
|
||||
/*check pOsalLxOp and OSAL_THREAD_SHOULD_STOP*/
|
||||
int osal_thread_destroy(P_OSAL_THREAD);
|
||||
int osal_thread_sched_mark(P_OSAL_THREAD, P_OSAL_THREAD_SCHEDSTATS schedstats);
|
||||
int osal_thread_sched_unmark(P_OSAL_THREAD pThread, P_OSAL_THREAD_SCHEDSTATS schedstats);
|
||||
|
||||
int osal_clear_bit(unsigned int bitOffset, P_OSAL_BIT_OP_VAR pData);
|
||||
int osal_set_bit(unsigned int bitOffset, P_OSAL_BIT_OP_VAR pData);
|
||||
int osal_test_bit(unsigned int bitOffset, P_OSAL_BIT_OP_VAR pData);
|
||||
int osal_test_and_clear_bit(unsigned int bitOffset, P_OSAL_BIT_OP_VAR pData);
|
||||
int osal_test_and_set_bit(unsigned int bitOffset, P_OSAL_BIT_OP_VAR pData);
|
||||
|
||||
int osal_gettimeofday(int *sec, int *usec);
|
||||
int osal_gettimeofday2(struct timeval *tv);
|
||||
|
||||
//int osal_printtimeofday(const unsigned char *prefix);
|
||||
void osal_get_local_time(unsigned long long *sec, unsigned long *nsec);
|
||||
unsigned long long osal_elapsed_us(unsigned long long ts, unsigned long usec);
|
||||
|
||||
void osal_buffer_dump(const unsigned char *buf, const unsigned char *title, unsigned int len, unsigned int limit);
|
||||
void osal_buffer_dump_data(const unsigned int *buf, const unsigned char *title, const unsigned int len, const unsigned int limit,
|
||||
const int flag);
|
||||
|
||||
unsigned int osal_op_get_id(P_OSAL_OP pOp);
|
||||
MTK_CONN_BOOL osal_op_is_wait_for_signal(P_OSAL_OP pOp);
|
||||
void osal_op_raise_signal(P_OSAL_OP pOp, int result);
|
||||
void osal_set_op_result(P_OSAL_OP pOp, int result);
|
||||
void osal_opq_dump(const char *qName, P_OSAL_OP_Q pOpQ);
|
||||
void osal_opq_dump_locked(const char *qName, P_OSAL_OP_Q pOpQ);
|
||||
MTK_CONN_BOOL osal_opq_has_op(P_OSAL_OP_Q pOpQ, P_OSAL_OP pOp);
|
||||
|
||||
int osal_ftrace_print(const char *str, ...);
|
||||
int osal_ftrace_print_ctrl(int flag);
|
||||
|
||||
void osal_dump_thread_state(const unsigned char *name);
|
||||
void osal_op_history_init(struct osal_op_history *log_history, int queue_size);
|
||||
void osal_op_history_save(struct osal_op_history *log_history, P_OSAL_OP pOp);
|
||||
void osal_op_history_print(struct osal_op_history *log_history, char *name);
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _OSAL_H_ */
|
95
package/mtk/drivers/conninfra/src/base/include/ring.h
Normal file
95
package/mtk/drivers/conninfra/src/base/include/ring.h
Normal file
@ -0,0 +1,95 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
#ifndef _RING_H_
|
||||
#define _RING_H_
|
||||
|
||||
struct ring {
|
||||
/* addr where ring buffer starts */
|
||||
void *base;
|
||||
/* addr storing the next writable pos, guaranteed to be >= read except when write overflow, but it's ok. */
|
||||
unsigned int write;
|
||||
/* addr storing the next readable pos, except when read == write as buffer empty */
|
||||
unsigned int read;
|
||||
/* must be power of 2 */
|
||||
unsigned int max_size;
|
||||
};
|
||||
|
||||
struct ring_segment {
|
||||
/* addr points into ring buffer for read/write */
|
||||
void *ring_pt;
|
||||
/* size to read/write */
|
||||
unsigned int sz;
|
||||
/* pos in external data buffer to read/write */
|
||||
unsigned int data_pos;
|
||||
/* the size to be read/write after this segment completed */
|
||||
unsigned int remain;
|
||||
};
|
||||
|
||||
void ring_init(void *base, unsigned int max_size, unsigned int read,
|
||||
unsigned int write, struct ring *ring);
|
||||
unsigned int ring_read_prepare(unsigned int sz, struct ring_segment *seg, struct ring *ring);
|
||||
#define ring_read_all_prepare(seg, ring) ring_read_prepare((ring)->max_size, seg, ring)
|
||||
unsigned int ring_write_prepare(unsigned int sz, struct ring_segment *seg, struct ring *ring);
|
||||
unsigned int ring_overwrite_prepare(unsigned int sz,
|
||||
struct ring_segment *seg, struct ring *ring);
|
||||
|
||||
/* making sure max_size is power of 2 */
|
||||
#define RING_VALIDATE_SIZE(max_size) WARN_ON(!max_size || (max_size & (max_size - 1)))
|
||||
|
||||
#define RING_EMPTY(ring) ((ring)->read == (ring)->write)
|
||||
/* equation works even when write overflow */
|
||||
#define RING_SIZE(ring) ((ring)->write - (ring)->read)
|
||||
#define RING_FULL(ring) (RING_SIZE(ring) == (ring)->max_size)
|
||||
#define RING_WRITE_REMAIN_SIZE(ring) ((ring)->max_size - RING_SIZE(ring))
|
||||
|
||||
#define RING_READ_FOR_EACH(_sz, _seg, _ring) \
|
||||
for (ring_read_prepare(_sz, &(_seg), _ring), \
|
||||
_ring_segment_prepare((_ring)->read, &(_seg), (_ring)); \
|
||||
(_seg).sz > 0; \
|
||||
_ring_read_commit(&(_seg), (_ring)), _ring_segment_prepare((_ring)->read, \
|
||||
&(_seg), (_ring)))
|
||||
|
||||
#define RING_READ_ALL_FOR_EACH(seg, ring) RING_READ_FOR_EACH((ring)->max_size, seg, ring)
|
||||
|
||||
#define RING_READ_FOR_EACH_ITEM(_sz, _seg, _ring) \
|
||||
for (ring_read_prepare(_sz, &(_seg), _ring), \
|
||||
_ring_segment_prepare_item((_ring)->read, &(_seg), (_ring)); \
|
||||
(_seg).sz > 0; \
|
||||
_ring_read_commit(&(_seg), (_ring)), _ring_segment_prepare_item((_ring)->read, \
|
||||
&(_seg), (_ring)))
|
||||
|
||||
#define RING_WRITE_FOR_EACH(_sz, _seg, _ring) \
|
||||
for (ring_write_prepare(_sz, &(_seg), _ring),\
|
||||
_ring_segment_prepare((_ring)->write, &(_seg), (_ring)); \
|
||||
(_seg).sz > 0; \
|
||||
_ring_write_commit(&(_seg), (_ring)), _ring_segment_prepare((_ring)->write, \
|
||||
&(_seg), (_ring)))
|
||||
|
||||
#define RING_OVERWRITE_FOR_EACH(_sz, _seg, _ring) \
|
||||
for (ring_overwrite_prepare(_sz, &(_seg), _ring), \
|
||||
_ring_segment_prepare((_ring)->write, &(_seg), (_ring)); \
|
||||
(_seg).sz > 0; \
|
||||
_ring_write_commit(&(_seg), (_ring)), _ring_segment_prepare((_ring)->write, \
|
||||
&(_seg), (_ring)))
|
||||
|
||||
void ring_dump(const char *title, struct ring *ring);
|
||||
void ring_dump_segment(const char *title, struct ring_segment *seg);
|
||||
|
||||
|
||||
/* ring Buffer Internal API */
|
||||
void _ring_segment_prepare(unsigned int from, struct ring_segment *seg, struct ring *ring);
|
||||
void _ring_segment_prepare_item(unsigned int from, struct ring_segment *seg, struct ring *ring);
|
||||
void _ring_read_commit(struct ring_segment *seg, struct ring *ring);
|
||||
void _ring_write_commit(struct ring_segment *seg, struct ring *ring);
|
||||
|
||||
#endif
|
716
package/mtk/drivers/conninfra/src/base/msg_thread.c
Normal file
716
package/mtk/drivers/conninfra/src/base/msg_thread.c
Normal file
@ -0,0 +1,716 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
#include <linux/delay.h>
|
||||
#include "msg_thread.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
static void msg_opq_dump(const char *qName, struct msg_op_q *op_q);
|
||||
static void _msg_opq_dump(const char *qName, struct msg_op_q *op_q);
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define MSG_OP_SIZE(prb) ((prb)->size)
|
||||
#define MSG_OP_MASK(prb) (MSG_OP_SIZE(prb) - 1)
|
||||
#define MSG_OP_COUNT(prb) ((prb)->write - (prb)->read)
|
||||
#define MSG_OP_FULL(prb) (MSG_OP_COUNT(prb) >= MSG_OP_SIZE(prb))
|
||||
#define MSG_OP_EMPTY(prb) ((prb)->write == (prb)->read)
|
||||
|
||||
#define MSG_OP_INIT(prb, qsize) \
|
||||
do { \
|
||||
(prb)->read = (prb)->write = 0; \
|
||||
(prb)->size = (qsize); \
|
||||
} while (0)
|
||||
|
||||
#define MSG_OP_PUT(prb, value) \
|
||||
do { \
|
||||
if (!MSG_OP_FULL(prb)) { \
|
||||
(prb)->queue[(prb)->write & MSG_OP_MASK(prb)] = value; \
|
||||
++((prb)->write); \
|
||||
} \
|
||||
else { \
|
||||
pr_warn("Message queue is full.\n"); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define MSG_OP_GET(prb, value) \
|
||||
do { \
|
||||
if (!MSG_OP_EMPTY(prb)) { \
|
||||
value = (prb)->queue[(prb)->read & MSG_OP_MASK(prb)]; \
|
||||
++((prb)->read); \
|
||||
if (MSG_OP_EMPTY(prb)) { \
|
||||
(prb)->read = (prb)->write = 0; \
|
||||
} \
|
||||
} \
|
||||
else { \
|
||||
value = NULL; \
|
||||
pr_warn("Message queue is empty.\n"); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
|
||||
|
||||
#if defined(CONFIG_MTK_ENG_BUILD) || defined(CONFIG_MT_ENG_BUILD)
|
||||
static bool msg_evt_opq_has_op(struct msg_op_q *op_q, struct msg_op *op)
|
||||
{
|
||||
unsigned int rd;
|
||||
unsigned int wt;
|
||||
struct msg_op *tmp_op;
|
||||
|
||||
rd = op_q->read;
|
||||
wt = op_q->write;
|
||||
|
||||
while (rd != wt) {
|
||||
tmp_op = op_q->queue[rd & MSG_OP_MASK(op_q)];
|
||||
if (op == tmp_op)
|
||||
return true;
|
||||
rd++;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Utility functions
|
||||
*/
|
||||
static int msg_evt_put_op_to_q(struct msg_op_q *op_q, struct msg_op *op)
|
||||
{
|
||||
int ret;
|
||||
|
||||
if (!op_q || !op) {
|
||||
pr_err("invalid input param: pOpQ(0x%p), pLxOp(0x%p)\n", op_q, op);
|
||||
return -1;
|
||||
}
|
||||
|
||||
ret = osal_lock_sleepable_lock(&op_q->lock);
|
||||
if (ret) {
|
||||
pr_warn("osal_lock_sleepable_lock iRet(%d)\n", ret);
|
||||
return -2;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_MTK_ENG_BUILD) || defined(CONFIG_MT_ENG_BUILD)
|
||||
if (msg_evt_opq_has_op(op_q, op)) {
|
||||
pr_err("Op(%p) already exists in queue(%p)\n", op, op_q);
|
||||
ret = -3;
|
||||
}
|
||||
#endif
|
||||
|
||||
/* acquire lock success */
|
||||
if (!MSG_OP_FULL(op_q))
|
||||
MSG_OP_PUT(op_q, op);
|
||||
else {
|
||||
pr_warn("MSG_OP_FULL(%p -> %p)\n", op, op_q);
|
||||
ret = -4;
|
||||
}
|
||||
|
||||
osal_unlock_sleepable_lock(&op_q->lock);
|
||||
|
||||
if (ret) {
|
||||
//osal_opq_dump("FreeOpQ", &g_conninfra_ctx.rFreeOpQ);
|
||||
//osal_opq_dump("ActiveOpQ", &g_conninfra_ctx.rActiveOpQ);
|
||||
return ret;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Utility functions
|
||||
*/
|
||||
static struct msg_op *msg_evt_get_op_from_q(struct msg_op_q *op_q)
|
||||
{
|
||||
struct msg_op *op;
|
||||
int ret;
|
||||
|
||||
if (op_q == NULL) {
|
||||
pr_err("pOpQ = NULL\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
ret = osal_lock_sleepable_lock(&op_q->lock);
|
||||
if (ret) {
|
||||
pr_err("osal_lock_sleepable_lock iRet(%d)\n", ret);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* acquire lock success */
|
||||
MSG_OP_GET(op_q, op);
|
||||
osal_unlock_sleepable_lock(&op_q->lock);
|
||||
|
||||
if (op == NULL) {
|
||||
pr_warn("MSG_OP_GET(%p) return NULL\n", op_q);
|
||||
//osal_opq_dump("FreeOpQ", &g_conninfra_ctx.rFreeOpQ);
|
||||
//osal_opq_dump("ActiveOpQ", &g_conninfra_ctx.rActiveOpQ);
|
||||
}
|
||||
|
||||
return op;
|
||||
}
|
||||
|
||||
static void _msg_opq_dump(const char *qName, struct msg_op_q *op_q)
|
||||
{
|
||||
/* Line format:
|
||||
* [LogicalIdx(PhysicalIdx)]Address:OpId(Ref)(Result)-Info-OpData0,OpData1,OpData2,OpData3,OpData5_
|
||||
* [LogicalIdx] max 10+2=12 chars (decimal)
|
||||
* (PhysicalIdx) max 10+2=12 chars (decimal)
|
||||
* Address: max 16+1=17 chars (hex)
|
||||
* OpId max 10 chars (decimal)
|
||||
* (Ref) max 2+2=4 chars (should only be 1 digit, reserve 2 in case of negative number)
|
||||
* (Result) max 11+2=13 chars (signed decimal)
|
||||
* -Info- max 8+2=10 chars (hex)
|
||||
* OpData, max 16+1=17 chars (hex)
|
||||
*/
|
||||
#define OPQ_DUMP_OP_PER_LINE 1
|
||||
#define OPQ_DUMP_OPDATA_PER_OP 6
|
||||
#define OPQ_DUMP_OP_BUF_SIZE (12 + 12 + 17 + 10 + 4 + 13 + 10 + (17 * (OPQ_DUMP_OPDATA_PER_OP)) + 1)
|
||||
#define OPQ_DUMP_LINE_BUF_SIZE ((OPQ_DUMP_OP_BUF_SIZE * OPQ_DUMP_OP_PER_LINE) + 1)
|
||||
unsigned int rd;
|
||||
unsigned int wt;
|
||||
unsigned int idx = 0;
|
||||
unsigned int op_data_idx;
|
||||
unsigned int buf_idx;
|
||||
int printed;
|
||||
struct msg_op *op;
|
||||
char buf[OPQ_DUMP_LINE_BUF_SIZE];
|
||||
|
||||
rd = op_q->read;
|
||||
wt = op_q->write;
|
||||
|
||||
pr_info("%s(%p), sz:%u/%u, rd:%u, wt:%u\n",
|
||||
qName, op_q, RB_COUNT(op_q), RB_SIZE(op_q), rd, wt);
|
||||
while (rd != wt && idx < RB_SIZE(op_q)) {
|
||||
buf_idx = idx % OPQ_DUMP_OP_PER_LINE;
|
||||
op = op_q->queue[rd & RB_MASK(op_q)];
|
||||
|
||||
if (buf_idx == 0) {
|
||||
printed = 0;
|
||||
buf[0] = 0;
|
||||
}
|
||||
|
||||
if (op) {
|
||||
printed += snprintf(buf + printed, OPQ_DUMP_LINE_BUF_SIZE - printed,
|
||||
"[%u(%u)]%p:%u(%d)(%d)-%u-",
|
||||
idx,
|
||||
(rd & RB_MASK(op_q)),
|
||||
op,
|
||||
op->op.op_id,
|
||||
atomic_read(&op->ref_count),
|
||||
op->result,
|
||||
op->op.info_bit);
|
||||
for (op_data_idx = 0; op_data_idx < OPQ_DUMP_OPDATA_PER_OP; op_data_idx++)
|
||||
printed += snprintf(buf + printed, OPQ_DUMP_LINE_BUF_SIZE - printed,
|
||||
"%zx,", op->op.op_data[op_data_idx]);
|
||||
buf[printed-1] = ' ';
|
||||
} else {
|
||||
printed += snprintf(buf + printed, OPQ_DUMP_LINE_BUF_SIZE - printed,
|
||||
"[%u(%u)]%p ", idx, (rd & RB_MASK(op_q)), op);
|
||||
}
|
||||
buf[printed++] = ' ';
|
||||
|
||||
if (buf_idx == OPQ_DUMP_OP_PER_LINE - 1 || rd == wt - 1) {
|
||||
buf[printed - 1] = 0;
|
||||
pr_info("%s\n", buf);
|
||||
}
|
||||
rd++;
|
||||
idx++;
|
||||
}
|
||||
}
|
||||
|
||||
void msg_opq_dump(const char *qName, struct msg_op_q *op_q)
|
||||
{
|
||||
int err;
|
||||
|
||||
err = osal_lock_sleepable_lock(&op_q->lock);
|
||||
if (err) {
|
||||
pr_info("Failed to lock queue (%d)\n", err);
|
||||
return;
|
||||
}
|
||||
|
||||
_msg_opq_dump(qName, op_q);
|
||||
|
||||
osal_unlock_sleepable_lock(&op_q->lock);
|
||||
}
|
||||
|
||||
/*
|
||||
* msg_evt_thread API
|
||||
*/
|
||||
|
||||
int msg_evt_put_op_to_free_queue(struct msg_thread_ctx *ctx, struct msg_op *op)
|
||||
{
|
||||
if (msg_evt_put_op_to_q(&ctx->free_op_q, op))
|
||||
return -1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
struct msg_op *msg_evt_get_free_op(struct msg_thread_ctx *ctx)
|
||||
{
|
||||
struct msg_op *op = NULL;
|
||||
|
||||
if (ctx == NULL) {
|
||||
pr_warn("ctx is null.\n");
|
||||
return op;
|
||||
}
|
||||
op = msg_evt_get_op_from_q(&ctx->free_op_q);
|
||||
if (op)
|
||||
osal_memset(op, 0, osal_sizeof(struct msg_op));
|
||||
return op;
|
||||
}
|
||||
|
||||
int msg_evt_put_op_to_active(struct msg_thread_ctx *ctx, struct msg_op *op)
|
||||
{
|
||||
P_OSAL_SIGNAL signal = NULL;
|
||||
int wait_ret = -1;
|
||||
int ret = 0;
|
||||
|
||||
do {
|
||||
if (!ctx || !op) {
|
||||
pr_err("msg_thread_ctx(0x%p), op(0x%p)\n", ctx, op);
|
||||
break;
|
||||
}
|
||||
|
||||
signal = &op->signal;
|
||||
if (signal->timeoutValue) {
|
||||
op->result = -9;
|
||||
osal_signal_init(signal);
|
||||
atomic_set(&op->ref_count, 1);
|
||||
} else
|
||||
atomic_set(&op->ref_count, 0);
|
||||
|
||||
/* Increment ref_count by 1 as wmtd thread will hold a reference also,
|
||||
* this must be done here instead of on target thread, because
|
||||
* target thread might not be scheduled until a much later time,
|
||||
* allowing current thread to decrement ref_count at the end of function,
|
||||
* putting op back to free queue before target thread has a chance to process.
|
||||
*/
|
||||
atomic_inc(&op->ref_count);
|
||||
|
||||
/* put to active Q */
|
||||
ret = msg_evt_put_op_to_q(&ctx->active_op_q, op);
|
||||
if (ret) {
|
||||
pr_warn("put to active queue fail\n");
|
||||
atomic_dec(&op->ref_count);
|
||||
break;
|
||||
}
|
||||
|
||||
/* wake up conninfra_cored */
|
||||
osal_trigger_event(&ctx->evt);
|
||||
|
||||
if (signal->timeoutValue == 0) {
|
||||
//ret = -1;
|
||||
/* Not set timeout, don't wait */
|
||||
/* pr_info("[%s] timeout is zero", __func__);*/
|
||||
break;
|
||||
}
|
||||
|
||||
/* check result */
|
||||
wait_ret = osal_wait_for_signal_timeout(signal, &ctx->thread);
|
||||
/*pr_info("osal_wait_for_signal_timeout:%d result=[%d]\n",
|
||||
wait_ret, op->result);*/
|
||||
|
||||
if (wait_ret == 0)
|
||||
pr_warn("opId(%d) completion timeout\n", op->op.op_id);
|
||||
else if (op->result)
|
||||
pr_info("opId(%d) result:%d\n",
|
||||
op->op.op_id, op->result);
|
||||
|
||||
/* op completes, check result */
|
||||
ret = op->result;
|
||||
} while (0);
|
||||
|
||||
if (op != NULL && signal != NULL && signal->timeoutValue &&
|
||||
atomic_dec_and_test(&op->ref_count)) {
|
||||
/* put Op back to freeQ */
|
||||
msg_evt_put_op_to_free_queue(ctx, op);
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
int msg_thread_send(struct msg_thread_ctx *ctx, int opid)
|
||||
{
|
||||
return msg_thread_send_2(ctx, opid, 0, 0);
|
||||
}
|
||||
|
||||
int msg_thread_send_1(struct msg_thread_ctx *ctx, int opid,
|
||||
size_t param1)
|
||||
{
|
||||
return msg_thread_send_2(ctx, opid, param1, 0);
|
||||
}
|
||||
|
||||
int msg_thread_send_2(struct msg_thread_ctx *ctx, int opid,
|
||||
size_t param1, size_t param2)
|
||||
{
|
||||
struct msg_op *op = NULL;
|
||||
P_OSAL_SIGNAL signal;
|
||||
int ret;
|
||||
|
||||
op = msg_evt_get_free_op(ctx);
|
||||
if (!op) {
|
||||
pr_err("[%s] can't get free op\n", __func__);
|
||||
return -1;
|
||||
}
|
||||
op->op.op_id = opid;
|
||||
op->op.op_data[0] = param1;
|
||||
op->op.op_data[1] = param2;
|
||||
|
||||
signal = &op->signal;
|
||||
//signal->timeoutValue = timeout > 0 ? timeout : MSG_OP_TIMEOUT;
|
||||
signal->timeoutValue = 0;
|
||||
ret = msg_evt_put_op_to_active(ctx, op);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int msg_thread_send_wait(struct msg_thread_ctx *ctx, int opid,
|
||||
int timeout)
|
||||
{
|
||||
return msg_thread_send_wait_3(ctx, opid, timeout, 0, 0, 0);
|
||||
}
|
||||
|
||||
int msg_thread_send_wait_1(struct msg_thread_ctx *ctx,
|
||||
int opid, int timeout,
|
||||
size_t param1)
|
||||
{
|
||||
return msg_thread_send_wait_3(ctx, opid, timeout, param1, 0, 0);
|
||||
}
|
||||
|
||||
|
||||
int msg_thread_send_wait_2(struct msg_thread_ctx *ctx,
|
||||
int opid, int timeout,
|
||||
size_t param1,
|
||||
size_t param2)
|
||||
{
|
||||
return msg_thread_send_wait_3(ctx, opid, timeout, param1, param2, 0);
|
||||
}
|
||||
|
||||
int msg_thread_send_wait_3(struct msg_thread_ctx *ctx,
|
||||
int opid, int timeout,
|
||||
size_t param1,
|
||||
size_t param2,
|
||||
size_t param3)
|
||||
{
|
||||
struct msg_op *op = NULL;
|
||||
P_OSAL_SIGNAL signal;
|
||||
int ret;
|
||||
|
||||
op = msg_evt_get_free_op(ctx);
|
||||
if (!op) {
|
||||
pr_err("can't get free op for 0x%x\n", opid);
|
||||
return -1;
|
||||
}
|
||||
op->op.op_id = opid;
|
||||
op->op.op_data[0] = param1;
|
||||
op->op.op_data[1] = param2;
|
||||
op->op.op_data[2] = param3;
|
||||
|
||||
signal = &op->signal;
|
||||
signal->timeoutValue = timeout > 0 ? timeout : MSG_OP_TIMEOUT;
|
||||
ret = msg_evt_put_op_to_active(ctx, op);
|
||||
return ret;
|
||||
|
||||
}
|
||||
|
||||
void msg_op_history_save(struct osal_op_history *log_history, struct msg_op *op)
|
||||
{
|
||||
struct osal_op_history_entry *entry = NULL;
|
||||
struct ring_segment seg;
|
||||
int index;
|
||||
unsigned long long sec = 0;
|
||||
unsigned long usec = 0;
|
||||
unsigned long flags;
|
||||
|
||||
if (log_history->queue == NULL)
|
||||
return;
|
||||
|
||||
osal_get_local_time(&sec, &usec);
|
||||
|
||||
spin_lock_irqsave(&(log_history->lock), flags);
|
||||
RING_OVERWRITE_FOR_EACH(1, seg, &log_history->ring_buffer) {
|
||||
index = seg.ring_pt - log_history->ring_buffer.base;
|
||||
entry = &log_history->queue[index];
|
||||
}
|
||||
|
||||
if (entry == NULL) {
|
||||
pr_info("Entry is null, size %d\n",
|
||||
RING_SIZE(&log_history->ring_buffer));
|
||||
spin_unlock_irqrestore(&(log_history->lock), flags);
|
||||
return;
|
||||
}
|
||||
|
||||
entry->opbuf_address = op;
|
||||
entry->op_id = op->op.op_id;
|
||||
entry->opbuf_ref_count = atomic_read(&op->ref_count);
|
||||
entry->op_info_bit = op->op.info_bit;
|
||||
entry->param_0 = op->op.op_data[0];
|
||||
entry->param_1 = op->op.op_data[1];
|
||||
entry->param_2 = op->op.op_data[2];
|
||||
entry->param_3 = op->op.op_data[3];
|
||||
entry->ts = sec;
|
||||
entry->usec = usec;
|
||||
spin_unlock_irqrestore(&(log_history->lock), flags);
|
||||
}
|
||||
|
||||
unsigned int msg_evt_wait_event_checker(P_OSAL_THREAD thread)
|
||||
{
|
||||
struct msg_thread_ctx *ctx = NULL;
|
||||
|
||||
if (thread) {
|
||||
ctx = (struct msg_thread_ctx *) (thread->pThreadData);
|
||||
return !MSG_OP_EMPTY(&ctx->active_op_q);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int msg_evt_set_current_op(struct msg_thread_ctx *ctx, struct msg_op *op)
|
||||
{
|
||||
ctx->cur_op = op;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int msg_evt_opid_handler(struct msg_thread_ctx *ctx, struct msg_op_data *op)
|
||||
{
|
||||
int opid, ret;
|
||||
|
||||
/*sanity check */
|
||||
if (op == NULL) {
|
||||
pr_warn("null op\n");
|
||||
return -1;
|
||||
}
|
||||
if (ctx == NULL) {
|
||||
pr_warn("null evt thread ctx\n");
|
||||
return -2;
|
||||
}
|
||||
|
||||
opid = op->op_id;
|
||||
|
||||
if (opid >= ctx->op_func_size) {
|
||||
pr_err("msg_evt_thread invalid OPID(%d)\n", opid);
|
||||
return -3;
|
||||
}
|
||||
|
||||
if (ctx->op_func[opid] == NULL) {
|
||||
pr_err("null handler (%d)\n", opid);
|
||||
return -4;
|
||||
}
|
||||
ret = (*(ctx->op_func[opid])) (op);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int msg_evt_thread(void *pvData)
|
||||
{
|
||||
struct msg_thread_ctx *ctx = (struct msg_thread_ctx *)pvData;
|
||||
P_OSAL_EVENT evt = NULL;
|
||||
struct msg_op *op;
|
||||
int ret;
|
||||
|
||||
if (ctx == NULL) {
|
||||
pr_err("msg_evt_thread (NULL)\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
evt = &(ctx->evt);
|
||||
|
||||
for (;;) {
|
||||
op = NULL;
|
||||
evt->timeoutValue = 0;
|
||||
|
||||
osal_thread_wait_for_event(&ctx->thread, evt, msg_evt_wait_event_checker);
|
||||
|
||||
if (osal_thread_should_stop(&ctx->thread)) {
|
||||
pr_info("msg_evt_thread thread should stop now...\n");
|
||||
/* TODO: clean up active opQ */
|
||||
break;
|
||||
}
|
||||
/* get Op from activeQ */
|
||||
op = msg_evt_get_op_from_q(&ctx->active_op_q);
|
||||
if (!op) {
|
||||
pr_warn("get op from activeQ fail\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
/* TODO: save op history */
|
||||
msg_op_history_save(&ctx->op_history, op);
|
||||
msg_evt_set_current_op(ctx, op);
|
||||
ret = msg_evt_opid_handler(ctx, &op->op);
|
||||
msg_evt_set_current_op(ctx, NULL);
|
||||
|
||||
if (ret)
|
||||
pr_warn("opid (0x%x) failed, ret(%d)\n",
|
||||
op->op.op_id, ret);
|
||||
|
||||
if (atomic_dec_and_test(&op->ref_count)) {
|
||||
/* msg_evt_free_op(ctx) */
|
||||
msg_evt_put_op_to_free_queue(ctx, op);
|
||||
} else if (op->signal.timeoutValue) {
|
||||
op->result = ret;
|
||||
osal_raise_signal(&op->signal);
|
||||
}
|
||||
}
|
||||
|
||||
pr_debug("msg evt thread exists\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int msg_thread_dump(struct msg_thread_ctx *ctx)
|
||||
{
|
||||
P_OSAL_THREAD p_thread;
|
||||
struct msg_op *cur_op;
|
||||
|
||||
if (ctx == NULL) {
|
||||
pr_err("get NULL input\n");
|
||||
return 0;
|
||||
}
|
||||
p_thread = &ctx->thread;
|
||||
pr_info("Dump msg_thread_ctx: %s\n", p_thread->threadName);
|
||||
cur_op = ctx->cur_op;
|
||||
if (cur_op) {
|
||||
pr_info("cur_op: %x(%x)-%zx,%zx,%zx,%zx\n",
|
||||
cur_op->op.op_id, cur_op->op.info_bit,
|
||||
cur_op->op.op_data[0], cur_op->op.op_data[1],
|
||||
cur_op->op.op_data[2], cur_op->op.op_data[3]);
|
||||
}
|
||||
osal_dump_thread_state(p_thread->threadName);
|
||||
osal_op_history_print(&(ctx->op_history), p_thread->threadName);
|
||||
msg_opq_dump("ActiveOpQ", &ctx->active_op_q);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int msg_thread_init(struct msg_thread_ctx *ctx,
|
||||
const char *thread_name, const msg_opid_func *funcs,
|
||||
int op_size)
|
||||
{
|
||||
int r = 0, i;
|
||||
P_OSAL_THREAD p_thread;
|
||||
|
||||
osal_memset(ctx, 0, sizeof(struct msg_thread_ctx));
|
||||
|
||||
ctx->op_func = funcs;
|
||||
ctx->op_func_size = op_size;
|
||||
|
||||
/* init thread inst */
|
||||
p_thread = &ctx->thread;
|
||||
|
||||
osal_strncpy(p_thread->threadName, thread_name,
|
||||
sizeof(p_thread->threadName));
|
||||
|
||||
p_thread->pThreadData = (void *) ctx;
|
||||
p_thread->pThreadFunc = (void *) msg_evt_thread;
|
||||
r = osal_thread_create(p_thread);
|
||||
|
||||
if (r) {
|
||||
pr_err("osal_thread_create(0x%p) fail(%d)\n", p_thread, r);
|
||||
return -1;
|
||||
}
|
||||
|
||||
osal_event_init(&ctx->evt);
|
||||
osal_sleepable_lock_init(&ctx->active_op_q.lock);
|
||||
osal_sleepable_lock_init(&ctx->free_op_q.lock);
|
||||
|
||||
/* Initialize op queue */
|
||||
MSG_OP_INIT(&ctx->free_op_q, MSG_THREAD_OP_BUF_SIZE);
|
||||
MSG_OP_INIT(&ctx->active_op_q, MSG_THREAD_OP_BUF_SIZE);
|
||||
|
||||
/* Put all to free Q */
|
||||
for (i = 0; i < MSG_THREAD_OP_BUF_SIZE; i++) {
|
||||
osal_signal_init(&(ctx->op_q_inst[i].signal));
|
||||
msg_evt_put_op_to_free_queue(ctx, &(ctx->op_q_inst[i]));
|
||||
}
|
||||
|
||||
osal_op_history_init(&ctx->op_history, 16);
|
||||
|
||||
r = osal_thread_run(p_thread);
|
||||
if (r) {
|
||||
pr_err("osal_thread_run(evt_thread 0x%p) fail(%d)\n",
|
||||
p_thread, r);
|
||||
return -2;
|
||||
}
|
||||
return r;
|
||||
}
|
||||
|
||||
int msg_thread_deinit(struct msg_thread_ctx *ctx)
|
||||
{
|
||||
int r, i;
|
||||
P_OSAL_THREAD p_thraed = &ctx->thread;
|
||||
|
||||
r = osal_thread_stop(p_thraed);
|
||||
if (r) {
|
||||
pr_err("osal_thread_stop(0x%p) fail(%d)\n", p_thraed, r);
|
||||
return -1;
|
||||
}
|
||||
|
||||
for (i = 0; i < MSG_THREAD_OP_BUF_SIZE; i++)
|
||||
osal_signal_deinit(&(ctx->op_q_inst[i].signal));
|
||||
|
||||
osal_sleepable_lock_deinit(&ctx->free_op_q.lock);
|
||||
osal_sleepable_lock_deinit(&ctx->active_op_q.lock);
|
||||
|
||||
r = osal_thread_destroy(p_thraed);
|
||||
if (r) {
|
||||
pr_err("osal_thread_stop(0x%p) fail(%d)\n", p_thraed, r);
|
||||
return -2;
|
||||
}
|
||||
|
||||
osal_memset(ctx, 0, sizeof(struct msg_thread_ctx));
|
||||
|
||||
pr_debug("[%s] DONE\n", __func__);
|
||||
return 0;
|
||||
}
|
1595
package/mtk/drivers/conninfra/src/base/osal.c
Normal file
1595
package/mtk/drivers/conninfra/src/base/osal.c
Normal file
File diff suppressed because it is too large
Load Diff
150
package/mtk/drivers/conninfra/src/base/ring.c
Normal file
150
package/mtk/drivers/conninfra/src/base/ring.c
Normal file
@ -0,0 +1,150 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
#include "ring.h"
|
||||
#include <linux/string.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/bug.h>
|
||||
|
||||
|
||||
void ring_init(void *base, unsigned int max_size, unsigned int read,
|
||||
unsigned int write, struct ring *ring)
|
||||
{
|
||||
WARN_ON(!base);
|
||||
|
||||
/* making sure max_size is power of 2 */
|
||||
WARN_ON(!max_size || (max_size & (max_size - 1)));
|
||||
|
||||
/* making sure write largger than read */
|
||||
WARN_ON(read > write);
|
||||
|
||||
ring->base = base;
|
||||
ring->read = read;
|
||||
ring->write = write;
|
||||
ring->max_size = max_size;
|
||||
}
|
||||
|
||||
void ring_dump(const char *title, struct ring *ring)
|
||||
{
|
||||
pr_info("[%s] ring:{write=%d, read=%d, max_size=%d}\n",
|
||||
title, ring->write, ring->read, ring->max_size);
|
||||
}
|
||||
|
||||
void ring_dump_segment(const char *title, struct ring_segment *seg)
|
||||
{
|
||||
pr_info("[%s] seg:{ring_pt=0x%p, data_pos=%d, sz=%d, remain=%d}\n",
|
||||
title, seg->ring_pt, seg->data_pos,
|
||||
seg->sz, seg->remain);
|
||||
}
|
||||
|
||||
/*
|
||||
* Function prepares the ring_segment and
|
||||
* returns the number of valid bytes for read.
|
||||
*/
|
||||
unsigned int ring_read_prepare(unsigned int sz,
|
||||
struct ring_segment *seg,
|
||||
struct ring *ring)
|
||||
{
|
||||
unsigned int wt = ring->write;
|
||||
unsigned int rd = ring->read;
|
||||
|
||||
memset(seg, 0, sizeof(struct ring_segment));
|
||||
if (sz > wt - rd)
|
||||
sz = wt - rd;
|
||||
seg->remain = sz;
|
||||
/* ring_dump(__func__, ring); */
|
||||
/* ring_dump_segment(__func__, seg); */
|
||||
return seg->remain;
|
||||
}
|
||||
|
||||
/*
|
||||
* Function prepares the ring_segment and
|
||||
* returns the number of bytes available for write.
|
||||
*/
|
||||
unsigned int ring_write_prepare(unsigned int sz,
|
||||
struct ring_segment *seg,
|
||||
struct ring *ring)
|
||||
{
|
||||
unsigned int wt = ring->write;
|
||||
unsigned int rd = ring->read;
|
||||
|
||||
memset(seg, 0, sizeof(struct ring_segment));
|
||||
if (sz > ring->max_size - (wt - rd))
|
||||
sz = ring->max_size - (wt - rd);
|
||||
seg->remain = sz;
|
||||
/* ring_dump(__func__, ring); */
|
||||
/* ring_dump_segment(__func__, seg); */
|
||||
return seg->remain;
|
||||
}
|
||||
|
||||
unsigned int ring_overwrite_prepare(unsigned int sz, struct ring_segment *seg,
|
||||
struct ring *ring)
|
||||
{
|
||||
unsigned int wt = ring->write;
|
||||
unsigned int rd = ring->read;
|
||||
|
||||
memset(seg, 0, sizeof(struct ring_segment));
|
||||
if (sz > ring->max_size - (wt - rd))
|
||||
ring->read += sz - (ring->max_size - (wt - rd));
|
||||
seg->remain = sz;
|
||||
/* ring_dump(__func__, ring); */
|
||||
/* ring_dump_segment(__func__, seg); */
|
||||
return seg->remain;
|
||||
}
|
||||
|
||||
void __ring_segment_prepare(unsigned int from, unsigned int sz,
|
||||
struct ring_segment *seg,
|
||||
struct ring *ring)
|
||||
{
|
||||
unsigned int ring_pos = from & (ring->max_size - 1);
|
||||
|
||||
seg->ring_pt = ring->base + ring_pos;
|
||||
seg->data_pos = (seg->sz ? seg->data_pos + seg->sz : 0);
|
||||
if (ring_pos + sz <= ring->max_size)
|
||||
seg->sz = sz;
|
||||
else
|
||||
seg->sz = ring->max_size - ring_pos;
|
||||
seg->remain -= seg->sz;
|
||||
/* ring_dump(__func__, ring); */
|
||||
/* ring_dump_segment(__func__, seg); */
|
||||
}
|
||||
|
||||
void _ring_segment_prepare(unsigned int from,
|
||||
struct ring_segment *seg,
|
||||
struct ring *ring)
|
||||
{
|
||||
__ring_segment_prepare(from, seg->remain, seg, ring);
|
||||
}
|
||||
|
||||
void _ring_segment_prepare_item(unsigned int from,
|
||||
struct ring_segment *seg,
|
||||
struct ring *ring)
|
||||
{
|
||||
unsigned int size;
|
||||
|
||||
size = (seg->remain ? 1 : 0);
|
||||
__ring_segment_prepare(from, size, seg, ring);
|
||||
}
|
||||
|
||||
void _ring_read_commit(struct ring_segment *seg, struct ring *ring)
|
||||
{
|
||||
ring->read += seg->sz;
|
||||
/* ring_dump(__func__, ring); */
|
||||
/* ring_dump_segment(__func__, seg); */
|
||||
}
|
||||
void _ring_write_commit(struct ring_segment *seg, struct ring *ring)
|
||||
{
|
||||
ring->write += seg->sz;
|
||||
/* ring_dump(__func__, ring); */
|
||||
/* ring_dump_segment(__func__, seg); */
|
||||
}
|
||||
|
1244
package/mtk/drivers/conninfra/src/core/conninfra_core.c
Normal file
1244
package/mtk/drivers/conninfra/src/core/conninfra_core.c
Normal file
File diff suppressed because it is too large
Load Diff
193
package/mtk/drivers/conninfra/src/core/include/conninfra_core.h
Normal file
193
package/mtk/drivers/conninfra/src/core/include/conninfra_core.h
Normal file
@ -0,0 +1,193 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _CONNINFRA_CORE_H_
|
||||
#define _CONNINFRA_CORE_H_
|
||||
|
||||
#include <linux/semaphore.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/workqueue.h>
|
||||
#include <linux/time.h>
|
||||
|
||||
#include "osal.h"
|
||||
#include "msg_thread.h"
|
||||
#include "conninfra.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define CHIP_RST_REASON_MAX_LEN 128
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
typedef enum _ENUM_DRV_STS_ {
|
||||
DRV_STS_POWER_OFF = 0, /* initial state */
|
||||
DRV_STS_POWER_ON = 1, /* powered on */
|
||||
DRV_STS_MAX
|
||||
} ENUM_DRV_STS, *P_ENUM_DRV_STS;
|
||||
|
||||
enum chip_rst_status {
|
||||
CHIP_RST_NONE = 0,
|
||||
CHIP_RST_START = 1,
|
||||
CHIP_RST_PRE_CB = 2,
|
||||
CHIP_RST_RESET = 3,
|
||||
CHIP_RST_POST_CB = 4,
|
||||
CHIP_RST_DONE = 5
|
||||
};
|
||||
|
||||
struct subsys_drv_inst {
|
||||
ENUM_DRV_STS drv_status; /* Controlled driver status */
|
||||
unsigned int rst_state;
|
||||
struct sub_drv_ops_cb ops_cb;
|
||||
struct msg_thread_ctx msg_ctx;
|
||||
};
|
||||
|
||||
/*
|
||||
* state of conninfra
|
||||
*
|
||||
*/
|
||||
struct conninfra_ctx {
|
||||
ENUM_DRV_STS infra_drv_status;
|
||||
|
||||
struct subsys_drv_inst drv_inst[CONNDRV_TYPE_MAX];
|
||||
/*struct spinlock infra_lock;*/
|
||||
spinlock_t infra_lock;
|
||||
|
||||
OSAL_SLEEPABLE_LOCK core_lock;
|
||||
|
||||
/* chip reset */
|
||||
enum chip_rst_status rst_status;
|
||||
spinlock_t rst_lock;
|
||||
|
||||
struct semaphore rst_sema;
|
||||
atomic_t rst_state;
|
||||
enum consys_drv_type trg_drv;
|
||||
char trg_reason[CHIP_RST_REASON_MAX_LEN];
|
||||
|
||||
struct msg_thread_ctx msg_ctx;
|
||||
struct msg_thread_ctx cb_ctx;
|
||||
|
||||
unsigned int hw_ver;
|
||||
unsigned int fw_ver;
|
||||
unsigned int ip_ver;
|
||||
};
|
||||
|
||||
//typedef enum _ENUM_CONNINFRA_CORE_OPID_T {
|
||||
typedef enum {
|
||||
CONNINFRA_OPID_PWR_ON = 0,
|
||||
CONNINFRA_OPID_PWR_OFF = 1,
|
||||
CONNINFRA_OPID_RFSPI_READ = 2,
|
||||
CONNINFRA_OPID_RFSPI_WRITE = 3,
|
||||
CONNINFRA_OPID_ADIE_TOP_CK_EN_ON = 4,
|
||||
CONNINFRA_OPID_ADIE_TOP_CK_EN_OFF = 5,
|
||||
CONNINFRA_OPID_SPI_CLOCK_SWITCH = 6,
|
||||
CONNINFRA_OPID_FORCE_CONNINFRA_WAKUP = 7,
|
||||
CONNINFRA_OPID_FORCE_CONNINFRA_SLEEP = 8,
|
||||
CONNINFRA_OPID_DUMP_POWER_STATE = 9,
|
||||
CONNINFRA_OPID_MAX
|
||||
} conninfra_core_opid;
|
||||
|
||||
/* For the operation which may callback subsys driver */
|
||||
typedef enum {
|
||||
CONNINFRA_CB_OPID_CHIP_RST = 0,
|
||||
CONNINFRA_CB_OPID_MAX
|
||||
} conninfra_core_cb_opid;
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
extern int conninfra_core_init(void);
|
||||
extern int conninfra_core_deinit(void);
|
||||
|
||||
int conninfra_core_power_on(enum consys_drv_type type);
|
||||
int conninfra_core_power_off(enum consys_drv_type type);
|
||||
|
||||
int conninfra_core_lock_rst(void);
|
||||
int conninfra_core_unlock_rst(void);
|
||||
int conninfra_core_trg_chip_rst(enum consys_drv_type drv, char *reason);
|
||||
|
||||
int conninfra_core_subsys_ops_reg(enum consys_drv_type type, struct sub_drv_ops_cb *cb);
|
||||
int conninfra_core_subsys_ops_unreg(enum consys_drv_type type);
|
||||
|
||||
/* reg control */
|
||||
/* NOTE: NOT thread-safe
|
||||
* return value
|
||||
* 1 : Yes, 0: NO
|
||||
*/
|
||||
int conninfra_core_reg_readable(void);
|
||||
int conninfra_core_reg_readable_no_lock(void);
|
||||
int conninfra_core_is_bus_hang(void);
|
||||
|
||||
int conninfra_core_is_consys_reg(phys_addr_t addr);
|
||||
int conninfra_core_reg_read(unsigned long address, unsigned int *value, unsigned int mask);
|
||||
int conninfra_core_reg_write(unsigned long address, unsigned int value, unsigned int mask);
|
||||
|
||||
int conninfra_core_is_rst_locking(void);
|
||||
|
||||
int conninfra_core_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data);
|
||||
int conninfra_core_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data);
|
||||
|
||||
int conninfra_core_adie_top_ck_en_on(enum consys_drv_type type);
|
||||
int conninfra_core_adie_top_ck_en_off(enum consys_drv_type type);
|
||||
|
||||
int conninfra_core_force_conninfra_wakeup(void);
|
||||
int conninfra_core_force_conninfra_sleep(void);
|
||||
|
||||
int conninfra_core_spi_clock_switch(enum connsys_spi_speed_type type);
|
||||
|
||||
int conninfra_core_dump_power_state(void);
|
||||
int conninfra_core_pmic_event_cb(unsigned int, unsigned int);
|
||||
int conninfra_core_debug_dump(void);
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _CONNINFRA_CORE_H_ */
|
216
package/mtk/drivers/conninfra/src/include/conninfra.h
Normal file
216
package/mtk/drivers/conninfra/src/include/conninfra.h
Normal file
@ -0,0 +1,216 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _CONNINFRA_H_
|
||||
#define _CONNINFRA_H_
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
#define AIDE_NUM_MAX 2
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
enum consys_drv_type {
|
||||
CONNDRV_TYPE_BT = 0,
|
||||
CONNDRV_TYPE_FM = 1,
|
||||
CONNDRV_TYPE_GPS = 2,
|
||||
CONNDRV_TYPE_WIFI = 3,
|
||||
CONNDRV_TYPE_CONNINFRA = 4,
|
||||
CONNDRV_TYPE_MAX
|
||||
};
|
||||
|
||||
/* HW-specific, need sync with FW. DO NOT MODIFY */
|
||||
enum sys_spi_subsystem
|
||||
{
|
||||
SYS_SPI_WF1 = 0x00,
|
||||
SYS_SPI_WF = 0x01,
|
||||
SYS_SPI_BT = 0x02,
|
||||
SYS_SPI_FM = 0x03,
|
||||
SYS_SPI_GPS = 0x04,
|
||||
SYS_SPI_TOP = 0x05,
|
||||
SYS_SPI_WF2 = 0x06,
|
||||
SYS_SPI_WF3 = 0x07,
|
||||
SYS_SPI_2ND_ADIE_WF1 = 0x10,
|
||||
SYS_SPI_2ND_ADIE_WF = 0x11,
|
||||
SYS_SPI_2ND_ADIE_BT = 0x12,
|
||||
SYS_SPI_2ND_ADIE_FM = 0x13,
|
||||
SYS_SPI_2ND_ADIE_GPS = 0x14,
|
||||
SYS_SPI_2ND_ADIE_TOP = 0x15,
|
||||
SYS_SPI_2ND_ADIE_WF2 = 0x16,
|
||||
SYS_SPI_2ND_ADIE_WF3 = 0x17,
|
||||
SYS_SPI_MAX
|
||||
};
|
||||
|
||||
enum connsys_spi_speed_type {
|
||||
CONNSYS_SPI_SPEED_26M,
|
||||
CONNSYS_SPI_SPEED_64M,
|
||||
CONNSYS_SPI_SPEED_MAX
|
||||
};
|
||||
|
||||
/* Conninfra driver allocate EMI for FW and WFDAM
|
||||
* (FW includes: BT, WIFI and their MCU)
|
||||
* +-----------+ +
|
||||
* | | |
|
||||
* | FW | |
|
||||
* | | |
|
||||
* +-----------+ v
|
||||
* | |
|
||||
* | | FW_WFDMA
|
||||
* | | ^
|
||||
* | WFDMA | |
|
||||
* | | |
|
||||
* | | |
|
||||
* +-----------+ +
|
||||
*
|
||||
* MCIF region is provided by MD
|
||||
* +-----------+
|
||||
* | |
|
||||
* | |
|
||||
* | MCIF |
|
||||
* | |
|
||||
* +-----------+
|
||||
*/
|
||||
enum connsys_emi_type
|
||||
{
|
||||
CONNSYS_EMI_FW = 0,
|
||||
CONNSYS_EMI_MAX,
|
||||
};
|
||||
|
||||
#define CONNINFRA_SPI_OP_FAIL 0x1
|
||||
|
||||
#define CONNINFRA_CB_RET_CAL_PASS_POWER_OFF 0x0
|
||||
#define CONNINFRA_CB_RET_CAL_PASS_POWER_ON 0x2
|
||||
#define CONNINFRA_CB_RET_CAL_FAIL_POWER_OFF 0x1
|
||||
#define CONNINFRA_CB_RET_CAL_FAIL_POWER_ON 0x3
|
||||
|
||||
#define CONNINFRA_BUS_CLOCK_WPLL 0x1
|
||||
#define CONNINFRA_BUS_CLOCK_ALL (CONNINFRA_BUS_CLOCK_WPLL)
|
||||
|
||||
/* bus hang error define */
|
||||
#define CONNINFRA_INFRA_BUS_HANG 0x1
|
||||
#define CONNINFRA_AP2CONN_RX_SLP_PROT_ERR 0x2
|
||||
#define CONNINFRA_AP2CONN_TX_SLP_PROT_ERR 0x4
|
||||
#define CONNINFRA_AP2CONN_CLK_ERR 0x8
|
||||
#define CONNINFRA_INFRA_BUS_HANG_IRQ 0x10
|
||||
|
||||
#define CONNINFRA_ERR_RST_ONGOING -0x7788
|
||||
#define CONNINFRA_ERR_WAKEUP_FAIL -0x5566
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/* SPI clock switch */
|
||||
int conninfra_spi_clock_switch(enum connsys_spi_speed_type type);
|
||||
|
||||
/* A-die top_ck_en control, only for MT6885 */
|
||||
int conninfra_adie_top_ck_en_on(enum consys_drv_type type);
|
||||
int conninfra_adie_top_ck_en_off(enum consys_drv_type type);
|
||||
|
||||
/* RFSPI */
|
||||
int conninfra_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data);
|
||||
int conninfra_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data);
|
||||
|
||||
/* EMI */
|
||||
void conninfra_get_emi_phy_addr(enum connsys_emi_type type, phys_addr_t* base, unsigned int *size);
|
||||
|
||||
/* power on/off */
|
||||
int conninfra_pwr_on(enum consys_drv_type drv_type);
|
||||
int conninfra_pwr_off(enum consys_drv_type drv_type);
|
||||
|
||||
/* To setup config relative data, ex: debug flag */
|
||||
void conninfra_config_setup(void);
|
||||
|
||||
/*
|
||||
* 0 : NO hang
|
||||
* > 0 : HANG!!
|
||||
* CONNINFRA_ERR_RST_ONGOING: whole chip reset is ongoing
|
||||
*/
|
||||
int conninfra_is_bus_hang(void);
|
||||
|
||||
/* chip reset
|
||||
* return:
|
||||
* <0: error
|
||||
* =0: triggered
|
||||
* =1: ongoing
|
||||
*/
|
||||
int conninfra_trigger_whole_chip_rst(enum consys_drv_type drv, char *reason);
|
||||
|
||||
int conninfra_debug_dump(void);
|
||||
|
||||
struct whole_chip_rst_cb {
|
||||
int (*pre_whole_chip_rst)(enum consys_drv_type drv, char *reason);
|
||||
int (*post_whole_chip_rst)(void);
|
||||
};
|
||||
|
||||
/* driver state query */
|
||||
|
||||
/* VCN control */
|
||||
|
||||
/* Thermal */
|
||||
|
||||
/* Config */
|
||||
|
||||
/* semaphore */
|
||||
|
||||
/* calibration */
|
||||
|
||||
struct sub_drv_ops_cb {
|
||||
/* chip reset */
|
||||
struct whole_chip_rst_cb rst_cb;
|
||||
};
|
||||
|
||||
int conninfra_sub_drv_ops_register(enum consys_drv_type drv_type, struct sub_drv_ops_cb *cb);
|
||||
int conninfra_sub_drv_ops_unregister(enum consys_drv_type drv_type);
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _CONNINFRA_H_ */
|
663
package/mtk/drivers/conninfra/src/platform/consys_hw.c
Normal file
663
package/mtk/drivers/conninfra/src/platform/consys_hw.c
Normal file
@ -0,0 +1,663 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
|
||||
#include <linux/delay.h>
|
||||
#include <linux/of_device.h>
|
||||
#include <linux/of_reserved_mem.h>
|
||||
|
||||
#include "osal.h"
|
||||
#include "consys_hw.h"
|
||||
#include "emi_mng.h"
|
||||
#include "pmic_mng.h"
|
||||
#include "consys_reg_mng.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
static int mtk_conninfra_probe(struct platform_device *pdev);
|
||||
static int mtk_conninfra_remove(struct platform_device *pdev);
|
||||
static int mtk_conninfra_suspend(struct platform_device *pdev, pm_message_t state);
|
||||
static int mtk_conninfra_resume(struct platform_device *pdev);
|
||||
|
||||
static int consys_hw_init(struct platform_device *pdev);
|
||||
static int consys_hw_deinit(void);
|
||||
static int _consys_hw_conninfra_wakeup(void);
|
||||
static int _consys_hw_conninfra_sleep(void);
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
extern const struct of_device_id apconninfra_of_ids[];
|
||||
|
||||
static struct platform_driver mtk_conninfra_dev_drv = {
|
||||
.probe = mtk_conninfra_probe,
|
||||
.remove = mtk_conninfra_remove,
|
||||
.suspend = mtk_conninfra_suspend,
|
||||
.resume = mtk_conninfra_resume,
|
||||
.driver = {
|
||||
.name = "mtk_conninfra",
|
||||
.owner = THIS_MODULE,
|
||||
.of_match_table = apconninfra_of_ids,
|
||||
},
|
||||
};
|
||||
|
||||
|
||||
struct consys_hw_env conn_hw_env[AIDE_NUM_MAX];
|
||||
|
||||
const struct consys_hw_ops_struct *consys_hw_ops;
|
||||
struct platform_device *g_pdev;
|
||||
|
||||
int g_conninfra_wakeup_ref_cnt;
|
||||
|
||||
struct work_struct ap_resume_work;
|
||||
|
||||
struct conninfra_dev_cb *g_conninfra_dev_cb;
|
||||
const struct conninfra_plat_data *g_conninfra_plat_data = NULL;
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
struct platform_device *get_consys_device(void)
|
||||
{
|
||||
return g_pdev;
|
||||
}
|
||||
|
||||
int consys_hw_get_clock_schematic(void)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_co_clock_type)
|
||||
return consys_hw_ops->consys_plt_co_clock_type();
|
||||
else
|
||||
pr_err("consys_hw_ops->consys_co_clock_type not supported\n");
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
unsigned int consys_hw_chipid_get(void)
|
||||
{
|
||||
if (g_conninfra_plat_data && g_conninfra_plat_data->chip_id)
|
||||
return g_conninfra_plat_data->chip_id;
|
||||
else if (consys_hw_ops->consys_plt_soc_chipid_get)
|
||||
return consys_hw_ops->consys_plt_soc_chipid_get();
|
||||
else
|
||||
pr_err("consys_plt_soc_chipid_get not supported\n");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
unsigned int consys_hw_get_hw_ver(void)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_get_hw_ver)
|
||||
return consys_hw_ops->consys_plt_get_hw_ver();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int consys_hw_reg_readable(void)
|
||||
{
|
||||
return consys_reg_mng_reg_readable();
|
||||
}
|
||||
|
||||
int consys_hw_is_connsys_reg(phys_addr_t addr)
|
||||
{
|
||||
return consys_reg_mng_is_connsys_reg(addr);
|
||||
}
|
||||
|
||||
int consys_hw_is_bus_hang(void)
|
||||
{
|
||||
return consys_reg_mng_is_bus_hang();
|
||||
}
|
||||
|
||||
int consys_hw_dump_bus_status(void)
|
||||
{
|
||||
return consys_reg_mng_dump_bus_status();
|
||||
}
|
||||
|
||||
int consys_hw_dump_cpupcr(enum conn_dump_cpupcr_type dump_type, int times, unsigned long interval_us)
|
||||
{
|
||||
return consys_reg_mng_dump_cpupcr(dump_type, times, interval_us);
|
||||
}
|
||||
|
||||
int consys_hw_pwr_on(unsigned int curr_status, unsigned int on_radio)
|
||||
{
|
||||
//unsigned int next_status = (curr_status | (0x1 << on_radio));
|
||||
|
||||
/* first power on */
|
||||
if (curr_status == 0) {
|
||||
/* POS PART 0:
|
||||
* Set PMIC to turn on the power that AFE WBG circuit in D-die,
|
||||
* OSC or crystal component, and A-die need.
|
||||
*/
|
||||
if (consys_hw_ops->consys_plt_xtal_ctrl_fast_mode)
|
||||
consys_hw_ops->consys_plt_xtal_ctrl_fast_mode();
|
||||
|
||||
if (consys_hw_ops->consys_plt_connsys_sw_reset_ctrl)
|
||||
consys_hw_ops->consys_plt_connsys_sw_reset_ctrl(false);
|
||||
|
||||
/* POS PART 1:
|
||||
* 1. Pinmux setting
|
||||
* 2. Turn on MTCMOS
|
||||
* 3. Enable AHB bus
|
||||
*/
|
||||
if (consys_hw_ops->consys_plt_set_if_pinmux)
|
||||
consys_hw_ops->consys_plt_set_if_pinmux(true);
|
||||
|
||||
udelay(500);
|
||||
|
||||
if (consys_hw_ops->consys_plt_tx_rx_bus_slp_prot_ctrl)
|
||||
consys_hw_ops->consys_plt_tx_rx_bus_slp_prot_ctrl(true);
|
||||
|
||||
if (consys_hw_ops->consys_plt_polling_consys_chipid)
|
||||
consys_hw_ops->consys_plt_polling_consys_chipid();
|
||||
|
||||
/* POS PART 2:
|
||||
* 1. Set connsys EMI mapping
|
||||
* 2. d_die_cfg
|
||||
* 3. spi_master_cfg
|
||||
* 4. a_die_cfg
|
||||
* 5. afe_wbg_cal
|
||||
* 6. patch default value
|
||||
* 7. CONN_INFRA low power setting (srcclken wait time, mtcmos HW ctl...)
|
||||
*/
|
||||
if (consys_hw_ops->consys_plt_bus_clock_ctrl)
|
||||
consys_hw_ops->consys_plt_bus_clock_ctrl(on_radio, CONNINFRA_BUS_CLOCK_ALL);
|
||||
|
||||
emi_mng_set_remapping_reg();
|
||||
emi_mng_set_region_protection();
|
||||
|
||||
if (consys_hw_ops->consys_plt_d_die_cfg)
|
||||
consys_hw_ops->consys_plt_d_die_cfg();
|
||||
|
||||
if (consys_hw_ops->consys_plt_conninfra_sysram_hw_ctrl)
|
||||
consys_hw_ops->consys_plt_conninfra_sysram_hw_ctrl();
|
||||
|
||||
if (consys_hw_ops->consys_plt_spi_master_cfg)
|
||||
consys_hw_ops->consys_plt_spi_master_cfg();
|
||||
|
||||
#ifndef CONFIG_FPGA_EARLY_PORTING
|
||||
if (consys_hw_ops->consys_plt_adie_type_check)
|
||||
consys_hw_ops->consys_plt_adie_type_check();
|
||||
|
||||
if (consys_hw_ops->consys_plt_a_die_cfg)
|
||||
consys_hw_ops->consys_plt_a_die_cfg();
|
||||
#endif
|
||||
|
||||
if (consys_hw_ops->consys_plt_afe_wbg_cal)
|
||||
consys_hw_ops->consys_plt_afe_wbg_cal();
|
||||
|
||||
if (consys_hw_ops->consys_plt_subsys_pll_initial)
|
||||
consys_hw_ops->consys_plt_subsys_pll_initial();
|
||||
|
||||
if (consys_hw_ops->consys_plt_osc_legacy_mode)
|
||||
consys_hw_ops->consys_plt_osc_legacy_mode();
|
||||
|
||||
#ifndef CONFIG_FPGA_EARLY_PORTING
|
||||
if (consys_hw_ops->consys_plt_top_pwr_ctrl)
|
||||
consys_hw_ops->consys_plt_top_pwr_ctrl();
|
||||
#endif
|
||||
|
||||
if (consys_hw_ops->consys_plt_conn_infra_bus_timeout)
|
||||
consys_hw_ops->consys_plt_conn_infra_bus_timeout();
|
||||
|
||||
if (consys_hw_ops->consys_plt_clkgen_wpll_hw_ctrl)
|
||||
consys_hw_ops->consys_plt_clkgen_wpll_hw_ctrl();
|
||||
|
||||
/* POS PART 3:
|
||||
* 1. A-die low power setting
|
||||
* 2. bgfsys power on(BT/GPS on)
|
||||
*/
|
||||
consys_hw_force_conninfra_wakeup();
|
||||
#ifndef CONFIG_FPGA_EARLY_PORTING
|
||||
consys_hw_adie_top_ck_en_on(on_radio);
|
||||
//consys_hw_adie_top_ck_en_off(on_radio);
|
||||
#endif
|
||||
consys_hw_force_conninfra_sleep();
|
||||
}else {
|
||||
switch (on_radio) {
|
||||
case CONNDRV_TYPE_WIFI:
|
||||
/* Power on WFSYS PART 0:
|
||||
* 1. wake up conn_infra
|
||||
* 2. turn on MTCMOS power switch of "wfsys_top_on" and "wfsys_top_off" circuit in D-die ("wfsys_top_off" is turned on by "wfsys_top_on" automatically)
|
||||
* 3. enable AHB bus(WF2conn/conn2WF)
|
||||
* 4. downlad CONNSYS EMI code
|
||||
* 5. patch default value
|
||||
*/
|
||||
if (consys_hw_ops->consys_plt_conninfra_wf_wakeup)
|
||||
consys_hw_ops->consys_plt_conninfra_wf_wakeup();
|
||||
|
||||
if (consys_hw_ops->consys_plt_conn_wmcpu_sw_reset)
|
||||
consys_hw_ops->consys_plt_conn_wmcpu_sw_reset(true);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wf_bus_slp_prot_ctrl)
|
||||
consys_hw_ops->consys_plt_wf_bus_slp_prot_ctrl(false);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wfsys_top_on_ctrl)
|
||||
consys_hw_ops->consys_plt_wfsys_top_on_ctrl(true);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wfsys_bus_slp_prot_check)
|
||||
consys_hw_ops->consys_plt_wfsys_bus_slp_prot_check(true);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wfsys_bus_timeout_ctrl)
|
||||
consys_hw_ops->consys_plt_wfsys_bus_timeout_ctrl();
|
||||
|
||||
if (consys_hw_ops->consys_plt_conn_wmcpu_sw_reset)
|
||||
consys_hw_ops->consys_plt_conn_wmcpu_sw_reset(false);
|
||||
|
||||
#ifndef CONFIG_FPGA_EARLY_PORTING
|
||||
if (consys_hw_ops->consys_plt_conn_wmcpu_idle_loop_check)
|
||||
consys_hw_ops->consys_plt_conn_wmcpu_idle_loop_check();
|
||||
|
||||
if (consys_hw_ops->consys_plt_adie_type_cfg)
|
||||
consys_hw_ops->consys_plt_adie_type_cfg();
|
||||
#endif
|
||||
/* No sleep requiremenct for rebb AP */
|
||||
#if 0
|
||||
if (consys_hw_ops->consys_plt_conninfra_wf_sleep)
|
||||
consys_hw_ops->consys_plt_conninfra_wf_sleep();
|
||||
#endif
|
||||
break;
|
||||
|
||||
default:
|
||||
pr_err("Not support type now (on_radio = %d)\n", on_radio);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int consys_hw_pwr_off(unsigned int curr_status, unsigned int off_radio)
|
||||
{
|
||||
//int ret = 0;
|
||||
unsigned int next_status = curr_status & ~(0x1 << off_radio);
|
||||
|
||||
if (next_status == 0) {
|
||||
pr_info("Last pwoer off: %d\n", off_radio);
|
||||
|
||||
/* Power off CONNSYS PART 0:
|
||||
* 1. A-die low power setting
|
||||
*/
|
||||
consys_hw_force_conninfra_wakeup();
|
||||
#ifndef CONFIG_FPGA_EARLY_PORTING
|
||||
//consys_hw_adie_top_ck_en_off(off_radio);
|
||||
#endif
|
||||
consys_hw_force_conninfra_sleep();
|
||||
|
||||
/* Power off CONNSYS PART 1:
|
||||
* 1. disable AXI bus
|
||||
* 2. turn off MTCMOS power switch of "conn_top_on" and "conn_top_off" circuit in D-die
|
||||
*/
|
||||
if (consys_hw_ops->consys_plt_tx_rx_bus_slp_prot_ctrl)
|
||||
consys_hw_ops->consys_plt_tx_rx_bus_slp_prot_ctrl(false);
|
||||
|
||||
if (consys_hw_ops->consys_plt_connsys_sw_reset_ctrl)
|
||||
consys_hw_ops->consys_plt_connsys_sw_reset_ctrl(true);
|
||||
|
||||
udelay(1);
|
||||
} else {
|
||||
switch (off_radio) {
|
||||
case CONNDRV_TYPE_WIFI:
|
||||
/* Power off WFSYS PART 1:
|
||||
* 1. disable AXI bus(wf2conn/conn2wf)
|
||||
* 2. turn off MTCMOS power switch of "wf_top_on" and "wf_top_off" circuit in D-die ("wf_top_off" is turned off by "wf_top_on" automatically)
|
||||
*/
|
||||
if (consys_hw_ops->consys_plt_conninfra_wf_wakeup)
|
||||
consys_hw_ops->consys_plt_conninfra_wf_wakeup();
|
||||
|
||||
if (consys_hw_ops->consys_plt_wf_bus_slp_prot_ctrl)
|
||||
consys_hw_ops->consys_plt_wf_bus_slp_prot_ctrl(true);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wfsys_bus_slp_prot_check)
|
||||
consys_hw_ops->consys_plt_wfsys_bus_slp_prot_check(false);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wpll_ctrl)
|
||||
consys_hw_ops->consys_plt_wpll_ctrl(false);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wfsys_top_on_ctrl)
|
||||
consys_hw_ops->consys_plt_wfsys_top_on_ctrl(false);
|
||||
|
||||
if (consys_hw_ops->consys_plt_wpll_ctrl)
|
||||
consys_hw_ops->consys_plt_wpll_ctrl(true);
|
||||
|
||||
consys_hw_adie_top_ck_en_off(off_radio);
|
||||
|
||||
if (consys_hw_ops->consys_plt_conninfra_wf_req_clr)
|
||||
consys_hw_ops->consys_plt_conninfra_wf_req_clr();
|
||||
|
||||
if (consys_hw_ops->consys_plt_conninfra_wf_sleep)
|
||||
consys_hw_ops->consys_plt_conninfra_wf_sleep();
|
||||
break;
|
||||
|
||||
default:
|
||||
consys_hw_force_conninfra_wakeup();
|
||||
consys_hw_adie_top_ck_en_off(off_radio);
|
||||
consys_hw_force_conninfra_sleep();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int consys_hw_wifi_power_ctl(unsigned int enable)
|
||||
{
|
||||
return pmic_mng_wifi_power_ctrl(enable);
|
||||
}
|
||||
|
||||
int consys_hw_bt_power_ctl(unsigned int enable)
|
||||
{
|
||||
return pmic_mng_bt_power_ctrl(enable);
|
||||
}
|
||||
|
||||
int consys_hw_gps_power_ctl(unsigned int enable)
|
||||
{
|
||||
return pmic_mng_gps_power_ctrl(enable);
|
||||
}
|
||||
|
||||
int consys_hw_fm_power_ctl(unsigned int enable)
|
||||
{
|
||||
return pmic_mng_fm_power_ctrl(enable);
|
||||
}
|
||||
|
||||
int consys_hw_dump_power_state(void)
|
||||
{
|
||||
if (consys_hw_ops && consys_hw_ops->consys_plt_power_state)
|
||||
consys_hw_ops->consys_plt_power_state();
|
||||
return 0;
|
||||
}
|
||||
|
||||
int consys_hw_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_spi_read)
|
||||
return consys_hw_ops->consys_plt_spi_read(subsystem, addr, data);
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_hw_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_spi_write)
|
||||
return consys_hw_ops->consys_plt_spi_write(subsystem, addr, data);
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_hw_adie_top_ck_en_on(enum consys_drv_type type)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_adie_top_ck_en_on_off_ctrl)
|
||||
return consys_hw_ops->consys_plt_adie_top_ck_en_on_off_ctrl(type, 1);
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_hw_adie_top_ck_en_off(enum consys_drv_type type)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_adie_top_ck_en_on_off_ctrl)
|
||||
return consys_hw_ops->consys_plt_adie_top_ck_en_on_off_ctrl(type, 0);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
static int _consys_hw_conninfra_wakeup(void)
|
||||
{
|
||||
int ref = g_conninfra_wakeup_ref_cnt;
|
||||
bool wakeup = false, ret;
|
||||
|
||||
if (consys_hw_ops->consys_plt_conninfra_wakeup) {
|
||||
if (g_conninfra_wakeup_ref_cnt == 0) {
|
||||
ret = consys_hw_ops->consys_plt_conninfra_wakeup();
|
||||
if (ret) {
|
||||
pr_err("wakeup fail!! ret=[%d]\n", ret);
|
||||
return ret;
|
||||
}
|
||||
wakeup = true;
|
||||
}
|
||||
|
||||
g_conninfra_wakeup_ref_cnt++;
|
||||
}
|
||||
|
||||
pr_info("conninfra_wakeup refcnt=[%d]->[%d] %s\n",
|
||||
ref, g_conninfra_wakeup_ref_cnt, (wakeup ? "wakeup!!" : ""));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int _consys_hw_conninfra_sleep(void)
|
||||
{
|
||||
int ref = g_conninfra_wakeup_ref_cnt;
|
||||
bool sleep = false;
|
||||
|
||||
if (consys_hw_ops->consys_plt_conninfra_sleep &&
|
||||
--g_conninfra_wakeup_ref_cnt == 0) {
|
||||
sleep = true;
|
||||
consys_hw_ops->consys_plt_conninfra_sleep();
|
||||
}
|
||||
|
||||
if (g_conninfra_wakeup_ref_cnt < 0)
|
||||
g_conninfra_wakeup_ref_cnt = 0;
|
||||
|
||||
pr_info("conninfra_sleep refcnt=[%d]->[%d] %s\n",
|
||||
ref, g_conninfra_wakeup_ref_cnt, (sleep ? "sleep!!" : ""));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int consys_hw_force_conninfra_wakeup(void)
|
||||
{
|
||||
return _consys_hw_conninfra_wakeup();
|
||||
}
|
||||
|
||||
int consys_hw_force_conninfra_sleep(void)
|
||||
{
|
||||
return _consys_hw_conninfra_sleep();
|
||||
}
|
||||
|
||||
int consys_hw_spi_clock_switch(enum connsys_spi_speed_type type)
|
||||
{
|
||||
if (consys_hw_ops->consys_plt_spi_clock_switch)
|
||||
return consys_hw_ops->consys_plt_spi_clock_switch(type);
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_hw_pmic_event_cb(unsigned int id, unsigned int event)
|
||||
{
|
||||
pmic_mng_event_cb(id, event);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int mtk_conninfra_probe(struct platform_device *pdev)
|
||||
{
|
||||
int ret = -1;
|
||||
|
||||
if (pdev)
|
||||
g_pdev = pdev;
|
||||
else {
|
||||
pr_err("pdev is NULL\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
g_conninfra_plat_data = (const struct conninfra_plat_data*)of_device_get_match_data(&pdev->dev);
|
||||
if (g_conninfra_plat_data == NULL) {
|
||||
pr_err("Get platform data fail.\n");
|
||||
return -2;
|
||||
}
|
||||
|
||||
if (consys_hw_ops == NULL)
|
||||
consys_hw_ops = (const struct consys_hw_ops_struct*)g_conninfra_plat_data->hw_ops;
|
||||
if (consys_hw_ops == NULL) {
|
||||
pr_err("Get HW op fail\n");
|
||||
return -3;
|
||||
}
|
||||
|
||||
/* Read device node */
|
||||
if (consys_reg_mng_init(pdev, g_conninfra_plat_data) != 0) {
|
||||
pr_err("consys_plt_read_reg_from_dts fail\n");
|
||||
return -4;
|
||||
}
|
||||
|
||||
if (consys_hw_ops->consys_plt_clk_get_from_dts) {
|
||||
if (consys_hw_ops->consys_plt_clk_get_from_dts(pdev) != 0) {
|
||||
pr_err("consys_plt_clk_get_from_dts fail\n");
|
||||
return -5;
|
||||
}
|
||||
}
|
||||
|
||||
/* HW operation init */
|
||||
if (consys_hw_init(pdev) != 0) {
|
||||
pr_err("consys_hw_init fail\n");
|
||||
return -6;
|
||||
}
|
||||
|
||||
/* emi mng init */
|
||||
ret = emi_mng_init(pdev, g_conninfra_plat_data);
|
||||
if (ret) {
|
||||
pr_err("emi_mng init fail, %d\n", ret);
|
||||
return -7;
|
||||
}
|
||||
|
||||
ret = pmic_mng_init(pdev, g_conninfra_dev_cb, g_conninfra_plat_data);
|
||||
if (ret) {
|
||||
pr_err("pmic_mng init fail, %d\n", ret);
|
||||
return -8;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int mtk_conninfra_remove(struct platform_device *pdev)
|
||||
{
|
||||
int ret;
|
||||
|
||||
ret = pmic_mng_deinit();
|
||||
pr_info("pmic_mng_deinit ret=%d\n", ret);
|
||||
|
||||
ret = emi_mng_deinit();
|
||||
pr_info("emi_mng_deinit ret=%d\n", ret);
|
||||
|
||||
if (consys_hw_ops->consys_plt_clk_detach)
|
||||
consys_hw_ops->consys_plt_clk_detach();
|
||||
else
|
||||
pr_err("consys_plt_clk_detach is null\n");
|
||||
|
||||
ret = consys_reg_mng_deinit();
|
||||
pr_info("consys_reg_mng_deinit ret=%d\n", ret);
|
||||
|
||||
ret = consys_hw_deinit();
|
||||
pr_info("consys_hw_deinit ret=%d\n", ret);
|
||||
|
||||
if (g_pdev)
|
||||
g_pdev = NULL;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int mtk_conninfra_suspend(struct platform_device *pdev, pm_message_t state)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
int mtk_conninfra_resume(struct platform_device *pdev)
|
||||
{
|
||||
/* suspend callback is in atomic context, use schedule work to execute STEP */
|
||||
|
||||
schedule_work(&ap_resume_work);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void consys_hw_ap_resume_handler(struct work_struct *work)
|
||||
{
|
||||
if (g_conninfra_dev_cb && g_conninfra_dev_cb->conninfra_resume_cb)
|
||||
(*g_conninfra_dev_cb->conninfra_resume_cb)();
|
||||
}
|
||||
|
||||
int consys_hw_init(struct platform_device *pdev)
|
||||
{
|
||||
int iRet = 0;
|
||||
|
||||
if (consys_hw_ops->consys_plt_hw_init)
|
||||
iRet = consys_hw_ops->consys_plt_hw_init();
|
||||
|
||||
return iRet;
|
||||
}
|
||||
|
||||
int consys_hw_deinit(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
int mtk_conninfra_drv_init(struct conninfra_dev_cb *dev_cb)
|
||||
{
|
||||
int iRet = 0;
|
||||
|
||||
g_conninfra_dev_cb = dev_cb;
|
||||
|
||||
pr_info("Before platform_driver_register\n");
|
||||
|
||||
iRet = platform_driver_register(&mtk_conninfra_dev_drv);
|
||||
if (iRet)
|
||||
pr_err("Conninfra platform driver registered failed(%d)\n", iRet);
|
||||
|
||||
pr_info("After platform_driver_register\n");
|
||||
|
||||
INIT_WORK(&ap_resume_work, consys_hw_ap_resume_handler);
|
||||
|
||||
return iRet;
|
||||
}
|
||||
|
||||
int mtk_conninfra_drv_deinit(void)
|
||||
{
|
||||
platform_driver_unregister(&mtk_conninfra_dev_drv);
|
||||
g_conninfra_dev_cb = NULL;
|
||||
return 0;
|
||||
}
|
||||
|
@ -0,0 +1,39 @@
|
||||
// SPDX-License-Identifier: GPL-2.0
|
||||
/*
|
||||
* Copyright (c) 2019 MediaTek Inc.
|
||||
*/
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
#include <linux/of_device.h>
|
||||
|
||||
#include "consys_hw.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/* Platform data */
|
||||
#ifdef CONNINFRA_APSOC_MT7986
|
||||
extern struct conninfra_plat_data mt7986_plat_data;
|
||||
const struct of_device_id apconninfra_of_ids[] = {
|
||||
{
|
||||
.compatible = "mediatek,mt7986-consys",
|
||||
.data = (void*)&mt7986_plat_data,
|
||||
},
|
||||
{}
|
||||
};
|
||||
#endif
|
||||
|
||||
#ifdef CONNINFRA_APSOC_MT7981
|
||||
extern struct conninfra_plat_data mt7981_plat_data;
|
||||
const struct of_device_id apconninfra_of_ids[] = {
|
||||
{
|
||||
.compatible = "mediatek,mt7981-consys",
|
||||
.data = (void*)&mt7981_plat_data,
|
||||
},
|
||||
{}
|
||||
};
|
||||
#endif
|
148
package/mtk/drivers/conninfra/src/platform/consys_reg_mng.c
Normal file
148
package/mtk/drivers/conninfra/src/platform/consys_reg_mng.c
Normal file
@ -0,0 +1,148 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_mng.h"
|
||||
#include "consys_reg_util.h"
|
||||
|
||||
const struct consys_reg_mng_ops* g_consys_reg_ops = NULL;
|
||||
|
||||
int consys_reg_mng_reg_readable(void)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_check_reable)
|
||||
return g_consys_reg_ops->consys_reg_mng_check_reable();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_reg_mng_is_connsys_reg(phys_addr_t addr)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_is_consys_reg)
|
||||
return g_consys_reg_ops->consys_reg_mng_is_consys_reg(addr);
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
int consys_reg_mng_is_bus_hang(void)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_is_bus_hang)
|
||||
return g_consys_reg_ops->consys_reg_mng_is_bus_hang();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_reg_mng_dump_bus_status(void)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_dump_bus_status)
|
||||
return g_consys_reg_ops->consys_reg_mng_dump_bus_status();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_reg_mng_dump_conninfra_status(void)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_dump_conninfra_status)
|
||||
return g_consys_reg_ops->consys_reg_mng_dump_conninfra_status();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_reg_mng_dump_cpupcr(enum conn_dump_cpupcr_type dump_type, int times, unsigned long interval_us)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_dump_cpupcr)
|
||||
return g_consys_reg_ops->consys_reg_mng_dump_cpupcr(dump_type, times, interval_us);
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int consys_reg_mng_init(struct platform_device *pdev, const struct conninfra_plat_data* plat_data)
|
||||
{
|
||||
int ret = 0;
|
||||
if (g_consys_reg_ops == NULL)
|
||||
g_consys_reg_ops = (const struct consys_reg_mng_ops*)plat_data->reg_ops;
|
||||
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_init)
|
||||
ret = g_consys_reg_ops->consys_reg_mng_init(pdev);
|
||||
else
|
||||
ret = EFAULT;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int consys_reg_mng_deinit(void)
|
||||
{
|
||||
if (g_consys_reg_ops&&
|
||||
g_consys_reg_ops->consys_reg_mng_deinit)
|
||||
g_consys_reg_ops->consys_reg_mng_deinit();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int consys_reg_mng_reg_read(unsigned long addr, unsigned int *value, unsigned int mask)
|
||||
{
|
||||
void __iomem *vir_addr = NULL;
|
||||
|
||||
vir_addr = ioremap_nocache(addr, 0x100);
|
||||
if (!vir_addr) {
|
||||
pr_err("ioremap fail\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
*value = (unsigned int)CONSYS_REG_READ(vir_addr) & mask;
|
||||
|
||||
pr_info("[%x] mask=[%x]\n", *value, mask);
|
||||
|
||||
iounmap(vir_addr);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int consys_reg_mng_reg_write(unsigned long addr, unsigned int value, unsigned int mask)
|
||||
{
|
||||
void __iomem *vir_addr = NULL;
|
||||
|
||||
vir_addr = ioremap_nocache(addr, 0x100);
|
||||
if (!vir_addr) {
|
||||
pr_err("ioremap fail\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
CONSYS_REG_WRITE_MASK(vir_addr, value, mask);
|
||||
|
||||
iounmap(vir_addr);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int consys_reg_mng_is_host_csr(unsigned long addr)
|
||||
{
|
||||
if (g_consys_reg_ops &&
|
||||
g_consys_reg_ops->consys_reg_mng_is_host_csr)
|
||||
return g_consys_reg_ops->consys_reg_mng_is_host_csr(addr);
|
||||
|
||||
return -1;
|
||||
}
|
158
package/mtk/drivers/conninfra/src/platform/emi_mng.c
Normal file
158
package/mtk/drivers/conninfra/src/platform/emi_mng.c
Normal file
@ -0,0 +1,158 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#include <linux/of.h>
|
||||
#include <linux/of_reserved_mem.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/types.h>
|
||||
#include "osal.h"
|
||||
|
||||
#include "consys_hw.h"
|
||||
#include "emi_mng.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
unsigned long long gConEmiSize = 0;
|
||||
phys_addr_t gConEmiPhyBase = 0x0;
|
||||
|
||||
const struct consys_platform_emi_ops* consys_platform_emi_ops = NULL;
|
||||
|
||||
struct consys_emi_addr_info connsys_emi_addr_info = {
|
||||
.emi_ap_phy_base = 0,
|
||||
.emi_ap_phy_size = 0,
|
||||
.fw_emi_size = 0,
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
int emi_mng_set_region_protection(void)
|
||||
{
|
||||
if (consys_platform_emi_ops &&
|
||||
consys_platform_emi_ops->consys_ic_emi_set_region_protection)
|
||||
return consys_platform_emi_ops->consys_ic_emi_set_region_protection();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int emi_mng_set_remapping_reg(void)
|
||||
{
|
||||
if (consys_platform_emi_ops &&
|
||||
consys_platform_emi_ops->consys_ic_emi_set_remapping_reg)
|
||||
return consys_platform_emi_ops->consys_ic_emi_set_remapping_reg();
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
struct consys_emi_addr_info* emi_mng_get_phy_addr(void)
|
||||
{
|
||||
return &connsys_emi_addr_info;
|
||||
}
|
||||
|
||||
int emi_mng_init(struct platform_device *pdev, const struct conninfra_plat_data* plat_data)
|
||||
{
|
||||
unsigned int fw_emi_size = 0;
|
||||
|
||||
#ifdef CONFIG_CONNINFRA_EMI_SUPPORT
|
||||
struct device_node *np;
|
||||
struct reserved_mem *rmem;
|
||||
|
||||
np = of_parse_phandle(pdev->dev.of_node, "memory-region", 0);
|
||||
if (!np) {
|
||||
pr_info("[%s] memory region not found.\n", __func__);
|
||||
return -1;
|
||||
}
|
||||
|
||||
rmem = of_reserved_mem_lookup(np);
|
||||
if (!rmem) {
|
||||
pr_info("[%s] no memory-region\n", __func__);
|
||||
return -1;
|
||||
} else {
|
||||
gConEmiPhyBase = rmem->base;
|
||||
gConEmiSize = rmem->size;
|
||||
}
|
||||
#else
|
||||
pr_info("Conninfra not support EMI reservation for %04x\n", plat_data->chip_id);
|
||||
#endif /* CONFIG_CONNINFRA_EMI_SUPPORT */
|
||||
|
||||
if (consys_platform_emi_ops == NULL) {
|
||||
consys_platform_emi_ops = (const struct consys_platform_emi_ops*)plat_data->platform_emi_ops;
|
||||
}
|
||||
|
||||
if (consys_platform_emi_ops && consys_platform_emi_ops->consys_ic_emi_get_fw_emi_size)
|
||||
fw_emi_size = consys_platform_emi_ops->consys_ic_emi_get_fw_emi_size();
|
||||
|
||||
pr_info("[emi_mng_init] gConEmiPhyBase = [0x%llx] size = [0x%llx] fw size = [0x%x] ops=[%p]\n",
|
||||
gConEmiPhyBase, gConEmiSize, fw_emi_size, consys_platform_emi_ops);
|
||||
|
||||
if (gConEmiPhyBase) {
|
||||
connsys_emi_addr_info.emi_ap_phy_base = gConEmiPhyBase;
|
||||
connsys_emi_addr_info.emi_ap_phy_size = gConEmiSize;
|
||||
connsys_emi_addr_info.fw_emi_size = fw_emi_size;
|
||||
} else {
|
||||
pr_err("consys emi memory address gConEmiPhyBase invalid\n");
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int emi_mng_deinit(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
255
package/mtk/drivers/conninfra/src/platform/include/consys_hw.h
Normal file
255
package/mtk/drivers/conninfra/src/platform/include/consys_hw.h
Normal file
@ -0,0 +1,255 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_CONSYS_HW_H_
|
||||
#define _PLATFORM_CONSYS_HW_H_
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include "conninfra.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define CONN_SEMA_GET_SUCCESS 0
|
||||
#define CONN_SEMA_GET_FAIL 1
|
||||
|
||||
#define CONN_SEMA_TIMEOUT (1*1000) /* 1ms */
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct conninfra_dev_cb {
|
||||
int (*conninfra_suspend_cb) (void);
|
||||
int (*conninfra_resume_cb) (void);
|
||||
int (*conninfra_pmic_event_notifier) (unsigned int, unsigned int);
|
||||
};
|
||||
|
||||
typedef int(*CONSYS_PLT_HW_INIT)(void);
|
||||
typedef int(*CONSYS_PLT_XTAL_CTRL_FAST_MODE)(void);
|
||||
typedef int(*CONSYS_PLT_CONNSYS_SW_RESET_CTRL)(bool bassert);
|
||||
typedef void(*CONSYS_PLT_SET_IF_PINMUX)(bool enable);
|
||||
typedef int(*CONSYS_PLT_TX_RX_BUS_SLP_PROT_CTRL)(bool enable);
|
||||
typedef int(*CONSYS_PLT_POLLING_CONSYS_CHIPID)(void);
|
||||
typedef int(*CONSYS_PLT_BUS_CLOCK_CTRL)(enum consys_drv_type drv_type, unsigned int bus_clock);
|
||||
typedef int(*CONSYS_PLT_D_DIE_CFG)(void);
|
||||
typedef int(*CONSYS_PLT_CONNINFRA_SYSRAM_HW_CTRL)(void);
|
||||
typedef int(*CONSYS_PLT_SPI_MASTER_CFG)(void);
|
||||
typedef int(*CONSYS_PLT_A_DIE_CFG)(void);
|
||||
typedef int(*CONSYS_PLT_AFE_WBG_CAL)(void);
|
||||
typedef int(*CONSYS_PLT_SUBSYS_PLL_INITIAL)(void);
|
||||
typedef int(*CONSYS_PLT_OSC_LEGACY_MODE)(void);
|
||||
typedef int(*CONSYS_PLT_TOP_PWR_CTRL)(void);
|
||||
typedef int(*CONSYS_PLT_CONN_INFRA_BUS_TIMEOUT)(void);
|
||||
typedef int(*CONSYS_PLT_CLKGEN_WPLL_HW_CTRL)(void);
|
||||
typedef int(*CONSYS_PLT_CONNINFRA_TOP_WAKEUP) (void);
|
||||
typedef int(*CONSYS_PLT_CONNINFRA_TOP_SLEEP) (void);
|
||||
typedef int(*CONSYS_PLT_ADIE_TOP_CK_EN_ON_OFF_CTRL)(enum consys_drv_type type, unsigned char on);
|
||||
typedef int(*CONSYS_PLT_CONNINFRA_WF_WAKEUP) (void);
|
||||
typedef int(*CONSYS_PLT_CONNINFRA_WF_SLEEP) (void);
|
||||
typedef int(*CONSYS_PLT_CONN_WMCPU_SW_RESET) (bool bassert);
|
||||
typedef int(*CONSYS_PLT_WF_BUS_SLP_PROT_CTRL)(bool enable);
|
||||
typedef int(*CONSYS_PLT_WFSYS_TOP_ON_CTRL) (bool enable);
|
||||
typedef int(*CONSYS_PLT_WFSYS_BUS_SLP_PROT_CHECK)(bool enable);
|
||||
typedef int(*CONSYS_PLT_WFSYS_BUS_TIMEOUT_CTRL) (void);
|
||||
typedef int(*CONSYS_PLT_CONN_WMCPU_IDLE_LOOP_CHECK) (void);
|
||||
typedef int(*CONSYS_PLT_WPLL_CTRL)(bool enable);
|
||||
typedef int(*CONSYS_PLT_CONNINFRA_WF_REQ_CLR) (void);
|
||||
typedef int(*CONSYS_PLT_CLK_GET_FROM_DTS) (struct platform_device *pdev);
|
||||
typedef int(*CONSYS_PLT_CLK_DETACH) (void);
|
||||
typedef int(*CONSYS_PLT_CO_CLOCK_TYPE) (void);
|
||||
typedef unsigned int(*CONSYS_PLT_SOC_CHIPID_GET) (void);
|
||||
typedef unsigned int(*CONSYS_PLT_GET_HW_VER)(void);
|
||||
typedef int(*CONSYS_PLT_SPI_READ)(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data);
|
||||
typedef int(*CONSYS_PLT_SPI_WRITE)(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data);
|
||||
typedef int(*CONSYS_PLT_SPI_CLOCK_SWITCH)(enum connsys_spi_speed_type type);
|
||||
typedef int(*CONSYS_PLT_POWER_STATE)(void);
|
||||
typedef int(*CONSYS_PLT_AIDE_TYPE_CHECK)(void);
|
||||
typedef int(*CONSYS_PLT_AIDE_TYPE_CFG)(void);
|
||||
|
||||
struct consys_hw_ops_struct {
|
||||
/* HW init */
|
||||
CONSYS_PLT_HW_INIT consys_plt_hw_init;
|
||||
|
||||
/* Power on/off CONNSYS PART (by Conn_infra Driver) */
|
||||
CONSYS_PLT_XTAL_CTRL_FAST_MODE consys_plt_xtal_ctrl_fast_mode;
|
||||
CONSYS_PLT_CONNSYS_SW_RESET_CTRL consys_plt_connsys_sw_reset_ctrl;
|
||||
CONSYS_PLT_SET_IF_PINMUX consys_plt_set_if_pinmux;
|
||||
CONSYS_PLT_TX_RX_BUS_SLP_PROT_CTRL consys_plt_tx_rx_bus_slp_prot_ctrl;
|
||||
CONSYS_PLT_POLLING_CONSYS_CHIPID consys_plt_polling_consys_chipid;
|
||||
CONSYS_PLT_BUS_CLOCK_CTRL consys_plt_bus_clock_ctrl;
|
||||
CONSYS_PLT_D_DIE_CFG consys_plt_d_die_cfg;
|
||||
CONSYS_PLT_CONNINFRA_SYSRAM_HW_CTRL consys_plt_conninfra_sysram_hw_ctrl;
|
||||
CONSYS_PLT_SPI_MASTER_CFG consys_plt_spi_master_cfg;
|
||||
CONSYS_PLT_A_DIE_CFG consys_plt_a_die_cfg;
|
||||
CONSYS_PLT_AFE_WBG_CAL consys_plt_afe_wbg_cal;
|
||||
CONSYS_PLT_SUBSYS_PLL_INITIAL consys_plt_subsys_pll_initial;
|
||||
CONSYS_PLT_OSC_LEGACY_MODE consys_plt_osc_legacy_mode;
|
||||
CONSYS_PLT_TOP_PWR_CTRL consys_plt_top_pwr_ctrl;
|
||||
CONSYS_PLT_CONN_INFRA_BUS_TIMEOUT consys_plt_conn_infra_bus_timeout;
|
||||
CONSYS_PLT_CLKGEN_WPLL_HW_CTRL consys_plt_clkgen_wpll_hw_ctrl;
|
||||
CONSYS_PLT_CONNINFRA_TOP_WAKEUP consys_plt_conninfra_wakeup;
|
||||
CONSYS_PLT_CONNINFRA_TOP_SLEEP consys_plt_conninfra_sleep;
|
||||
CONSYS_PLT_ADIE_TOP_CK_EN_ON_OFF_CTRL consys_plt_adie_top_ck_en_on_off_ctrl;
|
||||
CONSYS_PLT_WPLL_CTRL consys_plt_wpll_ctrl;
|
||||
|
||||
/* Power on/off WFSYS PART 0 (by WF Driver) */
|
||||
CONSYS_PLT_CONNINFRA_WF_WAKEUP consys_plt_conninfra_wf_wakeup;
|
||||
CONSYS_PLT_CONNINFRA_WF_SLEEP consys_plt_conninfra_wf_sleep;
|
||||
CONSYS_PLT_CONN_WMCPU_SW_RESET consys_plt_conn_wmcpu_sw_reset;
|
||||
CONSYS_PLT_WF_BUS_SLP_PROT_CTRL consys_plt_wf_bus_slp_prot_ctrl;
|
||||
CONSYS_PLT_WFSYS_TOP_ON_CTRL consys_plt_wfsys_top_on_ctrl;
|
||||
CONSYS_PLT_WFSYS_BUS_SLP_PROT_CHECK consys_plt_wfsys_bus_slp_prot_check;
|
||||
CONSYS_PLT_WFSYS_BUS_TIMEOUT_CTRL consys_plt_wfsys_bus_timeout_ctrl;
|
||||
CONSYS_PLT_CONN_WMCPU_IDLE_LOOP_CHECK consys_plt_conn_wmcpu_idle_loop_check;
|
||||
CONSYS_PLT_CONNINFRA_WF_REQ_CLR consys_plt_conninfra_wf_req_clr;
|
||||
|
||||
/* load from dts */
|
||||
CONSYS_PLT_CLK_GET_FROM_DTS consys_plt_clk_get_from_dts;
|
||||
CONSYS_PLT_CLK_DETACH consys_plt_clk_detach;
|
||||
|
||||
/* clock */
|
||||
CONSYS_PLT_CO_CLOCK_TYPE consys_plt_co_clock_type;
|
||||
|
||||
CONSYS_PLT_SOC_CHIPID_GET consys_plt_soc_chipid_get;
|
||||
|
||||
/* debug */
|
||||
CONSYS_PLT_GET_HW_VER consys_plt_get_hw_ver;
|
||||
|
||||
/* For SPI operation */
|
||||
CONSYS_PLT_SPI_READ consys_plt_spi_read;
|
||||
CONSYS_PLT_SPI_WRITE consys_plt_spi_write;
|
||||
|
||||
/* For SPI clock switch */
|
||||
CONSYS_PLT_SPI_CLOCK_SWITCH consys_plt_spi_clock_switch;
|
||||
|
||||
/* power state */
|
||||
CONSYS_PLT_POWER_STATE consys_plt_power_state;
|
||||
|
||||
/* others */
|
||||
CONSYS_PLT_AIDE_TYPE_CHECK consys_plt_adie_type_check;
|
||||
CONSYS_PLT_AIDE_TYPE_CFG consys_plt_adie_type_cfg;
|
||||
};
|
||||
|
||||
struct consys_hw_env {
|
||||
bool valid;
|
||||
unsigned int adie_hw_version;
|
||||
unsigned int adie_id;
|
||||
int is_rc_mode;
|
||||
};
|
||||
|
||||
struct conninfra_plat_data {
|
||||
const unsigned int chip_id;
|
||||
const void* hw_ops;
|
||||
const void* reg_ops;
|
||||
const void* platform_emi_ops;
|
||||
const void* platform_pmic_ops;
|
||||
};
|
||||
|
||||
extern struct consys_hw_env conn_hw_env[AIDE_NUM_MAX];
|
||||
extern struct consys_base_addr conn_reg;
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
int mtk_conninfra_drv_init(struct conninfra_dev_cb *dev_cb);
|
||||
int mtk_conninfra_drv_deinit(void);
|
||||
|
||||
int consys_hw_pwr_on(unsigned int curr_status, unsigned int on_radio);
|
||||
int consys_hw_pwr_off(unsigned int curr_status, unsigned int off_radio);
|
||||
|
||||
int consys_hw_wifi_power_ctl(unsigned int enable);
|
||||
int consys_hw_bt_power_ctl(unsigned int enable);
|
||||
int consys_hw_gps_power_ctl(unsigned int enable);
|
||||
int consys_hw_fm_power_ctl(unsigned int enable);
|
||||
int consys_hw_pmic_event_cb(unsigned int id, unsigned int event);
|
||||
|
||||
unsigned int consys_hw_chipid_get(void);
|
||||
|
||||
int consys_hw_get_clock_schematic(void);
|
||||
unsigned int consys_hw_get_hw_ver(void);
|
||||
|
||||
/*******************************************************************************
|
||||
* tempoary for STEP
|
||||
********************************************************************************
|
||||
*/
|
||||
/*
|
||||
* return
|
||||
* 1 : can read
|
||||
* 0 : can't read
|
||||
* -1: not consys register
|
||||
*/
|
||||
int consys_hw_reg_readable(void);
|
||||
int consys_hw_is_connsys_reg(phys_addr_t addr);
|
||||
/*
|
||||
* 0 means NO hang
|
||||
* > 0 means hang!!
|
||||
*/
|
||||
int consys_hw_is_bus_hang(void);
|
||||
int consys_hw_dump_bus_status(void);
|
||||
|
||||
int consys_hw_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data);
|
||||
int consys_hw_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data);
|
||||
|
||||
int consys_hw_adie_top_ck_en_on(enum consys_drv_type type);
|
||||
int consys_hw_adie_top_ck_en_off(enum consys_drv_type type);
|
||||
|
||||
/* NOTE: debug only*/
|
||||
int consys_hw_force_conninfra_wakeup(void);
|
||||
int consys_hw_force_conninfra_sleep(void);
|
||||
|
||||
int consys_hw_spi_clock_switch(enum connsys_spi_speed_type type);
|
||||
|
||||
struct platform_device *get_consys_device(void);
|
||||
struct consys_base_addr *get_conn_reg_base_addr(void);
|
||||
|
||||
int consys_hw_dump_power_state(void);
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _PLATFORM_CONSYS_HW_H_ */
|
@ -0,0 +1,28 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_CONSYS_REG_BASE_H_
|
||||
#define _PLATFORM_CONSYS_REG_BASE_H_
|
||||
|
||||
struct consys_reg_base_addr {
|
||||
unsigned long phy_addr;
|
||||
unsigned long long size;
|
||||
unsigned long vir_addr;
|
||||
};
|
||||
|
||||
#endif /* _PLATFORM_CONSYS_REG_BASE_H_ */
|
@ -0,0 +1,57 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_CONSYS_REG_MNG_H_
|
||||
#define _PLATFORM_CONSYS_REG_MNG_H_
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
#include "consys_hw.h"
|
||||
|
||||
enum conn_dump_cpupcr_type
|
||||
{
|
||||
CONN_DUMP_CPUPCR_TYPE_BT = 1,
|
||||
CONN_DUMP_CPUPCR_TYPE_WF = 2,
|
||||
CONN_DUMP_CPUPCR_TYPE_ALL = 3,
|
||||
};
|
||||
|
||||
struct consys_reg_mng_ops {
|
||||
int(*consys_reg_mng_init) (struct platform_device *pdev);
|
||||
int(*consys_reg_mng_deinit) (void);
|
||||
int(*consys_reg_mng_check_reable) (void);
|
||||
int(*consys_reg_mng_is_consys_reg) (unsigned int addr);
|
||||
int(*consys_reg_mng_is_bus_hang) (void);
|
||||
int(*consys_reg_mng_dump_bus_status) (void);
|
||||
int(*consys_reg_mng_dump_conninfra_status) (void);
|
||||
int(*consys_reg_mng_dump_cpupcr) (enum conn_dump_cpupcr_type, int times, unsigned long interval_us);
|
||||
int(*consys_reg_mng_is_host_csr) (unsigned long addr);
|
||||
};
|
||||
|
||||
int consys_reg_mng_init(struct platform_device *pdev, const struct conninfra_plat_data* plat_data);
|
||||
int consys_reg_mng_deinit(void);
|
||||
int consys_reg_mng_reg_readable(void);
|
||||
int consys_reg_mng_is_connsys_reg(phys_addr_t addr);
|
||||
int consys_reg_mng_reg_read(unsigned long addr, unsigned int *value, unsigned int mask);
|
||||
int consys_reg_mng_reg_write(unsigned long addr, unsigned int value, unsigned int mask);
|
||||
int consys_reg_mng_is_bus_hang(void);
|
||||
int consys_reg_mng_dump_bus_status(void);
|
||||
int consys_reg_mng_dump_conninfra_status(void);
|
||||
int consys_reg_mng_dump_cpupcr(enum conn_dump_cpupcr_type dump_type, int times, unsigned long interval_us);
|
||||
int consys_reg_mng_is_host_csr(unsigned long addr);
|
||||
|
||||
#endif /* _PLATFORM_CONSYS_REG_MNG_H_ */
|
@ -0,0 +1,174 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_CONSYS_REG_UTIL_H_
|
||||
#define _PLATFORM_CONSYS_REG_UTIL_H_
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
/* platform dependent */
|
||||
#include "plat_def.h"
|
||||
|
||||
#ifndef BIT
|
||||
#define BIT(x) (1<<(x))
|
||||
#endif
|
||||
|
||||
#define KBYTE (1024*sizeof(char))
|
||||
#ifndef GENMASK
|
||||
#define GENMASK(h, l) \
|
||||
(((~0UL) - (1UL << (l)) + 1) & (~0UL >> (BITS_PER_LONG - 1 - (h))))
|
||||
#endif
|
||||
|
||||
#define GET_BIT_MASK(value, mask) ((value) & (mask))
|
||||
#define SET_BIT_MASK(pdest, value, mask) (*(pdest) = (GET_BIT_MASK(*(pdest), ~(mask)) | GET_BIT_MASK(value, mask)))
|
||||
#define GET_BIT_RANGE(data, end, begin) ((data) & GENMASK(end, begin))
|
||||
#define SET_BIT_RANGE(pdest, data, end, begin) (SET_BIT_MASK(pdest, data, GENMASK(end, begin)))
|
||||
|
||||
#define CONSYS_SET_BIT(REG, BITVAL) (*((volatile unsigned int *)(REG)) |= ((unsigned int)(BITVAL)))
|
||||
#define CONSYS_CLR_BIT(REG, BITVAL) ((*(volatile unsigned int *)(REG)) &= ~((unsigned int)(BITVAL)))
|
||||
#define CONSYS_CLR_BIT_WITH_KEY(REG, BITVAL, KEY) {\
|
||||
unsigned int val = (*(volatile unsigned int *)(REG)); \
|
||||
val &= ~((unsigned int)(BITVAL)); \
|
||||
val |= ((unsigned int)(KEY)); \
|
||||
(*(volatile unsigned int *)(REG)) = val;\
|
||||
}
|
||||
#define CONSYS_REG_READ(addr) (*((volatile unsigned int *)(addr)))
|
||||
#define CONSYS_REG_READ_BIT(addr, BITVAL) (*((volatile unsigned int *)(addr)) & ((unsigned int)(BITVAL)))
|
||||
#define CONSYS_REG_WRITE(addr, data) mt_reg_sync_writel(data, addr)
|
||||
#define CONSYS_REG_WRITE_RANGE(reg, data, end, begin) {\
|
||||
unsigned int val = CONSYS_REG_READ(reg); \
|
||||
SET_BIT_RANGE(&val, data, end, begin); \
|
||||
CONSYS_REG_WRITE(reg, val); \
|
||||
}
|
||||
#define CONSYS_REG_WRITE_MASK(reg, data, mask) {\
|
||||
unsigned int val = CONSYS_REG_READ(reg); \
|
||||
SET_BIT_MASK(&val, data, mask); \
|
||||
CONSYS_REG_WRITE(reg, val); \
|
||||
}
|
||||
|
||||
/*
|
||||
* Write value with value_offset bits of right shift and size bits,
|
||||
* to the reg_offset-th bit of address reg
|
||||
* value -----------XXXXXXXXXXXX-------------------
|
||||
* |<--size-->|<--value_offset-->|
|
||||
* reg -------------OOOOOOOOOOOO-----------------
|
||||
* |<--size-->|<--reg_offset-->|
|
||||
* result -------------XXXXXXXXXXXX-----------------
|
||||
*/
|
||||
#define CONSYS_REG_WRITE_OFFSET_RANGE(reg, value, reg_offset, value_offset, size) ({\
|
||||
unsigned int data = (value) >> (value_offset); \
|
||||
data = GET_BIT_RANGE(data, size, 0); \
|
||||
data = data << (reg_offset); \
|
||||
CONSYS_REG_WRITE_RANGE(reg, data, ((reg_offset) + ((size) - 1)), reg_offset); \
|
||||
})
|
||||
|
||||
#define CONSYS_REG_WRITE_BIT(reg, offset, val) CONSYS_REG_WRITE_OFFSET_RANGE(reg, ((val) & 1), offset, 0, 1)
|
||||
|
||||
#define CONSYS_REG_BIT_POLLING(addr, bit_index, exp_val, loop, delay, success) {\
|
||||
unsigned int polling_count = 0; \
|
||||
unsigned int reg_value = 0; \
|
||||
success = 0; \
|
||||
reg_value = (CONSYS_REG_READ_BIT(addr, (0x1 << bit_index)) >> bit_index); \
|
||||
while (reg_value != exp_val) { \
|
||||
if (polling_count > loop) { \
|
||||
success = -1; \
|
||||
break; \
|
||||
} \
|
||||
reg_value = (CONSYS_REG_READ_BIT(addr, (0x1 << bit_index)) >> bit_index); \
|
||||
udelay(delay); \
|
||||
polling_count++; \
|
||||
} \
|
||||
}
|
||||
|
||||
#define CONSYS_REG_POLLING_LARGER_OR_EQUAL(addr, mask, bit_index, exp_val, loop, delay, success) {\
|
||||
unsigned int polling_count = 0; \
|
||||
unsigned int reg_value = 0; \
|
||||
success = 0; \
|
||||
reg_value = ((CONSYS_REG_READ(addr) & mask) >> bit_index); \
|
||||
while (reg_value < exp_val) { \
|
||||
if (polling_count > loop) { \
|
||||
success = -1; \
|
||||
break; \
|
||||
} \
|
||||
reg_value = ((CONSYS_REG_READ(addr) & mask) >> bit_index); \
|
||||
udelay(delay); \
|
||||
polling_count++; \
|
||||
} \
|
||||
}
|
||||
|
||||
#define CONSYS_REG_POLLING_EQUAL(addr, mask, bit_index, exp_val, loop, delay, success) {\
|
||||
unsigned int polling_count = 0; \
|
||||
unsigned int reg_value = 0; \
|
||||
success = 0; \
|
||||
reg_value = ((CONSYS_REG_READ(addr) & mask) >> bit_index); \
|
||||
while (reg_value != exp_val) { \
|
||||
if (polling_count > loop) { \
|
||||
success = -1; \
|
||||
break; \
|
||||
} \
|
||||
reg_value = ((CONSYS_REG_READ(addr) & mask) >> bit_index); \
|
||||
udelay(delay); \
|
||||
polling_count++; \
|
||||
} \
|
||||
}
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _PLATFORM_CONSYS_REG_UTIL_H_ */
|
99
package/mtk/drivers/conninfra/src/platform/include/emi_mng.h
Normal file
99
package/mtk/drivers/conninfra/src/platform/include/emi_mng.h
Normal file
@ -0,0 +1,99 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_EMI_MNG_H_
|
||||
#define _PLATFORM_EMI_MNG_H_
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/types.h>
|
||||
#include "osal.h"
|
||||
|
||||
#include "consys_hw.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_emi_addr_info {
|
||||
/* This include BT/WF FW and WFDMA */
|
||||
phys_addr_t emi_ap_phy_base;
|
||||
unsigned int emi_ap_phy_size;
|
||||
unsigned int fw_emi_size;
|
||||
};
|
||||
|
||||
typedef int(*CONSYS_IC_EMI_SET_REGION_PROTECTION) (void);
|
||||
typedef int(*CONSYS_IC_EMI_SET_REMAPPING_REG) (void);
|
||||
typedef unsigned int (*CONSYS_IC_GET_FW_EMI_SIZE)(void);
|
||||
|
||||
struct consys_platform_emi_ops {
|
||||
CONSYS_IC_EMI_SET_REGION_PROTECTION consys_ic_emi_set_region_protection;
|
||||
CONSYS_IC_EMI_SET_REMAPPING_REG consys_ic_emi_set_remapping_reg;
|
||||
CONSYS_IC_GET_FW_EMI_SIZE consys_ic_emi_get_fw_emi_size;
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
int emi_mng_init(struct platform_device *pdev, const struct conninfra_plat_data* plat_data);
|
||||
int emi_mng_deinit(void);
|
||||
|
||||
int emi_mng_set_region_protection(void);
|
||||
int emi_mng_set_remapping_reg(void);
|
||||
struct consys_emi_addr_info* emi_mng_get_phy_addr(void);
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _PLATFORM_EMI_MNG_H_ */
|
||||
|
@ -0,0 +1,31 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_DEF_H_
|
||||
#define _PLATFORM_DEF_H_
|
||||
|
||||
#include <linux/delay.h>
|
||||
#include <linux/io.h>
|
||||
|
||||
#define mt_reg_sync_writel(v, a) \
|
||||
do { \
|
||||
writel((v), (void __force __iomem *)((a))); \
|
||||
mb(); \
|
||||
} while (0)
|
||||
|
||||
#endif /* _PLATFORM_DEF_H_ */
|
110
package/mtk/drivers/conninfra/src/platform/include/pmic_mng.h
Normal file
110
package/mtk/drivers/conninfra/src/platform/include/pmic_mng.h
Normal file
@ -0,0 +1,110 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_PMIC_MNG_H_
|
||||
#define _PLATFORM_PMIC_MNG_H_
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
#include "consys_hw.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
typedef int(*CONSYS_PMIC_GET_FROM_DTS) (
|
||||
struct platform_device *pdev,
|
||||
struct conninfra_dev_cb* dev_cb);
|
||||
|
||||
typedef int(*CONSYS_PMIC_COMMON_POWER_CTRL) (unsigned int enable);
|
||||
|
||||
typedef int(*CONSYS_PMIC_WIFI_POWER_CTRL) (unsigned int enable);
|
||||
typedef int(*CONSYS_PMIC_BT_POWER_CTRL) (unsigned int enable);
|
||||
typedef int(*CONSYS_PMIC_GPS_POWER_CTRL) (unsigned int enable);
|
||||
typedef int(*CONSYS_PMIC_FM_POWER_CTRL) (unsigned int enable);
|
||||
typedef int(*CONSYS_PMIC_EVENT_NOTIFIER) (unsigned int id, unsigned int event);
|
||||
|
||||
struct consys_platform_pmic_ops {
|
||||
CONSYS_PMIC_GET_FROM_DTS consys_pmic_get_from_dts;
|
||||
/* vcn 18 */
|
||||
CONSYS_PMIC_COMMON_POWER_CTRL consys_pmic_common_power_ctrl;
|
||||
CONSYS_PMIC_WIFI_POWER_CTRL consys_pmic_wifi_power_ctrl;
|
||||
CONSYS_PMIC_BT_POWER_CTRL consys_pmic_bt_power_ctrl;
|
||||
CONSYS_PMIC_GPS_POWER_CTRL consys_pmic_gps_power_ctrl;
|
||||
CONSYS_PMIC_FM_POWER_CTRL consys_pmic_fm_power_ctrl;
|
||||
CONSYS_PMIC_EVENT_NOTIFIER consys_pmic_event_notifier;
|
||||
};
|
||||
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
int pmic_mng_init(
|
||||
struct platform_device *pdev,
|
||||
struct conninfra_dev_cb* dev_cb,
|
||||
const struct conninfra_plat_data* plat_data);
|
||||
int pmic_mng_deinit(void);
|
||||
|
||||
int pmic_mng_common_power_ctrl(unsigned int enable);
|
||||
int pmic_mng_wifi_power_ctrl(unsigned int enable);
|
||||
int pmic_mng_bt_power_ctrl(unsigned int enable);
|
||||
int pmic_mng_gps_power_ctrl(unsigned int enable);
|
||||
int pmic_mng_fm_power_ctrl(unsigned int enable);
|
||||
int pmic_mng_event_cb(unsigned int id, unsigned int event);
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _PLATFORM_PMIC_MNG_H_ */
|
@ -0,0 +1,59 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7981_H_
|
||||
#define _PLATFORM_MT7981_H_
|
||||
|
||||
enum
|
||||
{
|
||||
ADIE_TYPE_NONE = 0,
|
||||
ADIE_TYPE_ONE,
|
||||
ADIE_TYPE_TWO,
|
||||
ADIE_TYPE_NUM_MAX
|
||||
};
|
||||
|
||||
enum conn_semaphore_type
|
||||
{
|
||||
CONN_SEMA_CHIP_POWER_ON_INDEX = 0,
|
||||
CONN_SEMA_CALIBRATION_INDEX = 1,
|
||||
CONN_SEMA_FW_DL_INDEX = 2,
|
||||
CONN_SEMA_CLOCK_SWITCH_INDEX = 3,
|
||||
CONN_SEMA_CCIF_INDEX = 4,
|
||||
CONN_SEMA_COEX_INDEX = 5,
|
||||
CONN_SEMA_USB_EP0_INDEX = 6,
|
||||
CONN_SEMA_USB_SHARED_INFO_INDEX = 7,
|
||||
CONN_SEMA_USB_SUSPEND_INDEX = 8,
|
||||
CONN_SEMA_USB_RESUME_INDEX = 9,
|
||||
CONN_SEMA_PCIE_INDEX = 10,
|
||||
CONN_SEMA_RFSPI_INDEX = 11,
|
||||
CONN_SEMA_EFUSE_INDEX = 12,
|
||||
CONN_SEMA_THERMAL_INDEX = 13,
|
||||
CONN_SEMA_FLASH_INDEX = 14,
|
||||
CONN_SEMA_DEBUG_INDEX = 15,
|
||||
CONN_SEMA_WIFI_LP_INDEX = 16,
|
||||
CONN_SEMA_PATCH_DL_INDEX = 17,
|
||||
CONN_SEMA_SHARED_VAR_INDEX = 18,
|
||||
CONN_SEMA_CONN_INFRA_COMMON_SYSRAM_INDEX = 19,
|
||||
CONN_SEMA_NUM_MAX = 32 /* can't be omitted */
|
||||
};
|
||||
|
||||
unsigned int consys_soc_chipid_get(void);
|
||||
unsigned int consys_get_hw_ver(void);
|
||||
|
||||
|
||||
#endif /* _PLATFORM_MT7981_H_ */
|
@ -0,0 +1,132 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7981_CONSYS_REG_H_
|
||||
#define _PLATFORM_MT7981_CONSYS_REG_H_
|
||||
|
||||
#include "consys_reg_base.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
enum consys_base_addr_index {
|
||||
TOP_MISC_BASE = 0, /* top_misc */
|
||||
TOPRGU_BASE = 1, /* TOPRGU */
|
||||
GPIO_BASE = 2, /* GPIO */
|
||||
IOCFG_TM_BASE = 3, /* IOCFG_TM */
|
||||
IOCFG_LT_BASE = 4, /* IOCFG_LT */
|
||||
INFRACFG_AO_BASE = 5, /* infracfg_ao_auto_gen_reg */
|
||||
CONN_INFRA_CFG_BASE = 6, /* conn_infra_cfg */
|
||||
CONN_INFRA_SYSRAM_BASE = 7, /* conn_infra_sysram */
|
||||
CONN_INFRA_CLKGEN_ON_TOP_BASE = 8, /* conn_infra_clkgen_on_top */
|
||||
CONN_HOST_CSR_TOP_BASE = 9, /* conn_host_csr_top */
|
||||
CONN_INFRA_BUS_CR_BASE = 10, /* conn_infra_bus_cr */
|
||||
CONN_INFRA_RGU_BASE = 11, /* conn_infra_rgu */
|
||||
CONN_WT_SLP_CTL_REG_BASE = 12, /* conn_wt_slp_ctl_reg */
|
||||
INST2_CONN_WT_SLP_CTL_REG_BASE = 13, /* Inst2_conn_wt_slp_ctl_reg */
|
||||
CONN_RF_SPI_MST_REG_BASE = 14, /* conn_rf_spi_mst_reg */
|
||||
INST2_CONN_RF_SPI_MST_REG_BASE = 15, /* Inst2_conn_rf_spi_mst_reg */
|
||||
CONN_SEMAPHORE_BASE = 16, /* conn_semaphore */
|
||||
CONN_AFE_CTL_BASE = 17, /* conn_afe_ctl */
|
||||
CONN_AFE_CTL_2ND_BASE = 18, /* conn_afe_ctl_2nd */
|
||||
WF_TOP_SLPPROT_ON_BASE = 19, /* wf_top_slpprot_on by remapping to 0x81020000 */
|
||||
WF_TOP_CFG_BASE = 20, /* wf_top_cfg by remapping to 0x80020000 */
|
||||
WF_MCU_CONFIG_LS_BASE = 21, /* wf_mcu_confg_ls by remapping to 0x88000000 */
|
||||
WF_MCU_BUS_CR_BASE = 22, /* wf_mcu_bus_cr by remapping to 0x830C0XXX */
|
||||
WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE = 23, /* wf_mcusys_infra_bus_full_u_debug_ctrl_ao by remapping to 0x810F0000 */
|
||||
WF_TOP_CFG_ON_BASE = 24, /* wf_top_cfg_on by remapping to 0x81021000 */
|
||||
CONSYS_BASE_ADDR_MAX
|
||||
};
|
||||
|
||||
struct consys_base_addr {
|
||||
struct consys_reg_base_addr reg_base_addr[CONSYS_BASE_ADDR_MAX];
|
||||
};
|
||||
|
||||
extern struct consys_base_addr conn_reg;
|
||||
|
||||
#define REG_TOP_MISC_ADDR conn_reg.reg_base_addr[TOP_MISC_BASE].vir_addr
|
||||
#define REG_TOP_RGU_ADDR conn_reg.reg_base_addr[TOPRGU_BASE].vir_addr
|
||||
#define REG_GPIO_BASE_ADDR conn_reg.reg_base_addr[GPIO_BASE].vir_addr
|
||||
#define REG_IOCFG_TM_ADDR conn_reg.reg_base_addr[IOCFG_TM_BASE].vir_addr
|
||||
#define REG_IOCFG_LT_ADDR conn_reg.reg_base_addr[IOCFG_LT_BASE].vir_addr
|
||||
#define REG_INFRACFG_AO_ADDR conn_reg.reg_base_addr[INFRACFG_AO_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_CFG_ADDR conn_reg.reg_base_addr[CONN_INFRA_CFG_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_SYSRAM_ADDR conn_reg.reg_base_addr[CONN_INFRA_SYSRAM_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_CLKGEN_ON_TOP_ADDR conn_reg.reg_base_addr[CONN_INFRA_CLKGEN_ON_TOP_BASE].vir_addr
|
||||
#define REG_CONN_HOST_CSR_TOP_ADDR conn_reg.reg_base_addr[CONN_HOST_CSR_TOP_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_BUS_CR_ADDR conn_reg.reg_base_addr[CONN_INFRA_BUS_CR_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_RGU_ADDR conn_reg.reg_base_addr[CONN_INFRA_RGU_BASE].vir_addr
|
||||
#define REG_CONN_WT_SLP_CTL_REG_ADDR conn_reg.reg_base_addr[CONN_WT_SLP_CTL_REG_BASE].vir_addr
|
||||
#define REG_INST2_CONN_WT_SLP_CTL_REG_ADDR conn_reg.reg_base_addr[INST2_CONN_WT_SLP_CTL_REG_BASE].vir_addr
|
||||
#define REG_CONN_RF_SPI_MST_REG_ADDR conn_reg.reg_base_addr[CONN_RF_SPI_MST_REG_BASE].vir_addr
|
||||
#define REG_INST2_CONN_RF_SPI_MST_REG_ADDR conn_reg.reg_base_addr[INST2_CONN_RF_SPI_MST_REG_BASE].vir_addr
|
||||
#define REG_CONN_SEMAPHORE_ADDR conn_reg.reg_base_addr[CONN_SEMAPHORE_BASE].vir_addr
|
||||
#define REG_CONN_AFE_CTL_ADDR conn_reg.reg_base_addr[CONN_AFE_CTL_BASE].vir_addr
|
||||
#define REG_CONN_AFE_CTL_2ND_ADDR conn_reg.reg_base_addr[CONN_AFE_CTL_2ND_BASE].vir_addr
|
||||
#define REG_WF_TOP_SLPPROT_ON_ADDR conn_reg.reg_base_addr[WF_TOP_SLPPROT_ON_BASE].vir_addr
|
||||
#define REG_WF_TOP_CFG_ADDR conn_reg.reg_base_addr[WF_TOP_CFG_BASE].vir_addr
|
||||
#define REG_WF_MCU_CONFIG_LS_ADDR conn_reg.reg_base_addr[WF_MCU_CONFIG_LS_BASE].vir_addr
|
||||
#define REG_WF_MCU_BUS_CR_ADDR conn_reg.reg_base_addr[WF_MCU_BUS_CR_BASE].vir_addr
|
||||
#define REG_WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_ADDR conn_reg.reg_base_addr[WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE].vir_addr
|
||||
#define REG_WF_TOP_CFG_ON_ADDR conn_reg.reg_base_addr[WF_TOP_CFG_ON_BASE].vir_addr
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_base_addr* get_conn_reg_base_addr(void);
|
||||
|
||||
#endif /* _PLATFORM_MT7981_CONSYS_REG_H_ */
|
@ -0,0 +1,243 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7981_CONSYS_REG_OFFSET_H_
|
||||
#define _PLATFORM_MT7981_CONSYS_REG_OFFSET_H_
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: TOP_MISC (0x11D1_0000) */
|
||||
/**********************************************************************/
|
||||
#define CONNSYS_MISC 0x0114
|
||||
#define TOP_MISC_RSRV_ALL1_3 0x021C
|
||||
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: TOP RGU (0x1001_C000) */
|
||||
/**********************************************************************/
|
||||
#define TOP_RGU_WDT_SWSYSRST 0x0018
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: GPIO (0x11D0_0000) */
|
||||
/**********************************************************************/
|
||||
#define GPIO_MODE5 0x0350
|
||||
#define GPIO_MODE6 0x0360
|
||||
#define GPIO_MODE7 0x0370
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: IOCFG_TM (0x11F0_0000) */
|
||||
/**********************************************************************/
|
||||
#define IOCFG_TM_DRV_CFG0 0x0000
|
||||
#define IOCFG_TM_DRV_CFG1 0x0010
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: IOCFG_LT (0x11F1_0000) */
|
||||
/**********************************************************************/
|
||||
#define IOCFG_LT_DRV_CFG0 0x0000
|
||||
#define IOCFG_LT_DRV_CFG1 0x0010
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: INFRACFG_AO (0x1000_3000) */
|
||||
/**********************************************************************/
|
||||
#define CONN2AP_GALS_SLPPROT 0x00D0
|
||||
#define AP2CONN_GALS_SLPPROT 0x00D4
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_CFG (0x1800_1000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_INFRA_CFG_IP_VERSION 0x0000
|
||||
#define EFUSE 0x0020
|
||||
#define ADIE_CTL 0x0030
|
||||
#define CONN_INFRA_CFG_PWRCTRL0 0x0200
|
||||
#define CONN_INFRA_CFG_RC_CTL_0 0x0380
|
||||
#define OSC_CTL_0 0x0300
|
||||
#define EMI_CTL_WF 0x0414
|
||||
#define CONN_INFRA_WF_SLP_CTRL 0x0540
|
||||
#define CONN_INFRA_WF_SLP_STATUS 0x0544
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_SYSRAM (0x1805_0000) */
|
||||
/**********************************************************************/
|
||||
#define SYSRAM_BASE_ADDR 0x0000
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_CLKGEN_ON_TOP (0x1800_9000) */
|
||||
/**********************************************************************/
|
||||
#define CKGEN_BUS_WPLL_DIV_1 0x0008
|
||||
#define CKGEN_BUS_WPLL_DIV_2 0x000C
|
||||
#define CKGEN_RFSPI_WPLL_DIV 0x0040
|
||||
#define CKGEN_BUS 0x0A00
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_HOST_CSR_TOP (0x1806_0000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_INFRA_WAKEPU_TOP 0x01A0
|
||||
#define CONN_INFRA_WAKEPU_WF 0x01A4
|
||||
#define CONN2AP_REMAP_MCU_EMI 0x01C4
|
||||
#define CONN2AP_REMAP_WF_PERI 0x01D4
|
||||
#define CONN2AP_RSVD_PERI_REGION1 0x01D8
|
||||
#define DBG_DUMMY_3 0x02CC
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_BUS_CR (0x1800_E000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_INFRA_BUS_OFF_TIMEOUT_CTRL 0x0300
|
||||
#define CONN_INFRA_BUS_ON_TIMEOUT_CTRL 0x031C
|
||||
#define CONN2AP_EMI_PATH_ADDR_START 0x0360
|
||||
#define CONN2AP_EMI_PATH_ADDR_END 0x0364
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_RGU (0x1800_0000) */
|
||||
/**********************************************************************/
|
||||
#define WFSYS_ON_TOP_PWR_CTL 0x0010
|
||||
#define BGFYS_ON_TOP_PWR_CTL 0x0020
|
||||
#define SYSRAM_HWCTL_PDN 0x0050
|
||||
#define SYSRAM_HWCTL_SLP 0x0054
|
||||
#define WFSYS_CPU_SW_RST_B 0x0120
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_WT_SLP_CTL_REG (0x1800_5000) */
|
||||
/* Base: INST2_CONN_WT_SLP_CTL_REG (0x1808_5000) */
|
||||
/**********************************************************************/
|
||||
#define WB_WF_CK_ADDR 0x0070
|
||||
#define WB_WF_WAKE_ADDR 0x0074
|
||||
#define WB_WF_ZPS_ADDR 0x0078
|
||||
#define WB_TOP_CK_ADDR 0x0084
|
||||
#define WB_WF_B0_CMD_ADDR 0x008C
|
||||
#define WB_WF_B1_CMD_ADDR 0x0090
|
||||
#define WB_SLP_TOP_CK_0 0x0120
|
||||
#define WB_SLP_TOP_CK_1 0x0124
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_RF_SPI_MST_REG (0x1800_4000) */
|
||||
/* Base: INST2_CONN_RF_SPI_MST_REG (0x1808_4000) */
|
||||
/**********************************************************************/
|
||||
#define SPI_STA 0x0000
|
||||
#define SPI_WF_ADDR 0x0010
|
||||
#define SPI_WF_WDAT 0x0014
|
||||
#define SPI_WF_RDAT 0x0018
|
||||
#define SPI_BT_ADDR 0x0020
|
||||
#define SPI_BT_WDAT 0x0024
|
||||
#define SPI_BT_RDAT 0x0028
|
||||
#define SPI_FM_ADDR 0x0030
|
||||
#define SPI_FM_WDAT 0x0034
|
||||
#define SPI_FM_RDAT 0x0038
|
||||
#define SPI_GPS_ADDR 0x0040
|
||||
#define SPI_GPS_WDAT 0x0044
|
||||
#define SPI_GPS_RDAT 0x0048
|
||||
#define SPI_TOP_ADDR 0x0050
|
||||
#define SPI_TOP_WDAT 0x0054
|
||||
#define SPI_TOP_RDAT 0x0058
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_SEMAPHORE_BASE (0x1807_0000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_SEMA00_M2_OWN_STA 0x2000
|
||||
#define CONN_SEMA00_M2_OWN_REL 0x2200
|
||||
#define CONN_SEMA_OWN_BY_M0_STA_REP 0x0400
|
||||
#define CONN_SEMA_OWN_BY_M1_STA_REP 0x1400
|
||||
#define CONN_SEMA_OWN_BY_M2_STA_REP 0x2400
|
||||
#define CONN_SEMA_OWN_BY_M3_STA_REP 0x3400
|
||||
#define CONN_SEMA_OWN_BY_M4_STA_REP 0x4400
|
||||
#define CONN_SEMA_OWN_BY_M5_STA_REP 0x5400
|
||||
#define CONN_SEMA_OWN_BY_M6_STA_REP 0x6400
|
||||
#define CONN_SEMA_OWN_BY_M7_STA_REP 0x7400
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_AFE_CTL_BASE (0x1800_3000) */
|
||||
/* Base: CONN_AFE_CTL_2ND_BASE (0x1808_3000) */
|
||||
/**********************************************************************/
|
||||
#define RG_DIG_EN_01 0x0000
|
||||
#define RG_DIG_EN_02 0x0004
|
||||
#define RG_DIG_EN_03 0x0008
|
||||
#define RG_DIG_TOP_01 0x000C
|
||||
#define RG_PLL_STB_TIME 0x00F4
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_TOP_SLPPROT_ON_BASE (0x8102_0000 remap to 0x184C_0000) */
|
||||
/**********************************************************************/
|
||||
#define WF_TOP_SLPPROT_ON_STATUS_READ 0x300C
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_TOP_CFG_BASE (0x8002_0000 remap to 0x184B_0000) */
|
||||
/**********************************************************************/
|
||||
#define WF_TOP_CFG_IP_VERSION 0x0010
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_MCU_CONFIG_LS_BASE (0x8800_0000 remap to 0x184F_0000) */
|
||||
/**********************************************************************/
|
||||
#define BUSHANGCR 0x0440
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_MCU_BUS_CR_BASE (0x830C_0XXX remap to 0x1840_0XXX) */
|
||||
/**********************************************************************/
|
||||
#define AP2WF_REMAP_1 0x0120
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE (0x810F_0000 remap to 0x1850_0000) */
|
||||
/**********************************************************************/
|
||||
#define WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_WFMCU_PWA_CTRL0 0x0000
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_TOP_CFG_ON_BASE (0x8102_1000 remap to 0x184C_0000) */
|
||||
/**********************************************************************/
|
||||
#define ROMCODE_INDEX 0x1604
|
||||
|
||||
/**********************************************************************/
|
||||
/* A-die CR */
|
||||
/**********************************************************************/
|
||||
#define ATOP_CHIP_ID 0x02C
|
||||
#define ATOP_TOP_CLK_EN 0xA00
|
||||
#define ATOP_RG_ENCAL_WBTAC_IF_SW 0x070
|
||||
#define ATOP_RG_WRI_CK_SELECT 0x4AC
|
||||
#define ATOP_EFUSE_CTRL_1 0x108
|
||||
#define ATOP_EFUSE_CTRL_2 0x148
|
||||
#define ATOP_EFUSE_CTRL_3 0x14C
|
||||
#define ATOP_EFUSE_CTRL_4 0x15C
|
||||
#define ATOP_EFUSE_RDATA0 0x130
|
||||
#define ATOP_EFUSE_RDATA1 0x134
|
||||
#define ATOP_EFUSE_RDATA2 0x138
|
||||
#define ATOP_EFUSE_RDATA3 0x13C
|
||||
#define ATOP_RG_EFUSE_CFG5 0x144
|
||||
#define ATOP_THADC_ANALOG 0x3A6
|
||||
#define ATOP_THADC_SLOP 0x3A7
|
||||
#define ATOP_RG_TOP_THADC_BG 0x034
|
||||
#define ATOP_RG_TOP_THADC_00 0x038
|
||||
|
||||
#define ATOP_XTAL_TRIM_FLOW 0x3AC
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_80M_OSC 0x390
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_40M_OSC 0x391
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_TRIM1_80M_OSC 0x398
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_TRIM1_40M_OSC 0x399
|
||||
#define ATOP_RG_STRAP_PIN_IN 0x4FC
|
||||
#define ATOP_RG_XO_01 0x65C
|
||||
#define ATOP_RG_XO_03 0x664
|
||||
|
||||
|
||||
#define ATOP_7975_XTAL_CALIBRATION 0x3A1
|
||||
#define ATOP_7975_XTAL_TRIM2_COMPENSATION 0x3A2
|
||||
#define ATOP_7975_XTAL_TRIM3_COMPENSATION 0x3A3
|
||||
#define ATOP_7975_XTAL_TRIM4_COMPENSATION 0x3A4
|
||||
#define ATOP_7975_XTAL_TRIM_FLOW 0x3A5
|
||||
#define ATOP_7975_CR_C1_C2_A94 0xA94
|
||||
#define ATOP_7975_CR_C1_C2_A18 0xA18
|
||||
#define ATOP_7975_CR_C1_C2_A84 0xA84
|
||||
#define ATOP_7975_CR_C1_C2_AA4 0xAA4
|
||||
|
||||
|
||||
|
||||
#endif /* _PLATFORM_MT7981_CONSYS_REG_OFFSET_H_ */
|
@ -0,0 +1,72 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7981_EMI_H_
|
||||
#define _PLATFORM_MT7981_EMI_H_
|
||||
|
||||
#include "osal.h"
|
||||
#include "emi_mng.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_emi_ops* get_consys_platform_emi_ops(void);
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _PLATFORM_MT7981_EMI_H_ */
|
@ -0,0 +1,72 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7981_PMIC_H_
|
||||
#define _PLATFORM_MT7981_PMIC_H_
|
||||
|
||||
#include "osal.h"
|
||||
#include "pmic_mng.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_pmic_ops* get_consys_platform_pmic_ops(void);
|
||||
|
||||
#endif /* _PLATFORM_MT7981_PMIC_H_ */
|
@ -0,0 +1,63 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7981_POS_H_
|
||||
#define _PLATFORM_MT7981_POS_H_
|
||||
|
||||
int consys_plt_hw_init(void);
|
||||
int consys_xtal_ctrl_fast_mode(void);
|
||||
int consys_sw_reset_ctrl(bool bassert);
|
||||
int consys_tx_rx_bus_slp_prot_ctrl(bool enable);
|
||||
void consys_set_if_pinmux(bool enable);
|
||||
int consys_polling_chipid(void);
|
||||
int consys_plt_adie_type_cfg(void);
|
||||
int consys_bus_clock_ctrl(enum consys_drv_type drv_type, unsigned int bus_clock);
|
||||
int consys_emi_set_remapping_reg(void);
|
||||
int consys_emi_set_region_protection(void);
|
||||
int connsys_d_die_cfg(void);
|
||||
int connsys_conninfra_sysram_hw_ctrl(void);
|
||||
int connsys_spi_master_cfg(void);
|
||||
int consys_sema_acquire_timeout(unsigned int index, unsigned int usec);
|
||||
void consys_sema_release(unsigned int index);
|
||||
int consys_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data);
|
||||
int consys_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data);
|
||||
int consys_spi_write_offset_range(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int value,
|
||||
unsigned int reg_offset, unsigned int value_offset, unsigned int size);
|
||||
int connsys_a_die_cfg(void);
|
||||
int connsys_afe_wbg_cal(void);
|
||||
int connsys_subsys_pll_initial(void);
|
||||
int connsys_osc_legacy_mode(void);
|
||||
int connsys_top_pwr_ctrl(void);
|
||||
int connsys_conn_infra_bus_timeout(void);
|
||||
int connsys_clkgen_wpll_hw_ctrl(void);
|
||||
int consys_conninfra_top_wakeup(void);
|
||||
int consys_conninfra_top_sleep(void);
|
||||
int consys_adie_top_ck_en_on_off_ctrl(enum consys_drv_type type, unsigned char on);
|
||||
int consys_conninfra_wf_wakeup(void);
|
||||
int consys_conninfra_wf_sleep(void);
|
||||
int consys_conn_wmcpu_sw_reset(bool bassert);
|
||||
int consys_wf_bus_slp_prot_ctrl(bool enable);
|
||||
int consys_wfsys_top_on_ctrl(bool enable);
|
||||
int consys_wfsys_bus_slp_prot_check(bool enable);
|
||||
int consys_wfsys_bus_timeout_ctrl(void);
|
||||
int consys_wmcpu_idle_loop_check(void);
|
||||
int consys_wpll_ctrl(bool enable);
|
||||
int consys_conninfra_wf_req_clr(void);
|
||||
|
||||
|
||||
#endif /* _PLATFORM_MT7981_POS_H_ */
|
162
package/mtk/drivers/conninfra/src/platform/mt7981/mt7981.c
Normal file
162
package/mtk/drivers/conninfra/src/platform/mt7981/mt7981.c
Normal file
@ -0,0 +1,162 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/delay.h>
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/pm_runtime.h>
|
||||
#include <linux/of.h>
|
||||
#include <linux/of_irq.h>
|
||||
#include <linux/of_address.h>
|
||||
|
||||
#include "osal.h"
|
||||
#include "conninfra.h"
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_mng.h"
|
||||
#include "consys_reg_util.h"
|
||||
#include "mt7981.h"
|
||||
#include "mt7981_pos.h"
|
||||
#include "emi_mng.h"
|
||||
#include "mt7981_consys_reg.h"
|
||||
#include "mt7981_consys_reg_offset.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
#define PLATFORM_SOC_CHIP 0x7981
|
||||
#define CONN_IP_VER 0x02090000
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
struct consys_hw_ops_struct g_consys_hw_ops_mt7981 = {
|
||||
/* HW init */
|
||||
.consys_plt_hw_init = consys_plt_hw_init,
|
||||
|
||||
/* POS */
|
||||
.consys_plt_xtal_ctrl_fast_mode = consys_xtal_ctrl_fast_mode,
|
||||
.consys_plt_connsys_sw_reset_ctrl = consys_sw_reset_ctrl,
|
||||
.consys_plt_set_if_pinmux = consys_set_if_pinmux,
|
||||
.consys_plt_tx_rx_bus_slp_prot_ctrl = consys_tx_rx_bus_slp_prot_ctrl,
|
||||
.consys_plt_polling_consys_chipid = consys_polling_chipid,
|
||||
.consys_plt_bus_clock_ctrl = consys_bus_clock_ctrl,
|
||||
.consys_plt_d_die_cfg = connsys_d_die_cfg,
|
||||
.consys_plt_conninfra_sysram_hw_ctrl = connsys_conninfra_sysram_hw_ctrl,
|
||||
.consys_plt_spi_master_cfg = connsys_spi_master_cfg,
|
||||
.consys_plt_a_die_cfg = connsys_a_die_cfg,
|
||||
.consys_plt_afe_wbg_cal = connsys_afe_wbg_cal,
|
||||
.consys_plt_subsys_pll_initial = connsys_subsys_pll_initial,
|
||||
.consys_plt_osc_legacy_mode = connsys_osc_legacy_mode,
|
||||
.consys_plt_top_pwr_ctrl = connsys_top_pwr_ctrl,
|
||||
.consys_plt_conn_infra_bus_timeout = connsys_conn_infra_bus_timeout,
|
||||
.consys_plt_clkgen_wpll_hw_ctrl = connsys_clkgen_wpll_hw_ctrl,
|
||||
.consys_plt_conninfra_wakeup = consys_conninfra_top_wakeup,
|
||||
.consys_plt_conninfra_sleep = consys_conninfra_top_sleep,
|
||||
.consys_plt_adie_top_ck_en_on_off_ctrl = consys_adie_top_ck_en_on_off_ctrl,
|
||||
.consys_plt_conninfra_wf_wakeup = consys_conninfra_wf_wakeup,
|
||||
.consys_plt_conninfra_wf_sleep = consys_conninfra_wf_sleep,
|
||||
.consys_plt_conn_wmcpu_sw_reset = consys_conn_wmcpu_sw_reset,
|
||||
.consys_plt_wf_bus_slp_prot_ctrl = consys_wf_bus_slp_prot_ctrl,
|
||||
.consys_plt_wfsys_top_on_ctrl = consys_wfsys_top_on_ctrl,
|
||||
.consys_plt_wfsys_bus_slp_prot_check = consys_wfsys_bus_slp_prot_check,
|
||||
.consys_plt_wfsys_bus_timeout_ctrl = consys_wfsys_bus_timeout_ctrl,
|
||||
.consys_plt_conn_wmcpu_idle_loop_check = consys_wmcpu_idle_loop_check,
|
||||
.consys_plt_wpll_ctrl = consys_wpll_ctrl,
|
||||
.consys_plt_conninfra_wf_req_clr = consys_conninfra_wf_req_clr,
|
||||
|
||||
/* load from dts */
|
||||
/* TODO: mtcmos should move to a independent module */
|
||||
.consys_plt_clk_get_from_dts = NULL,
|
||||
.consys_plt_clk_detach = NULL,
|
||||
|
||||
/* clock */
|
||||
.consys_plt_soc_chipid_get = consys_soc_chipid_get,
|
||||
|
||||
/* debug */
|
||||
.consys_plt_get_hw_ver = consys_get_hw_ver,
|
||||
.consys_plt_spi_read = consys_spi_read,
|
||||
.consys_plt_spi_write = consys_spi_write,
|
||||
.consys_plt_spi_clock_switch = NULL,
|
||||
.consys_plt_power_state = NULL,
|
||||
|
||||
/* others */
|
||||
.consys_plt_adie_type_cfg = consys_plt_adie_type_cfg,
|
||||
};
|
||||
|
||||
/* For mt7981 */
|
||||
extern struct consys_hw_ops_struct g_consys_hw_ops_mt7981;
|
||||
extern struct consys_reg_mng_ops g_dev_consys_reg_ops_mt7981;
|
||||
extern struct consys_platform_emi_ops g_consys_platform_emi_ops_mt7981;
|
||||
extern struct consys_platform_pmic_ops g_consys_platform_pmic_ops_mt7981;
|
||||
|
||||
const struct conninfra_plat_data mt7981_plat_data = {
|
||||
.chip_id = PLATFORM_SOC_CHIP,
|
||||
.hw_ops = &g_consys_hw_ops_mt7981,
|
||||
.reg_ops = &g_dev_consys_reg_ops_mt7981,
|
||||
.platform_emi_ops = &g_consys_platform_emi_ops_mt7981,
|
||||
.platform_pmic_ops = &g_consys_platform_pmic_ops_mt7981,
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
unsigned int consys_soc_chipid_get(void)
|
||||
{
|
||||
return PLATFORM_SOC_CHIP;
|
||||
}
|
||||
|
||||
unsigned int consys_get_hw_ver(void)
|
||||
{
|
||||
return CONN_IP_VER;
|
||||
}
|
||||
|
@ -0,0 +1,172 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/of.h>
|
||||
#include <linux/of_irq.h>
|
||||
#include <linux/of_address.h>
|
||||
#include <linux/random.h>
|
||||
#include "consys_reg_mng.h"
|
||||
#include "mt7981_consys_reg.h"
|
||||
#include "mt7981_consys_reg_offset.h"
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_util.h"
|
||||
|
||||
#define CFG_REG_LOAD_FROM_DTS_CTRL 0
|
||||
|
||||
static int consys_reg_init(struct platform_device *pdev);
|
||||
static int consys_reg_deinit(void);
|
||||
|
||||
struct consys_base_addr conn_reg = {
|
||||
.reg_base_addr[TOP_MISC_BASE] = {0x11D10000, 0x1000, 0},
|
||||
.reg_base_addr[TOPRGU_BASE] = {0x1001C000, 0x1000, 0},
|
||||
.reg_base_addr[GPIO_BASE] = {0x11D00000, 0x1000, 0},
|
||||
.reg_base_addr[IOCFG_TM_BASE] = {0x11F00000, 0x1000, 0},
|
||||
.reg_base_addr[IOCFG_LT_BASE] = {0x11F10000, 0x1000, 0},
|
||||
.reg_base_addr[INFRACFG_AO_BASE] = {0x10003000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_CFG_BASE] = {0x18001000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_SYSRAM_BASE] = {0x18050000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_CLKGEN_ON_TOP_BASE] = {0x18009000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_HOST_CSR_TOP_BASE] = {0x18060000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_BUS_CR_BASE] = {0x1800E000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_RGU_BASE] = {0x18000000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_WT_SLP_CTL_REG_BASE] = {0x18005000, 0x1000, 0},
|
||||
.reg_base_addr[INST2_CONN_WT_SLP_CTL_REG_BASE] = {0x18085000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_RF_SPI_MST_REG_BASE] = {0x18004000, 0x1000, 0},
|
||||
.reg_base_addr[INST2_CONN_RF_SPI_MST_REG_BASE] = {0x18084000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_SEMAPHORE_BASE] = {0x18070000, 0x10000, 0},
|
||||
.reg_base_addr[CONN_AFE_CTL_BASE] = {0x18003000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_AFE_CTL_2ND_BASE] = {0x18083000, 0x1000, 0},
|
||||
.reg_base_addr[WF_TOP_SLPPROT_ON_BASE] = {0x184C0000, 0x10000, 0},
|
||||
.reg_base_addr[WF_TOP_CFG_BASE] = {0x184B0000, 0x1000, 0},
|
||||
.reg_base_addr[WF_MCU_CONFIG_LS_BASE] = {0x184F0000, 0x1000, 0},
|
||||
.reg_base_addr[WF_MCU_BUS_CR_BASE] = {0x18400000, 0x1000, 0},
|
||||
.reg_base_addr[WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE] = {0x18500000, 0x1000, 0},
|
||||
.reg_base_addr[WF_TOP_CFG_ON_BASE] = {0x184C0000, 0x10000, 0},
|
||||
};
|
||||
|
||||
const char* consys_base_addr_index_to_str[CONSYS_BASE_ADDR_MAX] = {
|
||||
"TOP_MISC_BASE",
|
||||
"TOPRGU_BASE",
|
||||
"GPIO_BASE",
|
||||
"IOCFG_TR_BASE",
|
||||
"IOCFG_TL_BASE",
|
||||
"INFRACFG_AO_BASE",
|
||||
"CONN_INFRA_CFG_BASE",
|
||||
"CONN_INFRA_SYSRAM_BASE",
|
||||
"CONN_INFRA_CLKGEN_ON_TOP_BASE",
|
||||
"CONN_HOST_CSR_TOP_BASE",
|
||||
"CONN_INFRA_BUS_CR_BASE",
|
||||
"CONN_INFRA_RGU_BASE",
|
||||
"CONN_WT_SLP_CTL_REG_BASE",
|
||||
"INST2_CONN_WT_SLP_CTL_REG_BASE",
|
||||
"CONN_RF_SPI_MST_REG_BASE",
|
||||
"INST2_CONN_RF_SPI_MST_REG_BASE",
|
||||
"CONN_SEMAPHORE_BASE",
|
||||
"CONN_AFE_CTL_BASE",
|
||||
"CONN_AFE_CTL_2ND_BASE",
|
||||
"WF_TOP_SLPPROT_ON_BASE",
|
||||
"WF_TOP_CFG_BASE",
|
||||
"WF_MCU_CONFIG_LS_BASE",
|
||||
"WF_MCU_BUS_CR_BASE",
|
||||
"WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE",
|
||||
"WF_TOP_CFG_ON_BASE"
|
||||
};
|
||||
|
||||
struct consys_reg_mng_ops g_dev_consys_reg_ops_mt7981 = {
|
||||
.consys_reg_mng_init = consys_reg_init,
|
||||
.consys_reg_mng_deinit = consys_reg_deinit,
|
||||
.consys_reg_mng_check_reable = NULL,
|
||||
.consys_reg_mng_is_consys_reg = NULL,
|
||||
.consys_reg_mng_is_bus_hang = NULL,
|
||||
.consys_reg_mng_dump_bus_status = NULL,
|
||||
.consys_reg_mng_dump_conninfra_status = NULL,
|
||||
.consys_reg_mng_dump_cpupcr = NULL,
|
||||
.consys_reg_mng_is_host_csr = NULL,
|
||||
};
|
||||
|
||||
struct consys_base_addr* get_conn_reg_base_addr()
|
||||
{
|
||||
return &conn_reg;
|
||||
}
|
||||
|
||||
static int consys_reg_init(struct platform_device *pdev)
|
||||
{
|
||||
int ret = -1;
|
||||
struct device_node *node = NULL;
|
||||
struct consys_reg_base_addr *base_addr = NULL;
|
||||
int i = 0;
|
||||
|
||||
node = pdev->dev.of_node;
|
||||
if (node) {
|
||||
#if (CFG_REG_LOAD_FROM_DTS_CTRL == 1)
|
||||
struct resource res;
|
||||
int flag;
|
||||
|
||||
for (i = 0; i < CONSYS_BASE_ADDR_MAX; i++) {
|
||||
base_addr = &conn_reg.reg_base_addr[i];
|
||||
ret = of_address_to_resource(node, i, &res);
|
||||
if (ret) {
|
||||
pr_err("Get Reg Index(%d-%s) failed\n", i, consys_base_addr_index_to_str[i]);
|
||||
continue;
|
||||
}
|
||||
base_addr->phy_addr = res.start;
|
||||
base_addr->vir_addr = (unsigned long)of_iomap(node, i);
|
||||
of_get_address(node, i, &(base_addr->size), &flag);
|
||||
#if 0
|
||||
pr_info("Get Index(%d-%s) phy_addr(0x%zx) vir_addr=(0x%zx) size=(0x%zx)\n",
|
||||
i, consys_base_addr_index_to_str[i], base_addr->phy_addr,
|
||||
base_addr->vir_addr, base_addr->size);
|
||||
#endif
|
||||
}
|
||||
#else
|
||||
for (i = 0; i < CONSYS_BASE_ADDR_MAX; i++) {
|
||||
base_addr = &conn_reg.reg_base_addr[i];
|
||||
if (base_addr->vir_addr == 0)
|
||||
base_addr->vir_addr = (unsigned long)ioremap(base_addr->phy_addr, base_addr->size);
|
||||
|
||||
pr_info("Get Index(%d-%s) phy_addr(0x%zx) vir_addr=(0x%zx) size=(0x%zx)\n",
|
||||
i, consys_base_addr_index_to_str[i], base_addr->phy_addr,
|
||||
base_addr->vir_addr, base_addr->size);
|
||||
}
|
||||
#endif
|
||||
} else {
|
||||
pr_err("[%s] can't find CONSYS compatible node\n", __func__);
|
||||
return ret;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int consys_reg_deinit(void)
|
||||
{
|
||||
int i = 0;
|
||||
|
||||
for (i = 0; i < CONSYS_BASE_ADDR_MAX; i++) {
|
||||
if (conn_reg.reg_base_addr[i].vir_addr) {
|
||||
pr_info("[%d] Unmap %s (0x%zx)\n", i, consys_base_addr_index_to_str[i],
|
||||
conn_reg.reg_base_addr[i].vir_addr);
|
||||
iounmap((void __iomem*)conn_reg.reg_base_addr[i].vir_addr);
|
||||
conn_reg.reg_base_addr[i].vir_addr = 0;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -0,0 +1,50 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/of_reserved_mem.h>
|
||||
#include "mt7981_emi.h"
|
||||
#include "mt7981.h"
|
||||
#include "mt7981_consys_reg.h"
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_util.h"
|
||||
#include "mt7981_pos.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
unsigned int consys_emi_get_fw_emi_size(void)
|
||||
{
|
||||
return 0x100000;
|
||||
}
|
||||
|
||||
struct consys_platform_emi_ops g_consys_platform_emi_ops_mt7981 = {
|
||||
.consys_ic_emi_set_region_protection = consys_emi_set_region_protection,
|
||||
.consys_ic_emi_set_remapping_reg = consys_emi_set_remapping_reg,
|
||||
.consys_ic_emi_get_fw_emi_size = consys_emi_get_fw_emi_size,
|
||||
};
|
||||
|
||||
struct consys_platform_emi_ops* get_consys_platform_emi_ops(void)
|
||||
{
|
||||
return &g_consys_platform_emi_ops_mt7981;
|
||||
}
|
||||
|
@ -0,0 +1,95 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/of_reserved_mem.h>
|
||||
#include <linux/regulator/consumer.h>
|
||||
#include <linux/notifier.h>
|
||||
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_util.h"
|
||||
#include "osal.h"
|
||||
#include "mt7981_pmic.h"
|
||||
#include "mt7981_pos.h"
|
||||
#include "mt7981_consys_reg.h"
|
||||
#include "mt7981_consys_reg_offset.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_pmic_ops g_consys_platform_pmic_ops_mt7981 = {
|
||||
.consys_pmic_get_from_dts = NULL,
|
||||
.consys_pmic_common_power_ctrl = NULL,
|
||||
.consys_pmic_wifi_power_ctrl = NULL,
|
||||
.consys_pmic_bt_power_ctrl = NULL,
|
||||
.consys_pmic_gps_power_ctrl = NULL,
|
||||
.consys_pmic_fm_power_ctrl = NULL,
|
||||
.consys_pmic_event_notifier = NULL,
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_pmic_ops* get_consys_platform_pmic_ops(void)
|
||||
{
|
||||
return &g_consys_platform_pmic_ops_mt7981;
|
||||
}
|
||||
|
1715
package/mtk/drivers/conninfra/src/platform/mt7981/mt7981_pos.c
Normal file
1715
package/mtk/drivers/conninfra/src/platform/mt7981/mt7981_pos.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,59 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7986_H_
|
||||
#define _PLATFORM_MT7986_H_
|
||||
|
||||
enum
|
||||
{
|
||||
ADIE_TYPE_NONE = 0,
|
||||
ADIE_TYPE_ONE,
|
||||
ADIE_TYPE_TWO,
|
||||
ADIE_TYPE_NUM_MAX
|
||||
};
|
||||
|
||||
enum conn_semaphore_type
|
||||
{
|
||||
CONN_SEMA_CHIP_POWER_ON_INDEX = 0,
|
||||
CONN_SEMA_CALIBRATION_INDEX = 1,
|
||||
CONN_SEMA_FW_DL_INDEX = 2,
|
||||
CONN_SEMA_CLOCK_SWITCH_INDEX = 3,
|
||||
CONN_SEMA_CCIF_INDEX = 4,
|
||||
CONN_SEMA_COEX_INDEX = 5,
|
||||
CONN_SEMA_USB_EP0_INDEX = 6,
|
||||
CONN_SEMA_USB_SHARED_INFO_INDEX = 7,
|
||||
CONN_SEMA_USB_SUSPEND_INDEX = 8,
|
||||
CONN_SEMA_USB_RESUME_INDEX = 9,
|
||||
CONN_SEMA_PCIE_INDEX = 10,
|
||||
CONN_SEMA_RFSPI_INDEX = 11,
|
||||
CONN_SEMA_EFUSE_INDEX = 12,
|
||||
CONN_SEMA_THERMAL_INDEX = 13,
|
||||
CONN_SEMA_FLASH_INDEX = 14,
|
||||
CONN_SEMA_DEBUG_INDEX = 15,
|
||||
CONN_SEMA_WIFI_LP_INDEX = 16,
|
||||
CONN_SEMA_PATCH_DL_INDEX = 17,
|
||||
CONN_SEMA_SHARED_VAR_INDEX = 18,
|
||||
CONN_SEMA_CONN_INFRA_COMMON_SYSRAM_INDEX = 19,
|
||||
CONN_SEMA_NUM_MAX = 32 /* can't be omitted */
|
||||
};
|
||||
|
||||
unsigned int consys_soc_chipid_get(void);
|
||||
unsigned int consys_get_hw_ver(void);
|
||||
|
||||
|
||||
#endif /* _PLATFORM_MT7986_H_ */
|
@ -0,0 +1,132 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7986_CONSYS_REG_H_
|
||||
#define _PLATFORM_MT7986_CONSYS_REG_H_
|
||||
|
||||
#include "consys_reg_base.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
enum consys_base_addr_index {
|
||||
TOP_MISC_BASE = 0, /* top_misc */
|
||||
TOPRGU_BASE = 1, /* TOPRGU */
|
||||
GPIO_BASE = 2, /* GPIO */
|
||||
IOCFG_TR_BASE = 3, /* IOCFG_TR */
|
||||
IOCFG_TL_BASE = 4, /* IOCFG_TL */
|
||||
INFRACFG_AO_BASE = 5, /* infracfg_ao_auto_gen_reg */
|
||||
CONN_INFRA_CFG_BASE = 6, /* conn_infra_cfg */
|
||||
CONN_INFRA_SYSRAM_BASE = 7, /* conn_infra_sysram */
|
||||
CONN_INFRA_CLKGEN_ON_TOP_BASE = 8, /* conn_infra_clkgen_on_top */
|
||||
CONN_HOST_CSR_TOP_BASE = 9, /* conn_host_csr_top */
|
||||
CONN_INFRA_BUS_CR_BASE = 10, /* conn_infra_bus_cr */
|
||||
CONN_INFRA_RGU_BASE = 11, /* conn_infra_rgu */
|
||||
CONN_WT_SLP_CTL_REG_BASE = 12, /* conn_wt_slp_ctl_reg */
|
||||
INST2_CONN_WT_SLP_CTL_REG_BASE = 13, /* Inst2_conn_wt_slp_ctl_reg */
|
||||
CONN_RF_SPI_MST_REG_BASE = 14, /* conn_rf_spi_mst_reg */
|
||||
INST2_CONN_RF_SPI_MST_REG_BASE = 15, /* Inst2_conn_rf_spi_mst_reg */
|
||||
CONN_SEMAPHORE_BASE = 16, /* conn_semaphore */
|
||||
CONN_AFE_CTL_BASE = 17, /* conn_afe_ctl */
|
||||
CONN_AFE_CTL_2ND_BASE = 18, /* conn_afe_ctl_2nd */
|
||||
WF_TOP_SLPPROT_ON_BASE = 19, /* wf_top_slpprot_on by remapping to 0x81020000 */
|
||||
WF_TOP_CFG_BASE = 20, /* wf_top_cfg by remapping to 0x80020000 */
|
||||
WF_MCU_CONFIG_LS_BASE = 21, /* wf_mcu_confg_ls by remapping to 0x88000000 */
|
||||
WF_MCU_BUS_CR_BASE = 22, /* wf_mcu_bus_cr by remapping to 0x830C0XXX */
|
||||
WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE = 23, /* wf_mcusys_infra_bus_full_u_debug_ctrl_ao by remapping to 0x810F0000 */
|
||||
WF_TOP_CFG_ON_BASE = 24, /* wf_top_cfg_on by remapping to 0x81021000 */
|
||||
CONSYS_BASE_ADDR_MAX
|
||||
};
|
||||
|
||||
struct consys_base_addr {
|
||||
struct consys_reg_base_addr reg_base_addr[CONSYS_BASE_ADDR_MAX];
|
||||
};
|
||||
|
||||
extern struct consys_base_addr conn_reg;
|
||||
|
||||
#define REG_TOP_MISC_ADDR conn_reg.reg_base_addr[TOP_MISC_BASE].vir_addr
|
||||
#define REG_TOP_RGU_ADDR conn_reg.reg_base_addr[TOPRGU_BASE].vir_addr
|
||||
#define REG_GPIO_BASE_ADDR conn_reg.reg_base_addr[GPIO_BASE].vir_addr
|
||||
#define REG_IOCFG_TR_ADDR conn_reg.reg_base_addr[IOCFG_TR_BASE].vir_addr
|
||||
#define REG_IOCFG_TL_ADDR conn_reg.reg_base_addr[IOCFG_TL_BASE].vir_addr
|
||||
#define REG_INFRACFG_AO_ADDR conn_reg.reg_base_addr[INFRACFG_AO_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_CFG_ADDR conn_reg.reg_base_addr[CONN_INFRA_CFG_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_SYSRAM_ADDR conn_reg.reg_base_addr[CONN_INFRA_SYSRAM_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_CLKGEN_ON_TOP_ADDR conn_reg.reg_base_addr[CONN_INFRA_CLKGEN_ON_TOP_BASE].vir_addr
|
||||
#define REG_CONN_HOST_CSR_TOP_ADDR conn_reg.reg_base_addr[CONN_HOST_CSR_TOP_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_BUS_CR_ADDR conn_reg.reg_base_addr[CONN_INFRA_BUS_CR_BASE].vir_addr
|
||||
#define REG_CONN_INFRA_RGU_ADDR conn_reg.reg_base_addr[CONN_INFRA_RGU_BASE].vir_addr
|
||||
#define REG_CONN_WT_SLP_CTL_REG_ADDR conn_reg.reg_base_addr[CONN_WT_SLP_CTL_REG_BASE].vir_addr
|
||||
#define REG_INST2_CONN_WT_SLP_CTL_REG_ADDR conn_reg.reg_base_addr[INST2_CONN_WT_SLP_CTL_REG_BASE].vir_addr
|
||||
#define REG_CONN_RF_SPI_MST_REG_ADDR conn_reg.reg_base_addr[CONN_RF_SPI_MST_REG_BASE].vir_addr
|
||||
#define REG_INST2_CONN_RF_SPI_MST_REG_ADDR conn_reg.reg_base_addr[INST2_CONN_RF_SPI_MST_REG_BASE].vir_addr
|
||||
#define REG_CONN_SEMAPHORE_ADDR conn_reg.reg_base_addr[CONN_SEMAPHORE_BASE].vir_addr
|
||||
#define REG_CONN_AFE_CTL_ADDR conn_reg.reg_base_addr[CONN_AFE_CTL_BASE].vir_addr
|
||||
#define REG_CONN_AFE_CTL_2ND_ADDR conn_reg.reg_base_addr[CONN_AFE_CTL_2ND_BASE].vir_addr
|
||||
#define REG_WF_TOP_SLPPROT_ON_ADDR conn_reg.reg_base_addr[WF_TOP_SLPPROT_ON_BASE].vir_addr
|
||||
#define REG_WF_TOP_CFG_ADDR conn_reg.reg_base_addr[WF_TOP_CFG_BASE].vir_addr
|
||||
#define REG_WF_MCU_CONFIG_LS_ADDR conn_reg.reg_base_addr[WF_MCU_CONFIG_LS_BASE].vir_addr
|
||||
#define REG_WF_MCU_BUS_CR_ADDR conn_reg.reg_base_addr[WF_MCU_BUS_CR_BASE].vir_addr
|
||||
#define REG_WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_ADDR conn_reg.reg_base_addr[WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE].vir_addr
|
||||
#define REG_WF_TOP_CFG_ON_ADDR conn_reg.reg_base_addr[WF_TOP_CFG_ON_BASE].vir_addr
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_base_addr* get_conn_reg_base_addr(void);
|
||||
|
||||
#endif /* _PLATFORM_MT7986_CONSYS_REG_H_ */
|
@ -0,0 +1,243 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7986_CONSYS_REG_OFFSET_H_
|
||||
#define _PLATFORM_MT7986_CONSYS_REG_OFFSET_H_
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: TOP_MISC (0x11D1_0000) */
|
||||
/**********************************************************************/
|
||||
#define CONNSYS_MISC 0x0114
|
||||
#define TOP_MISC_RSRV_ALL1_3 0x021C
|
||||
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: TOP RGU (0x1001_C000) */
|
||||
/**********************************************************************/
|
||||
#define TOP_RGU_WDT_SWSYSRST 0x0018
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: GPIO (0x1001_F000) */
|
||||
/**********************************************************************/
|
||||
#define GPIO_MODE9 0x0390
|
||||
#define GPIO_MODE10 0x03A0
|
||||
#define GPIO_MODE11 0x03B0
|
||||
#define GPIO_MODE12 0x03C0
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: IOCFG_TR (0x11F0_0000) */
|
||||
/**********************************************************************/
|
||||
#define IOCFG_TR_DRV_CFG0 0x0000
|
||||
#define IOCFG_TR_DRV_CFG1 0x0010
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: IOCFG_TL (0x11F1_0000) */
|
||||
/**********************************************************************/
|
||||
#define IOCFG_TL_DRV_CFG0 0x0000
|
||||
#define IOCFG_TL_DRV_CFG1 0x0010
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: INFRACFG_AO (0x1000_3000) */
|
||||
/**********************************************************************/
|
||||
#define CONN2AP_GALS_SLPPROT 0x00D0
|
||||
#define AP2CONN_GALS_SLPPROT 0x00D4
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_CFG (0x1800_1000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_INFRA_CFG_IP_VERSION 0x0000
|
||||
#define EFUSE 0x0020
|
||||
#define ADIE_CTL 0x0030
|
||||
#define CONN_INFRA_CFG_PWRCTRL0 0x0200
|
||||
#define CONN_INFRA_CFG_RC_CTL_0 0x0380
|
||||
#define OSC_CTL_0 0x0300
|
||||
#define EMI_CTL_WF 0x0414
|
||||
#define CONN_INFRA_WF_SLP_CTRL 0x0540
|
||||
#define CONN_INFRA_WF_SLP_STATUS 0x0544
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_SYSRAM (0x1805_0000) */
|
||||
/**********************************************************************/
|
||||
#define SYSRAM_BASE_ADDR 0x0000
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_CLKGEN_ON_TOP (0x1800_9000) */
|
||||
/**********************************************************************/
|
||||
#define CKGEN_BUS_WPLL_DIV_1 0x0008
|
||||
#define CKGEN_BUS_WPLL_DIV_2 0x000C
|
||||
#define CKGEN_RFSPI_WPLL_DIV 0x0040
|
||||
#define CKGEN_BUS 0x0A00
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_HOST_CSR_TOP (0x1806_0000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_INFRA_WAKEPU_TOP 0x01A0
|
||||
#define CONN_INFRA_WAKEPU_WF 0x01A4
|
||||
#define CONN2AP_REMAP_MCU_EMI 0x01C4
|
||||
#define CONN2AP_REMAP_WF_PERI 0x01D4
|
||||
#define DBG_DUMMY_3 0x02CC
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_BUS_CR (0x1800_E000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_INFRA_BUS_OFF_TIMEOUT_CTRL 0x0300
|
||||
#define CONN_INFRA_BUS_ON_TIMEOUT_CTRL 0x031C
|
||||
#define CONN2AP_EMI_PATH_ADDR_START 0x0360
|
||||
#define CONN2AP_EMI_PATH_ADDR_END 0x0364
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_INFRA_RGU (0x1800_0000) */
|
||||
/**********************************************************************/
|
||||
#define WFSYS_ON_TOP_PWR_CTL 0x0010
|
||||
#define BGFYS_ON_TOP_PWR_CTL 0x0020
|
||||
#define SYSRAM_HWCTL_PDN 0x0050
|
||||
#define SYSRAM_HWCTL_SLP 0x0054
|
||||
#define WFSYS_CPU_SW_RST_B 0x0120
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_WT_SLP_CTL_REG (0x1800_5000) */
|
||||
/* Base: INST2_CONN_WT_SLP_CTL_REG (0x1808_5000) */
|
||||
/**********************************************************************/
|
||||
#define WB_WF_CK_ADDR 0x0070
|
||||
#define WB_WF_WAKE_ADDR 0x0074
|
||||
#define WB_WF_ZPS_ADDR 0x0078
|
||||
#define WB_TOP_CK_ADDR 0x0084
|
||||
#define WB_WF_B0_CMD_ADDR 0x008C
|
||||
#define WB_WF_B1_CMD_ADDR 0x0090
|
||||
#define WB_SLP_TOP_CK_0 0x0120
|
||||
#define WB_SLP_TOP_CK_1 0x0124
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_RF_SPI_MST_REG (0x1800_4000) */
|
||||
/* Base: INST2_CONN_RF_SPI_MST_REG (0x1808_4000) */
|
||||
/**********************************************************************/
|
||||
#define SPI_STA 0x0000
|
||||
#define SPI_WF_ADDR 0x0010
|
||||
#define SPI_WF_WDAT 0x0014
|
||||
#define SPI_WF_RDAT 0x0018
|
||||
#define SPI_BT_ADDR 0x0020
|
||||
#define SPI_BT_WDAT 0x0024
|
||||
#define SPI_BT_RDAT 0x0028
|
||||
#define SPI_FM_ADDR 0x0030
|
||||
#define SPI_FM_WDAT 0x0034
|
||||
#define SPI_FM_RDAT 0x0038
|
||||
#define SPI_GPS_ADDR 0x0040
|
||||
#define SPI_GPS_WDAT 0x0044
|
||||
#define SPI_GPS_RDAT 0x0048
|
||||
#define SPI_TOP_ADDR 0x0050
|
||||
#define SPI_TOP_WDAT 0x0054
|
||||
#define SPI_TOP_RDAT 0x0058
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_SEMAPHORE_BASE (0x1807_0000) */
|
||||
/**********************************************************************/
|
||||
#define CONN_SEMA00_M2_OWN_STA 0x2000
|
||||
#define CONN_SEMA00_M2_OWN_REL 0x2200
|
||||
#define CONN_SEMA_OWN_BY_M0_STA_REP 0x0400
|
||||
#define CONN_SEMA_OWN_BY_M1_STA_REP 0x1400
|
||||
#define CONN_SEMA_OWN_BY_M2_STA_REP 0x2400
|
||||
#define CONN_SEMA_OWN_BY_M3_STA_REP 0x3400
|
||||
#define CONN_SEMA_OWN_BY_M4_STA_REP 0x4400
|
||||
#define CONN_SEMA_OWN_BY_M5_STA_REP 0x5400
|
||||
#define CONN_SEMA_OWN_BY_M6_STA_REP 0x6400
|
||||
#define CONN_SEMA_OWN_BY_M7_STA_REP 0x7400
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: CONN_AFE_CTL_BASE (0x1800_3000) */
|
||||
/* Base: CONN_AFE_CTL_2ND_BASE (0x1808_3000) */
|
||||
/**********************************************************************/
|
||||
#define RG_DIG_EN_01 0x0000
|
||||
#define RG_DIG_EN_02 0x0004
|
||||
#define RG_DIG_EN_03 0x0008
|
||||
#define RG_DIG_TOP_01 0x000C
|
||||
#define RG_PLL_STB_TIME 0x00F4
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_TOP_SLPPROT_ON_BASE (0x8102_0000 remap to 0x184C_0000) */
|
||||
/**********************************************************************/
|
||||
#define WF_TOP_SLPPROT_ON_STATUS_READ 0x300C
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_TOP_CFG_BASE (0x8002_0000 remap to 0x184B_0000) */
|
||||
/**********************************************************************/
|
||||
#define WF_TOP_CFG_IP_VERSION 0x0010
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_MCU_CONFIG_LS_BASE (0x8800_0000 remap to 0x184F_0000) */
|
||||
/**********************************************************************/
|
||||
#define BUSHANGCR 0x0440
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_MCU_BUS_CR_BASE (0x830C_0XXX remap to 0x1840_0XXX) */
|
||||
/**********************************************************************/
|
||||
#define AP2WF_REMAP_1 0x0120
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE (0x810F_0000 remap to 0x1850_0000) */
|
||||
/**********************************************************************/
|
||||
#define WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_WFMCU_PWA_CTRL0 0x0000
|
||||
|
||||
/**********************************************************************/
|
||||
/* Base: WF_TOP_CFG_ON_BASE (0x8102_1000 remap to 0x184C_0000) */
|
||||
/**********************************************************************/
|
||||
#define ROMCODE_INDEX 0x1604
|
||||
|
||||
/**********************************************************************/
|
||||
/* A-die CR */
|
||||
/**********************************************************************/
|
||||
#define ATOP_CHIP_ID 0x02C
|
||||
#define ATOP_TOP_CLK_EN 0xA00
|
||||
#define ATOP_RG_ENCAL_WBTAC_IF_SW 0x070
|
||||
#define ATOP_RG_WRI_CK_SELECT 0x4AC
|
||||
#define ATOP_EFUSE_CTRL_1 0x108
|
||||
#define ATOP_EFUSE_CTRL_2 0x148
|
||||
#define ATOP_EFUSE_CTRL_3 0x14C
|
||||
#define ATOP_EFUSE_CTRL_4 0x15C
|
||||
#define ATOP_EFUSE_RDATA0 0x130
|
||||
#define ATOP_EFUSE_RDATA1 0x134
|
||||
#define ATOP_EFUSE_RDATA2 0x138
|
||||
#define ATOP_EFUSE_RDATA3 0x13C
|
||||
#define ATOP_RG_EFUSE_CFG5 0x144
|
||||
#define ATOP_THADC_ANALOG 0x3A6
|
||||
#define ATOP_THADC_SLOP 0x3A7
|
||||
#define ATOP_RG_TOP_THADC_BG 0x034
|
||||
#define ATOP_RG_TOP_THADC_00 0x038
|
||||
|
||||
#define ATOP_XTAL_TRIM_FLOW 0x3AC
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_80M_OSC 0x390
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_40M_OSC 0x391
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_TRIM1_80M_OSC 0x398
|
||||
#define ATOP_XTAL_CR_C1_SEL_AXM_TRIM1_40M_OSC 0x399
|
||||
#define ATOP_RG_STRAP_PIN_IN 0x4FC
|
||||
#define ATOP_RG_XO_01 0x65C
|
||||
#define ATOP_RG_XO_03 0x664
|
||||
|
||||
|
||||
#define ATOP_7975_XTAL_CALIBRATION 0x3A1
|
||||
#define ATOP_7975_XTAL_TRIM2_COMPENSATION 0x3A2
|
||||
#define ATOP_7975_XTAL_TRIM3_COMPENSATION 0x3A3
|
||||
#define ATOP_7975_XTAL_TRIM4_COMPENSATION 0x3A4
|
||||
#define ATOP_7975_XTAL_TRIM_FLOW 0x3A5
|
||||
#define ATOP_7975_CR_C1_C2_A94 0xA94
|
||||
#define ATOP_7975_CR_C1_C2_A18 0xA18
|
||||
#define ATOP_7975_CR_C1_C2_A84 0xA84
|
||||
#define ATOP_7975_CR_C1_C2_AA4 0xAA4
|
||||
#define ATOP_7975_CO_CLK 0xA1C
|
||||
|
||||
|
||||
#endif /* _PLATFORM_MT7986_CONSYS_REG_OFFSET_H_ */
|
@ -0,0 +1,72 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7986_EMI_H_
|
||||
#define _PLATFORM_MT7986_EMI_H_
|
||||
|
||||
#include "osal.h"
|
||||
#include "emi_mng.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_emi_ops* get_consys_platform_emi_ops(void);
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#endif /* _PLATFORM_MT7986_EMI_H_ */
|
@ -0,0 +1,72 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7986_PMIC_H_
|
||||
#define _PLATFORM_MT7986_PMIC_H_
|
||||
|
||||
#include "osal.h"
|
||||
#include "pmic_mng.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_pmic_ops* get_consys_platform_pmic_ops(void);
|
||||
|
||||
#endif /* _PLATFORM_MT7986_PMIC_H_ */
|
@ -0,0 +1,64 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#ifndef _PLATFORM_MT7986_POS_H_
|
||||
#define _PLATFORM_MT7986_POS_H_
|
||||
|
||||
int consys_plt_hw_init(void);
|
||||
int consys_xtal_ctrl_fast_mode(void);
|
||||
int consys_sw_reset_ctrl(bool bassert);
|
||||
int consys_tx_rx_bus_slp_prot_ctrl(bool enable);
|
||||
void consys_set_if_pinmux(bool enable);
|
||||
int consys_polling_chipid(void);
|
||||
int consys_plt_adie_type_check(void);
|
||||
int consys_plt_adie_type_cfg(void);
|
||||
int consys_bus_clock_ctrl(enum consys_drv_type drv_type, unsigned int bus_clock);
|
||||
int consys_emi_set_remapping_reg(void);
|
||||
int consys_emi_set_region_protection(void);
|
||||
int connsys_d_die_cfg(void);
|
||||
int connsys_conninfra_sysram_hw_ctrl(void);
|
||||
int connsys_spi_master_cfg(void);
|
||||
int consys_sema_acquire_timeout(unsigned int index, unsigned int usec);
|
||||
void consys_sema_release(unsigned int index);
|
||||
int consys_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data);
|
||||
int consys_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data);
|
||||
int consys_spi_write_offset_range(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int value,
|
||||
unsigned int reg_offset, unsigned int value_offset, unsigned int size);
|
||||
int connsys_a_die_cfg(void);
|
||||
int connsys_afe_wbg_cal(void);
|
||||
int connsys_subsys_pll_initial(void);
|
||||
int connsys_osc_legacy_mode(void);
|
||||
int connsys_top_pwr_ctrl(void);
|
||||
int connsys_conn_infra_bus_timeout(void);
|
||||
int connsys_clkgen_wpll_hw_ctrl(void);
|
||||
int consys_conninfra_top_wakeup(void);
|
||||
int consys_conninfra_top_sleep(void);
|
||||
int consys_adie_top_ck_en_on_off_ctrl(enum consys_drv_type type, unsigned char on);
|
||||
int consys_conninfra_wf_wakeup(void);
|
||||
int consys_conninfra_wf_sleep(void);
|
||||
int consys_conn_wmcpu_sw_reset(bool bassert);
|
||||
int consys_wf_bus_slp_prot_ctrl(bool enable);
|
||||
int consys_wfsys_top_on_ctrl(bool enable);
|
||||
int consys_wfsys_bus_slp_prot_check(bool enable);
|
||||
int consys_wfsys_bus_timeout_ctrl(void);
|
||||
int consys_wmcpu_idle_loop_check(void);
|
||||
int consys_wpll_ctrl(bool enable);
|
||||
int consys_conninfra_wf_req_clr(void);
|
||||
|
||||
|
||||
#endif /* _PLATFORM_MT7986_POS_H_ */
|
163
package/mtk/drivers/conninfra/src/platform/mt7986/mt7986.c
Normal file
163
package/mtk/drivers/conninfra/src/platform/mt7986/mt7986.c
Normal file
@ -0,0 +1,163 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/delay.h>
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/pm_runtime.h>
|
||||
#include <linux/of.h>
|
||||
#include <linux/of_irq.h>
|
||||
#include <linux/of_address.h>
|
||||
|
||||
#include "osal.h"
|
||||
#include "conninfra.h"
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_mng.h"
|
||||
#include "consys_reg_util.h"
|
||||
#include "mt7986.h"
|
||||
#include "mt7986_pos.h"
|
||||
#include "emi_mng.h"
|
||||
#include "mt7986_consys_reg.h"
|
||||
#include "mt7986_consys_reg_offset.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
#define PLATFORM_SOC_CHIP 0x7986
|
||||
#define CONN_IP_VER 0x02070000
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
struct consys_hw_ops_struct g_consys_hw_ops_mt7986 = {
|
||||
/* HW init */
|
||||
.consys_plt_hw_init = consys_plt_hw_init,
|
||||
|
||||
/* POS */
|
||||
.consys_plt_xtal_ctrl_fast_mode = consys_xtal_ctrl_fast_mode,
|
||||
.consys_plt_connsys_sw_reset_ctrl = consys_sw_reset_ctrl,
|
||||
.consys_plt_set_if_pinmux = consys_set_if_pinmux,
|
||||
.consys_plt_tx_rx_bus_slp_prot_ctrl = consys_tx_rx_bus_slp_prot_ctrl,
|
||||
.consys_plt_polling_consys_chipid = consys_polling_chipid,
|
||||
.consys_plt_bus_clock_ctrl = consys_bus_clock_ctrl,
|
||||
.consys_plt_d_die_cfg = connsys_d_die_cfg,
|
||||
.consys_plt_conninfra_sysram_hw_ctrl = connsys_conninfra_sysram_hw_ctrl,
|
||||
.consys_plt_spi_master_cfg = connsys_spi_master_cfg,
|
||||
.consys_plt_a_die_cfg = connsys_a_die_cfg,
|
||||
.consys_plt_afe_wbg_cal = connsys_afe_wbg_cal,
|
||||
.consys_plt_subsys_pll_initial = connsys_subsys_pll_initial,
|
||||
.consys_plt_osc_legacy_mode = connsys_osc_legacy_mode,
|
||||
.consys_plt_top_pwr_ctrl = connsys_top_pwr_ctrl,
|
||||
.consys_plt_conn_infra_bus_timeout = connsys_conn_infra_bus_timeout,
|
||||
.consys_plt_clkgen_wpll_hw_ctrl = connsys_clkgen_wpll_hw_ctrl,
|
||||
.consys_plt_conninfra_wakeup = consys_conninfra_top_wakeup,
|
||||
.consys_plt_conninfra_sleep = consys_conninfra_top_sleep,
|
||||
.consys_plt_adie_top_ck_en_on_off_ctrl = consys_adie_top_ck_en_on_off_ctrl,
|
||||
.consys_plt_conninfra_wf_wakeup = consys_conninfra_wf_wakeup,
|
||||
.consys_plt_conninfra_wf_sleep = consys_conninfra_wf_sleep,
|
||||
.consys_plt_conn_wmcpu_sw_reset = consys_conn_wmcpu_sw_reset,
|
||||
.consys_plt_wf_bus_slp_prot_ctrl = consys_wf_bus_slp_prot_ctrl,
|
||||
.consys_plt_wfsys_top_on_ctrl = consys_wfsys_top_on_ctrl,
|
||||
.consys_plt_wfsys_bus_slp_prot_check = consys_wfsys_bus_slp_prot_check,
|
||||
.consys_plt_wfsys_bus_timeout_ctrl = consys_wfsys_bus_timeout_ctrl,
|
||||
.consys_plt_conn_wmcpu_idle_loop_check = consys_wmcpu_idle_loop_check,
|
||||
.consys_plt_wpll_ctrl = consys_wpll_ctrl,
|
||||
.consys_plt_conninfra_wf_req_clr = consys_conninfra_wf_req_clr,
|
||||
|
||||
/* load from dts */
|
||||
/* TODO: mtcmos should move to a independent module */
|
||||
.consys_plt_clk_get_from_dts = NULL,
|
||||
.consys_plt_clk_detach = NULL,
|
||||
|
||||
/* clock */
|
||||
.consys_plt_soc_chipid_get = consys_soc_chipid_get,
|
||||
|
||||
/* debug */
|
||||
.consys_plt_get_hw_ver = consys_get_hw_ver,
|
||||
.consys_plt_spi_read = consys_spi_read,
|
||||
.consys_plt_spi_write = consys_spi_write,
|
||||
.consys_plt_spi_clock_switch = NULL,
|
||||
.consys_plt_power_state = NULL,
|
||||
|
||||
/* others */
|
||||
.consys_plt_adie_type_check = consys_plt_adie_type_check,
|
||||
.consys_plt_adie_type_cfg = consys_plt_adie_type_cfg,
|
||||
};
|
||||
|
||||
/* For mt7986 */
|
||||
extern struct consys_hw_ops_struct g_consys_hw_ops_mt7986;
|
||||
extern struct consys_reg_mng_ops g_dev_consys_reg_ops_mt7986;
|
||||
extern struct consys_platform_emi_ops g_consys_platform_emi_ops_mt7986;
|
||||
extern struct consys_platform_pmic_ops g_consys_platform_pmic_ops_mt7986;
|
||||
|
||||
const struct conninfra_plat_data mt7986_plat_data = {
|
||||
.chip_id = PLATFORM_SOC_CHIP,
|
||||
.hw_ops = &g_consys_hw_ops_mt7986,
|
||||
.reg_ops = &g_dev_consys_reg_ops_mt7986,
|
||||
.platform_emi_ops = &g_consys_platform_emi_ops_mt7986,
|
||||
.platform_pmic_ops = &g_consys_platform_pmic_ops_mt7986,
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
unsigned int consys_soc_chipid_get(void)
|
||||
{
|
||||
return PLATFORM_SOC_CHIP;
|
||||
}
|
||||
|
||||
unsigned int consys_get_hw_ver(void)
|
||||
{
|
||||
return CONN_IP_VER;
|
||||
}
|
||||
|
@ -0,0 +1,172 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/of.h>
|
||||
#include <linux/of_irq.h>
|
||||
#include <linux/of_address.h>
|
||||
#include <linux/random.h>
|
||||
#include "consys_reg_mng.h"
|
||||
#include "mt7986_consys_reg.h"
|
||||
#include "mt7986_consys_reg_offset.h"
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_util.h"
|
||||
|
||||
#define CFG_REG_LOAD_FROM_DTS_CTRL 0
|
||||
|
||||
static int consys_reg_init(struct platform_device *pdev);
|
||||
static int consys_reg_deinit(void);
|
||||
|
||||
struct consys_base_addr conn_reg = {
|
||||
.reg_base_addr[TOP_MISC_BASE] = {0x11D10000, 0x1000, 0},
|
||||
.reg_base_addr[TOPRGU_BASE] = {0x1001C000, 0x1000, 0},
|
||||
.reg_base_addr[GPIO_BASE] = {0x1001F000, 0x1000, 0},
|
||||
.reg_base_addr[IOCFG_TR_BASE] = {0x11F00000, 0x1000, 0},
|
||||
.reg_base_addr[IOCFG_TL_BASE] = {0x11F10000, 0x1000, 0},
|
||||
.reg_base_addr[INFRACFG_AO_BASE] = {0x10003000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_CFG_BASE] = {0x18001000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_SYSRAM_BASE] = {0x18050000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_CLKGEN_ON_TOP_BASE] = {0x18009000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_HOST_CSR_TOP_BASE] = {0x18060000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_BUS_CR_BASE] = {0x1800E000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_INFRA_RGU_BASE] = {0x18000000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_WT_SLP_CTL_REG_BASE] = {0x18005000, 0x1000, 0},
|
||||
.reg_base_addr[INST2_CONN_WT_SLP_CTL_REG_BASE] = {0x18085000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_RF_SPI_MST_REG_BASE] = {0x18004000, 0x1000, 0},
|
||||
.reg_base_addr[INST2_CONN_RF_SPI_MST_REG_BASE] = {0x18084000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_SEMAPHORE_BASE] = {0x18070000, 0x10000, 0},
|
||||
.reg_base_addr[CONN_AFE_CTL_BASE] = {0x18003000, 0x1000, 0},
|
||||
.reg_base_addr[CONN_AFE_CTL_2ND_BASE] = {0x18083000, 0x1000, 0},
|
||||
.reg_base_addr[WF_TOP_SLPPROT_ON_BASE] = {0x184C0000, 0x10000, 0},
|
||||
.reg_base_addr[WF_TOP_CFG_BASE] = {0x184B0000, 0x1000, 0},
|
||||
.reg_base_addr[WF_MCU_CONFIG_LS_BASE] = {0x184F0000, 0x1000, 0},
|
||||
.reg_base_addr[WF_MCU_BUS_CR_BASE] = {0x18400000, 0x1000, 0},
|
||||
.reg_base_addr[WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE] = {0x18500000, 0x1000, 0},
|
||||
.reg_base_addr[WF_TOP_CFG_ON_BASE] = {0x184C0000, 0x10000, 0},
|
||||
};
|
||||
|
||||
const char* consys_base_addr_index_to_str[CONSYS_BASE_ADDR_MAX] = {
|
||||
"TOP_MISC_BASE",
|
||||
"TOPRGU_BASE",
|
||||
"GPIO_BASE",
|
||||
"IOCFG_TR_BASE",
|
||||
"IOCFG_TL_BASE",
|
||||
"INFRACFG_AO_BASE",
|
||||
"CONN_INFRA_CFG_BASE",
|
||||
"CONN_INFRA_SYSRAM_BASE",
|
||||
"CONN_INFRA_CLKGEN_ON_TOP_BASE",
|
||||
"CONN_HOST_CSR_TOP_BASE",
|
||||
"CONN_INFRA_BUS_CR_BASE",
|
||||
"CONN_INFRA_RGU_BASE",
|
||||
"CONN_WT_SLP_CTL_REG_BASE",
|
||||
"INST2_CONN_WT_SLP_CTL_REG_BASE",
|
||||
"CONN_RF_SPI_MST_REG_BASE",
|
||||
"INST2_CONN_RF_SPI_MST_REG_BASE",
|
||||
"CONN_SEMAPHORE_BASE",
|
||||
"CONN_AFE_CTL_BASE",
|
||||
"CONN_AFE_CTL_2ND_BASE",
|
||||
"WF_TOP_SLPPROT_ON_BASE",
|
||||
"WF_TOP_CFG_BASE",
|
||||
"WF_MCU_CONFIG_LS_BASE",
|
||||
"WF_MCU_BUS_CR_BASE",
|
||||
"WF_MCUSYS_INFRA_BUS_FULL_U_DEBUG_CTRL_AO_BASE",
|
||||
"WF_TOP_CFG_ON_BASE"
|
||||
};
|
||||
|
||||
struct consys_reg_mng_ops g_dev_consys_reg_ops_mt7986 = {
|
||||
.consys_reg_mng_init = consys_reg_init,
|
||||
.consys_reg_mng_deinit = consys_reg_deinit,
|
||||
.consys_reg_mng_check_reable = NULL,
|
||||
.consys_reg_mng_is_consys_reg = NULL,
|
||||
.consys_reg_mng_is_bus_hang = NULL,
|
||||
.consys_reg_mng_dump_bus_status = NULL,
|
||||
.consys_reg_mng_dump_conninfra_status = NULL,
|
||||
.consys_reg_mng_dump_cpupcr = NULL,
|
||||
.consys_reg_mng_is_host_csr = NULL,
|
||||
};
|
||||
|
||||
struct consys_base_addr* get_conn_reg_base_addr()
|
||||
{
|
||||
return &conn_reg;
|
||||
}
|
||||
|
||||
static int consys_reg_init(struct platform_device *pdev)
|
||||
{
|
||||
int ret = -1;
|
||||
struct device_node *node = NULL;
|
||||
struct consys_reg_base_addr *base_addr = NULL;
|
||||
int i = 0;
|
||||
|
||||
node = pdev->dev.of_node;
|
||||
if (node) {
|
||||
#if (CFG_REG_LOAD_FROM_DTS_CTRL == 1)
|
||||
struct resource res;
|
||||
int flag;
|
||||
|
||||
for (i = 0; i < CONSYS_BASE_ADDR_MAX; i++) {
|
||||
base_addr = &conn_reg.reg_base_addr[i];
|
||||
ret = of_address_to_resource(node, i, &res);
|
||||
if (ret) {
|
||||
pr_err("Get Reg Index(%d-%s) failed\n", i, consys_base_addr_index_to_str[i]);
|
||||
continue;
|
||||
}
|
||||
base_addr->phy_addr = res.start;
|
||||
base_addr->vir_addr = (unsigned long)of_iomap(node, i);
|
||||
of_get_address(node, i, &(base_addr->size), &flag);
|
||||
#if 0
|
||||
pr_info("Get Index(%d-%s) phy_addr(0x%zx) vir_addr=(0x%zx) size=(0x%zx)\n",
|
||||
i, consys_base_addr_index_to_str[i], base_addr->phy_addr,
|
||||
base_addr->vir_addr, base_addr->size);
|
||||
#endif
|
||||
}
|
||||
#else
|
||||
for (i = 0; i < CONSYS_BASE_ADDR_MAX; i++) {
|
||||
base_addr = &conn_reg.reg_base_addr[i];
|
||||
if (base_addr->vir_addr == 0)
|
||||
base_addr->vir_addr = (unsigned long)ioremap(base_addr->phy_addr, base_addr->size);
|
||||
|
||||
pr_info("Get Index(%d-%s) phy_addr(0x%zx) vir_addr=(0x%zx) size=(0x%zx)\n",
|
||||
i, consys_base_addr_index_to_str[i], base_addr->phy_addr,
|
||||
base_addr->vir_addr, base_addr->size);
|
||||
}
|
||||
#endif
|
||||
} else {
|
||||
pr_err("[%s] can't find CONSYS compatible node\n", __func__);
|
||||
return ret;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int consys_reg_deinit(void)
|
||||
{
|
||||
int i = 0;
|
||||
|
||||
for (i = 0; i < CONSYS_BASE_ADDR_MAX; i++) {
|
||||
if (conn_reg.reg_base_addr[i].vir_addr) {
|
||||
pr_info("[%d] Unmap %s (0x%zx)\n", i, consys_base_addr_index_to_str[i],
|
||||
conn_reg.reg_base_addr[i].vir_addr);
|
||||
iounmap((void __iomem*)conn_reg.reg_base_addr[i].vir_addr);
|
||||
conn_reg.reg_base_addr[i].vir_addr = 0;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -0,0 +1,50 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/of_reserved_mem.h>
|
||||
#include "mt7986_emi.h"
|
||||
#include "mt7986.h"
|
||||
#include "mt7986_consys_reg.h"
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_util.h"
|
||||
#include "mt7986_pos.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
unsigned int consys_emi_get_fw_emi_size(void)
|
||||
{
|
||||
return 0x100000;
|
||||
}
|
||||
|
||||
struct consys_platform_emi_ops g_consys_platform_emi_ops_mt7986 = {
|
||||
.consys_ic_emi_set_region_protection = consys_emi_set_region_protection,
|
||||
.consys_ic_emi_set_remapping_reg = consys_emi_set_remapping_reg,
|
||||
.consys_ic_emi_get_fw_emi_size = consys_emi_get_fw_emi_size,
|
||||
};
|
||||
|
||||
struct consys_platform_emi_ops* get_consys_platform_emi_ops(void)
|
||||
{
|
||||
return &g_consys_platform_emi_ops_mt7986;
|
||||
}
|
||||
|
@ -0,0 +1,95 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/memblock.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/of_reserved_mem.h>
|
||||
#include <linux/regulator/consumer.h>
|
||||
#include <linux/notifier.h>
|
||||
|
||||
#include "consys_hw.h"
|
||||
#include "consys_reg_util.h"
|
||||
#include "osal.h"
|
||||
#include "mt7986_pmic.h"
|
||||
#include "mt7986_pos.h"
|
||||
#include "mt7986_consys_reg.h"
|
||||
#include "mt7986_consys_reg_offset.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_pmic_ops g_consys_platform_pmic_ops_mt7986 = {
|
||||
.consys_pmic_get_from_dts = NULL,
|
||||
.consys_pmic_common_power_ctrl = NULL,
|
||||
.consys_pmic_wifi_power_ctrl = NULL,
|
||||
.consys_pmic_bt_power_ctrl = NULL,
|
||||
.consys_pmic_gps_power_ctrl = NULL,
|
||||
.consys_pmic_fm_power_ctrl = NULL,
|
||||
.consys_pmic_event_notifier = NULL,
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct consys_platform_pmic_ops* get_consys_platform_pmic_ops(void)
|
||||
{
|
||||
return &g_consys_platform_pmic_ops_mt7986;
|
||||
}
|
||||
|
2043
package/mtk/drivers/conninfra/src/platform/mt7986/mt7986_pos.c
Normal file
2043
package/mtk/drivers/conninfra/src/platform/mt7986/mt7986_pos.c
Normal file
File diff suppressed because it is too large
Load Diff
145
package/mtk/drivers/conninfra/src/platform/pmic_mng.c
Normal file
145
package/mtk/drivers/conninfra/src/platform/pmic_mng.c
Normal file
@ -0,0 +1,145 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#include "consys_hw.h"
|
||||
#include "pmic_mng.h"
|
||||
#include "osal.h"
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
const struct consys_platform_pmic_ops* consys_platform_pmic_ops = NULL;
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
int pmic_mng_init(
|
||||
struct platform_device *pdev,
|
||||
struct conninfra_dev_cb* dev_cb,
|
||||
const struct conninfra_plat_data* plat_data)
|
||||
{
|
||||
if (consys_platform_pmic_ops == NULL) {
|
||||
consys_platform_pmic_ops = (const struct consys_platform_pmic_ops*)plat_data->platform_pmic_ops;
|
||||
}
|
||||
|
||||
if (consys_platform_pmic_ops && consys_platform_pmic_ops->consys_pmic_get_from_dts)
|
||||
consys_platform_pmic_ops->consys_pmic_get_from_dts(pdev, dev_cb);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int pmic_mng_deinit(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
int pmic_mng_common_power_ctrl(unsigned int enable)
|
||||
{
|
||||
int ret = 0;
|
||||
|
||||
if (consys_platform_pmic_ops &&
|
||||
consys_platform_pmic_ops->consys_pmic_common_power_ctrl)
|
||||
ret = consys_platform_pmic_ops->consys_pmic_common_power_ctrl(enable);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int pmic_mng_wifi_power_ctrl(unsigned int enable)
|
||||
{
|
||||
int ret = 0;
|
||||
if (consys_platform_pmic_ops &&
|
||||
consys_platform_pmic_ops->consys_pmic_wifi_power_ctrl)
|
||||
ret = consys_platform_pmic_ops->consys_pmic_wifi_power_ctrl(enable);
|
||||
return ret;
|
||||
|
||||
}
|
||||
|
||||
int pmic_mng_bt_power_ctrl(unsigned int enable)
|
||||
{
|
||||
int ret = 0;
|
||||
if (consys_platform_pmic_ops &&
|
||||
consys_platform_pmic_ops->consys_pmic_bt_power_ctrl)
|
||||
ret = consys_platform_pmic_ops->consys_pmic_bt_power_ctrl(enable);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int pmic_mng_gps_power_ctrl(unsigned int enable)
|
||||
{
|
||||
int ret = 0;
|
||||
if (consys_platform_pmic_ops &&
|
||||
consys_platform_pmic_ops->consys_pmic_gps_power_ctrl)
|
||||
ret = consys_platform_pmic_ops->consys_pmic_gps_power_ctrl(enable);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int pmic_mng_fm_power_ctrl(unsigned int enable)
|
||||
{
|
||||
int ret = 0;
|
||||
if (consys_platform_pmic_ops &&
|
||||
consys_platform_pmic_ops->consys_pmic_fm_power_ctrl)
|
||||
ret = consys_platform_pmic_ops->consys_pmic_fm_power_ctrl(enable);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
int pmic_mng_event_cb(unsigned int id, unsigned int event)
|
||||
{
|
||||
if (consys_platform_pmic_ops &&
|
||||
consys_platform_pmic_ops->consys_pmic_event_notifier)
|
||||
consys_platform_pmic_ops->consys_pmic_event_notifier(id, event);
|
||||
return 0;
|
||||
}
|
263
package/mtk/drivers/conninfra/src/src/conninfra.c
Normal file
263
package/mtk/drivers/conninfra/src/src/conninfra.c
Normal file
@ -0,0 +1,263 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#define pr_fmt(fmt) KBUILD_MODNAME "@(%s:%d) " fmt, __func__, __LINE__
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/cdev.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/fb.h>
|
||||
#include <linux/workqueue.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/ratelimit.h>
|
||||
#include "conninfra.h"
|
||||
#include "emi_mng.h"
|
||||
#include "conninfra_core.h"
|
||||
#include "consys_hw.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define CONNINFRA_RST_RATE_LIMIT 0
|
||||
|
||||
#if CONNINFRA_RST_RATE_LIMIT
|
||||
DEFINE_RATELIMIT_STATE(g_rs, HZ, 1);
|
||||
|
||||
#define DUMP_LOG() if (__ratelimit(&g_rs)) \
|
||||
pr_info("rst is ongoing\n")
|
||||
|
||||
#else
|
||||
#define DUMP_LOG()
|
||||
#endif
|
||||
|
||||
struct conninfra_rst_data {
|
||||
enum consys_drv_type drv;
|
||||
char *reason;
|
||||
};
|
||||
|
||||
struct conninfra_rst_data rst_data;
|
||||
|
||||
void conninfra_get_emi_phy_addr(enum connsys_emi_type type, phys_addr_t* base, unsigned int *size)
|
||||
{
|
||||
struct consys_emi_addr_info* addr_info = emi_mng_get_phy_addr();
|
||||
|
||||
switch (type) {
|
||||
case CONNSYS_EMI_FW:
|
||||
if (base)
|
||||
*base = addr_info->emi_ap_phy_base;
|
||||
|
||||
if (size)
|
||||
*size = addr_info->fw_emi_size;
|
||||
break;
|
||||
|
||||
default:
|
||||
pr_err("Wrong EMI type: %d\n", type);
|
||||
if (base)
|
||||
*base = 0x0;
|
||||
|
||||
if (size)
|
||||
*size = 0;
|
||||
break;
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_get_emi_phy_addr);
|
||||
|
||||
int conninfra_pwr_on(enum consys_drv_type drv_type)
|
||||
{
|
||||
pr_info("[%s] drv=[%d]\n", __func__, drv_type);
|
||||
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
|
||||
return conninfra_core_power_on(drv_type);
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_pwr_on);
|
||||
|
||||
int conninfra_pwr_off(enum consys_drv_type drv_type)
|
||||
{
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
|
||||
return conninfra_core_power_off(drv_type);
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_pwr_off);
|
||||
|
||||
int conninfra_is_bus_hang(void)
|
||||
{
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
return conninfra_core_is_bus_hang();
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_is_bus_hang);
|
||||
|
||||
int conninfra_trigger_whole_chip_rst(enum consys_drv_type who, char *reason)
|
||||
{
|
||||
/* use schedule worker to trigger ??? */
|
||||
/* so that function can be returned immediately */
|
||||
int r;
|
||||
|
||||
r = conninfra_core_lock_rst();
|
||||
if (r >= CHIP_RST_START) {
|
||||
/* reset is ongoing */
|
||||
pr_warn("r=[%d] chip rst is ongoing\n", r);
|
||||
return 1;
|
||||
}
|
||||
pr_info("rst lock [%d] [%d] reason=%s\n", r, who, reason);
|
||||
|
||||
conninfra_core_trg_chip_rst(who, reason);
|
||||
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_trigger_whole_chip_rst);
|
||||
|
||||
int conninfra_sub_drv_ops_register(enum consys_drv_type type,
|
||||
struct sub_drv_ops_cb *cb)
|
||||
{
|
||||
/* type validation */
|
||||
if (type < 0 || type >= CONNDRV_TYPE_MAX) {
|
||||
pr_err("incorrect drv type [%d]\n", type);
|
||||
return -EINVAL;
|
||||
}
|
||||
pr_info("----\n");
|
||||
conninfra_core_subsys_ops_reg(type, cb);
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_sub_drv_ops_register);
|
||||
|
||||
int conninfra_sub_drv_ops_unregister(enum consys_drv_type type)
|
||||
{
|
||||
/* type validation */
|
||||
if (type < 0 || type >= CONNDRV_TYPE_MAX) {
|
||||
pr_err("[%s] incorrect drv type [%d]\n", __func__, type);
|
||||
return -EINVAL;
|
||||
}
|
||||
pr_info("----\n");
|
||||
conninfra_core_subsys_ops_unreg(type);
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_sub_drv_ops_unregister);
|
||||
|
||||
int conninfra_spi_read(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int *data)
|
||||
{
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
if (subsystem >= SYS_SPI_MAX) {
|
||||
pr_err("wrong subsys %d\n", subsystem);
|
||||
return -EINVAL;
|
||||
}
|
||||
conninfra_core_spi_read(subsystem, addr, data);
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_spi_read);
|
||||
|
||||
int conninfra_spi_write(enum sys_spi_subsystem subsystem, unsigned int addr, unsigned int data)
|
||||
{
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
|
||||
if (subsystem >= SYS_SPI_MAX) {
|
||||
pr_err("wrong subsys %d\n", subsystem);
|
||||
return -EINVAL;
|
||||
}
|
||||
conninfra_core_spi_write(subsystem, addr, data);
|
||||
return 0;
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_spi_write);
|
||||
|
||||
int conninfra_adie_top_ck_en_on(enum consys_drv_type type)
|
||||
{
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
|
||||
return conninfra_core_adie_top_ck_en_on(type);
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_adie_top_ck_en_on);
|
||||
|
||||
int conninfra_adie_top_ck_en_off(enum consys_drv_type type)
|
||||
{
|
||||
if (conninfra_core_is_rst_locking()) {
|
||||
DUMP_LOG();
|
||||
return CONNINFRA_ERR_RST_ONGOING;
|
||||
}
|
||||
|
||||
return conninfra_core_adie_top_ck_en_off(type);
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_adie_top_ck_en_off);
|
||||
|
||||
int conninfra_spi_clock_switch(enum connsys_spi_speed_type type)
|
||||
{
|
||||
return conninfra_core_spi_clock_switch(type);
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_spi_clock_switch);
|
||||
|
||||
int conninfra_debug_dump(void)
|
||||
{
|
||||
return conninfra_core_debug_dump();
|
||||
|
||||
}
|
||||
EXPORT_SYMBOL(conninfra_debug_dump);
|
344
package/mtk/drivers/conninfra/src/src/conninfra_dev.c
Normal file
344
package/mtk/drivers/conninfra/src/src/conninfra_dev.c
Normal file
@ -0,0 +1,344 @@
|
||||
/*
|
||||
* Copyright (C) 2016 MediaTek Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
|
||||
*/
|
||||
/*! \file
|
||||
* \brief Declaration of library functions
|
||||
*
|
||||
* Any definitions in this file will be shared among GLUE Layer and internal Driver Stack.
|
||||
*/
|
||||
|
||||
#include <linux/cdev.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/fb.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/workqueue.h>
|
||||
#include "conninfra.h"
|
||||
#include "conninfra_core.h"
|
||||
#include "consys_hw.h"
|
||||
#include "emi_mng.h"
|
||||
|
||||
/*******************************************************************************
|
||||
* C O M P I L E R F L A G S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* M A C R O S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
#define CONNINFRA_DEV_MAJOR 164
|
||||
#define CONNINFRA_DEV_NUM 1
|
||||
#define CONNINFRA_DRVIER_NAME "conninfra_drv"
|
||||
#define CONNINFRA_DEVICE_NAME "conninfra_dev"
|
||||
|
||||
#define CONNINFRA_DEV_IOC_MAGIC 0xc2
|
||||
#define CONNINFRA_IOCTL_GET_CHIP_ID _IOR(CONNINFRA_DEV_IOC_MAGIC, 0, int)
|
||||
|
||||
#define CONNINFRA_DEV_INIT_TO_MS (2 * 1000)
|
||||
|
||||
/*******************************************************************************
|
||||
* E X T E R N A L R E F E R E N C E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* C O N S T A N T S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
enum conninfra_init_status {
|
||||
CONNINFRA_INIT_NOT_START,
|
||||
CONNINFRA_INIT_START,
|
||||
CONNINFRA_INIT_DONE,
|
||||
};
|
||||
static int g_conninfra_init_status = CONNINFRA_INIT_NOT_START;
|
||||
static wait_queue_head_t g_conninfra_init_wq;
|
||||
|
||||
/*******************************************************************************
|
||||
* D A T A T Y P E S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N D E C L A R A T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
static int conninfra_dev_open(struct inode *inode, struct file *file);
|
||||
static int conninfra_dev_close(struct inode *inode, struct file *file);
|
||||
static ssize_t conninfra_dev_read(struct file *filp, char __user *buf,
|
||||
size_t count, loff_t *f_pos);
|
||||
static ssize_t conninfra_dev_write(struct file *filp,
|
||||
const char __user *buf, size_t count,
|
||||
loff_t *f_pos);
|
||||
static long conninfra_dev_unlocked_ioctl(
|
||||
struct file *filp, unsigned int cmd, unsigned long arg);
|
||||
#ifdef CONFIG_COMPAT
|
||||
static long conninfra_dev_compat_ioctl(
|
||||
struct file *filp, unsigned int cmd, unsigned long arg);
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
static int conninfra_dev_suspend_cb(void);
|
||||
static int conninfra_dev_resume_cb(void);
|
||||
static int conninfra_dev_pmic_event_cb(unsigned int, unsigned int);
|
||||
/*******************************************************************************
|
||||
* P U B L I C D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
/*******************************************************************************
|
||||
* P R I V A T E D A T A
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
struct class *pConninfraClass;
|
||||
struct device *pConninfraDev;
|
||||
static struct cdev gConninfraCdev;
|
||||
|
||||
const struct file_operations gConninfraDevFops = {
|
||||
.open = conninfra_dev_open,
|
||||
.release = conninfra_dev_close,
|
||||
.read = conninfra_dev_read,
|
||||
.write = conninfra_dev_write,
|
||||
.unlocked_ioctl = conninfra_dev_unlocked_ioctl,
|
||||
#ifdef CONFIG_COMPAT
|
||||
.compat_ioctl = conninfra_dev_compat_ioctl,
|
||||
#endif /* CONFIG_COMPAT */
|
||||
};
|
||||
|
||||
static int gConnInfraMajor = CONNINFRA_DEV_MAJOR;
|
||||
|
||||
/* screen on/off notification */
|
||||
|
||||
static struct conninfra_dev_cb gConninfraDevCb = {
|
||||
.conninfra_suspend_cb = conninfra_dev_suspend_cb,
|
||||
.conninfra_resume_cb = conninfra_dev_resume_cb,
|
||||
.conninfra_pmic_event_notifier = conninfra_dev_pmic_event_cb,
|
||||
};
|
||||
|
||||
/*******************************************************************************
|
||||
* F U N C T I O N S
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
int conninfra_dev_open(struct inode *inode, struct file *file)
|
||||
{
|
||||
static DEFINE_RATELIMIT_STATE(_rs, HZ, 1);
|
||||
|
||||
if (!wait_event_timeout(g_conninfra_init_wq, g_conninfra_init_status == CONNINFRA_INIT_DONE,
|
||||
msecs_to_jiffies(CONNINFRA_DEV_INIT_TO_MS))) {
|
||||
if (__ratelimit(&_rs)) {
|
||||
pr_warn("wait_event_timeout (%d)ms,(%lu)jiffies,return -EIO\n",
|
||||
CONNINFRA_DEV_INIT_TO_MS, msecs_to_jiffies(CONNINFRA_DEV_INIT_TO_MS));
|
||||
}
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
pr_info("open major %d minor %d (pid %d)\n",
|
||||
imajor(inode), iminor(inode), current->pid);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int conninfra_dev_close(struct inode *inode, struct file *file)
|
||||
{
|
||||
pr_info("close major %d minor %d (pid %d)\n",
|
||||
imajor(inode), iminor(inode), current->pid);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
ssize_t conninfra_dev_read(struct file *filp, char __user *buf,
|
||||
size_t count, loff_t *f_pos)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
ssize_t conninfra_dev_write(struct file *filp,
|
||||
const char __user *buf, size_t count, loff_t *f_pos)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
static long conninfra_dev_unlocked_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
|
||||
{
|
||||
int retval = 0;
|
||||
|
||||
pr_info("[%s] cmd (%d),arg(%ld)\n", __func__, cmd, arg);
|
||||
switch (cmd) {
|
||||
case CONNINFRA_IOCTL_GET_CHIP_ID:
|
||||
retval = consys_hw_chipid_get();
|
||||
break;
|
||||
}
|
||||
return retval;
|
||||
|
||||
}
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
static long conninfra_dev_compat_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
|
||||
{
|
||||
long ret;
|
||||
|
||||
pr_info("[%s] cmd (%d)\n", __func__, cmd);
|
||||
ret = conninfra_dev_unlocked_ioctl(filp, cmd, arg);
|
||||
return ret;
|
||||
}
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
static int conninfra_dev_suspend_cb(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int conninfra_dev_resume_cb(void)
|
||||
{
|
||||
conninfra_core_dump_power_state();
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int conninfra_dev_pmic_event_cb(unsigned int id, unsigned int event)
|
||||
{
|
||||
conninfra_core_pmic_event_cb(id, event);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/************************************************************************/
|
||||
|
||||
static int conninfra_dev_init(void)
|
||||
{
|
||||
dev_t devID = MKDEV(gConnInfraMajor, 0);
|
||||
int cdevErr = -1;
|
||||
int iret = 0;
|
||||
|
||||
g_conninfra_init_status = CONNINFRA_INIT_START;
|
||||
init_waitqueue_head((wait_queue_head_t *)&g_conninfra_init_wq);
|
||||
|
||||
iret = register_chrdev_region(devID, CONNINFRA_DEV_NUM, CONNINFRA_DRVIER_NAME);
|
||||
if (iret) {
|
||||
pr_err("fail to register chrdev\n");
|
||||
g_conninfra_init_status = CONNINFRA_INIT_NOT_START;
|
||||
return -1;
|
||||
}
|
||||
|
||||
cdev_init(&gConninfraCdev, &gConninfraDevFops);
|
||||
gConninfraCdev.owner = THIS_MODULE;
|
||||
|
||||
cdevErr = cdev_add(&gConninfraCdev, devID, CONNINFRA_DEV_NUM);
|
||||
if (cdevErr) {
|
||||
pr_err("cdev_add() fails (%d)\n", cdevErr);
|
||||
goto err1;
|
||||
}
|
||||
|
||||
pConninfraClass = class_create(THIS_MODULE, CONNINFRA_DEVICE_NAME);
|
||||
if (IS_ERR(pConninfraClass)) {
|
||||
pr_err("class create fail, error code(%ld)\n", PTR_ERR(pConninfraClass));
|
||||
goto err1;
|
||||
}
|
||||
|
||||
pConninfraDev = device_create(pConninfraClass, NULL, devID, NULL, CONNINFRA_DEVICE_NAME);
|
||||
if (IS_ERR(pConninfraDev)) {
|
||||
pr_err("device create fail, error code(%ld)\n", PTR_ERR(pConninfraDev));
|
||||
goto err2;
|
||||
}
|
||||
|
||||
iret = mtk_conninfra_drv_init(&gConninfraDevCb);
|
||||
if (iret) {
|
||||
pr_err("init consys_hw fail, ret = %d\n", iret);
|
||||
g_conninfra_init_status = CONNINFRA_INIT_NOT_START;
|
||||
return -2;
|
||||
}
|
||||
|
||||
iret = conninfra_core_init();
|
||||
if (iret) {
|
||||
pr_err("conninfra init fail\n");
|
||||
g_conninfra_init_status = CONNINFRA_INIT_NOT_START;
|
||||
return -3;
|
||||
}
|
||||
|
||||
pr_info("ConnInfra Dev: init (%d)\n", iret);
|
||||
g_conninfra_init_status = CONNINFRA_INIT_DONE;
|
||||
|
||||
#ifdef CONFIG_CONNINFRA_AUTO_UP
|
||||
iret = conninfra_core_power_on(CONNDRV_TYPE_CONNINFRA);
|
||||
if (iret) {
|
||||
pr_err("conninfra auto load power on fail\n");
|
||||
return -4;
|
||||
}
|
||||
#endif /* CONFIG_CONNINFRA_AUTO_UP */
|
||||
|
||||
return 0;
|
||||
|
||||
err2:
|
||||
|
||||
pr_err("[conninfra_dev_init] err2\n");
|
||||
if (pConninfraClass) {
|
||||
class_destroy(pConninfraClass);
|
||||
pConninfraClass = NULL;
|
||||
}
|
||||
err1:
|
||||
pr_err("[conninfra_dev_init] err1\n");
|
||||
if (cdevErr == 0)
|
||||
cdev_del(&gConninfraCdev);
|
||||
|
||||
if (iret == 0) {
|
||||
unregister_chrdev_region(devID, CONNINFRA_DEV_NUM);
|
||||
gConnInfraMajor = -1;
|
||||
}
|
||||
|
||||
g_conninfra_init_status = CONNINFRA_INIT_NOT_START;
|
||||
return -2;
|
||||
}
|
||||
|
||||
static void conninfra_dev_deinit(void)
|
||||
{
|
||||
dev_t dev = MKDEV(gConnInfraMajor, 0);
|
||||
int iret = 0;
|
||||
|
||||
#ifdef CONFIG_CONNINFRA_AUTO_UP
|
||||
iret = conninfra_core_power_off(CONNDRV_TYPE_CONNINFRA);
|
||||
if (iret) {
|
||||
pr_err("conninfra auto load power off fail\n");
|
||||
}
|
||||
#endif /* CONFIG_CONNINFRA_AUTO_UP */
|
||||
|
||||
g_conninfra_init_status = CONNINFRA_INIT_NOT_START;
|
||||
|
||||
iret = conninfra_core_deinit();
|
||||
|
||||
iret = mtk_conninfra_drv_deinit();
|
||||
|
||||
if (pConninfraDev) {
|
||||
device_destroy(pConninfraClass, dev);
|
||||
pConninfraDev = NULL;
|
||||
}
|
||||
|
||||
if (pConninfraClass) {
|
||||
class_destroy(pConninfraClass);
|
||||
pConninfraClass = NULL;
|
||||
}
|
||||
|
||||
cdev_del(&gConninfraCdev);
|
||||
unregister_chrdev_region(dev, CONNINFRA_DEV_NUM);
|
||||
|
||||
pr_info("ConnInfra: platform init (%d)\n", iret);
|
||||
}
|
||||
|
||||
module_init(conninfra_dev_init);
|
||||
module_exit(conninfra_dev_deinit);
|
||||
|
||||
MODULE_LICENSE("GPL");
|
||||
MODULE_AUTHOR("Willy.Yu @ CTD/SE5/CS5");
|
||||
|
||||
module_param(gConnInfraMajor, uint, 0644);
|
||||
|
Loading…
x
Reference in New Issue
Block a user