diff mbox

[v6] arm/arm64: add arm-smccc

Message ID 1449667495-23091-1-git-send-email-jens.wiklander@linaro.org (mailing list archive)
State New, archived
Headers show

Commit Message

Jens Wiklander Dec. 9, 2015, 1:24 p.m. UTC
Adds helpers to do SMC and HVC based on ARM SMC Calling Convention.
CONFIG_HAVE_ARM_SMCCC is enabled for architectures that may support the
SMC or HVC instruction. It's the responsibility of the caller to know if
the SMC instruction is supported by the platform.

This patch doesn't provide an implementation of the declared functions.
Later patches will bring in implementations and set
CONFIG_HAVE_ARM_SMCCC for ARM and ARM64 respectively.

Signed-off-by: Jens Wiklander <jens.wiklander@linaro.org>
---

v6:
* Move HAVE_ARM_SMCCC from init/Kconfig

 arch/Kconfig              |  3 ++
 include/linux/arm-smccc.h | 98 +++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 101 insertions(+)
 create mode 100644 include/linux/arm-smccc.h

Comments

Lorenzo Pieralisi Dec. 21, 2015, 11:14 a.m. UTC | #1
On Wed, Dec 09, 2015 at 02:24:55PM +0100, Jens Wiklander wrote:
> Adds helpers to do SMC and HVC based on ARM SMC Calling Convention.
> CONFIG_HAVE_ARM_SMCCC is enabled for architectures that may support the
> SMC or HVC instruction. It's the responsibility of the caller to know if
> the SMC instruction is supported by the platform.
> 
> This patch doesn't provide an implementation of the declared functions.
> Later patches will bring in implementations and set
> CONFIG_HAVE_ARM_SMCCC for ARM and ARM64 respectively.
> 
> Signed-off-by: Jens Wiklander <jens.wiklander@linaro.org>
> ---
> 
> v6:
> * Move HAVE_ARM_SMCCC from init/Kconfig
> 
>  arch/Kconfig              |  3 ++
>  include/linux/arm-smccc.h | 98 +++++++++++++++++++++++++++++++++++++++++++++++
>  2 files changed, 101 insertions(+)
>  create mode 100644 include/linux/arm-smccc.h
> 
> diff --git a/arch/Kconfig b/arch/Kconfig
> index 4e949e5..ce3c0b0 100644
> --- a/arch/Kconfig
> +++ b/arch/Kconfig
> @@ -564,4 +564,7 @@ config OLD_SIGACTION
>  config COMPAT_OLD_SIGACTION
>  	bool
>  
> +config HAVE_ARM_SMCCC
> +	bool

It is ok by me to move it there, probably we do not want it at the end of
the "ABI hall of shame" list :)

Or drivers/firmware/Kconfig ?

Strictly speaking, since PSCI uses this by default, you should also
enforce an ARM_PSCI_FW dependency on HAVE_ARM_SMCCC.

>  source "kernel/gcov/Kconfig"
> diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h
> new file mode 100644
> index 0000000..dea68a9
> --- /dev/null
> +++ b/include/linux/arm-smccc.h
> @@ -0,0 +1,98 @@
> +/*
> + * Copyright (c) 2015, Linaro Limited
> + *
> + * This software is licensed under the terms of the GNU General Public
> + * License version 2, as published by the Free Software Foundation, and
> + * may be copied, distributed, and modified under those terms.
> + *
> + * 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 the
> + * GNU General Public License for more details.
> + *
> + */
> +#ifndef __LINUX_ARM_SMCCC_H
> +#define __LINUX_ARM_SMCCC_H
> +
> +#include <linux/types.h>
> +#include <linux/linkage.h>

Nit: alphabetical order please.

> +
> +/*
> + * This file provides common defines for ARM SMC Calling Convention as
> + * specified in
> + * http://infocenter.arm.com/help/topic/com.arm.doc.den0028a/index.html
> + */
> +
> +#define ARM_SMCCC_SMC_32		(0 << 30)
> +#define ARM_SMCCC_SMC_64		(1 << 30)
> +#define ARM_SMCCC_FAST_CALL		(1 << 31)
> +#define ARM_SMCCC_STD_CALL		(0 << 31)
> +
> +#define ARM_SMCCC_OWNER_MASK		0x3F
> +#define ARM_SMCCC_OWNER_SHIFT		24
> +
> +#define ARM_SMCCC_FUNC_MASK		0xFFFF
> +
> +#define ARM_SMCCC_IS_FAST_CALL(smc_val)	((smc_val) & ARM_SMCCC_FAST_CALL)
> +#define ARM_SMCCC_IS_64(smc_val)	((smc_val) & ARM_SMCCC_SMC_64)
> +#define ARM_SMCCC_FUNC_NUM(smc_val)	((smc_val) & ARM_SMCCC_FUNC_MASK)
> +#define ARM_SMCCC_OWNER_NUM(smc_val) \
> +	(((smc_val) >> ARM_SMCCC_OWNER_SHIFT) & ARM_SMCCC_OWNER_MASK)
> +
> +#define ARM_SMCCC_CALL_VAL(type, calling_convention, owner, func_num) \
> +	((type) | (calling_convention) | \

Nit: if you use a shift macro for some fields it would be clearer if you use
for all of them (I am referring to type/calling_convention here), it can
be changed later.

Other than that:

Reviewed-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>

> +	(((owner) & ARM_SMCCC_OWNER_MASK) << ARM_SMCCC_OWNER_SHIFT) | \
> +	((func_num) & ARM_SMCCC_FUNC_MASK))
> +
> +#define ARM_SMCCC_OWNER_ARCH		0
> +#define ARM_SMCCC_OWNER_CPU		1
> +#define ARM_SMCCC_OWNER_SIP		2
> +#define ARM_SMCCC_OWNER_OEM		3
> +#define ARM_SMCCC_OWNER_STANDARD	4
> +#define ARM_SMCCC_OWNER_TRUSTED_APP	48
> +#define ARM_SMCCC_OWNER_TRUSTED_APP_END	49
> +#define ARM_SMCCC_OWNER_TRUSTED_OS	50
> +#define ARM_SMCCC_OWNER_TRUSTED_OS_END	63
> +
> +/**
> + * struct arm_smccc_res - Result from SMC/HVC call
> + * @a0-a3 result values from registers 0 to 3
> + */
> +struct arm_smccc_res {
> +	unsigned long a0;
> +	unsigned long a1;
> +	unsigned long a2;
> +	unsigned long a3;
> +};
> +
> +/**
> + * arm_smccc_smc() - make SMC calls
> + * @a0-a7: arguments passed in registers 0 to 7
> + * @res: result values from registers 0 to 3
> + *
> + * This function is used to make SMC calls following SMC Calling Convention.
> + * The content of the supplied param are copied to registers 0 to 7 prior
> + * to the SMC instruction. The return values are updated with the content
> + * from register 0 to 3 on return from the SMC instruction.
> + */
> +asmlinkage void arm_smccc_smc(unsigned long a0, unsigned long a1,
> +			unsigned long a2, unsigned long a3, unsigned long a4,
> +			unsigned long a5, unsigned long a6, unsigned long a7,
> +			struct arm_smccc_res *res);
> +
> +/**
> + * arm_smccc_hvc() - make HVC calls
> + * @a0-a7: arguments passed in registers 0 to 7
> + * @res: result values from registers 0 to 3
> + *
> + * This function is used to make HVC calls following SMC Calling
> + * Convention.  The content of the supplied param are copied to registers 0
> + * to 7 prior to the HVC instruction. The return values are updated with
> + * the content from register 0 to 3 on return from the HVC instruction.
> + */
> +asmlinkage void arm_smccc_hvc(unsigned long a0, unsigned long a1,
> +			unsigned long a2, unsigned long a3, unsigned long a4,
> +			unsigned long a5, unsigned long a6, unsigned long a7,
> +			struct arm_smccc_res *res);
> +
> +#endif /*__LINUX_ARM_SMCCC_H*/
> -- 
> 1.9.1
>
Jens Wiklander Dec. 22, 2015, 9:46 a.m. UTC | #2
On Mon, Dec 21, 2015 at 11:14:55AM +0000, Lorenzo Pieralisi wrote:
> On Wed, Dec 09, 2015 at 02:24:55PM +0100, Jens Wiklander wrote:
> > Adds helpers to do SMC and HVC based on ARM SMC Calling Convention.
> > CONFIG_HAVE_ARM_SMCCC is enabled for architectures that may support the
> > SMC or HVC instruction. It's the responsibility of the caller to know if
> > the SMC instruction is supported by the platform.
> > 
> > This patch doesn't provide an implementation of the declared functions.
> > Later patches will bring in implementations and set
> > CONFIG_HAVE_ARM_SMCCC for ARM and ARM64 respectively.
> > 
> > Signed-off-by: Jens Wiklander <jens.wiklander@linaro.org>
> > ---
> > 
> > v6:
> > * Move HAVE_ARM_SMCCC from init/Kconfig
> > 
> >  arch/Kconfig              |  3 ++
> >  include/linux/arm-smccc.h | 98 +++++++++++++++++++++++++++++++++++++++++++++++
> >  2 files changed, 101 insertions(+)
> >  create mode 100644 include/linux/arm-smccc.h
> > 
> > diff --git a/arch/Kconfig b/arch/Kconfig
> > index 4e949e5..ce3c0b0 100644
> > --- a/arch/Kconfig
> > +++ b/arch/Kconfig
> > @@ -564,4 +564,7 @@ config OLD_SIGACTION
> >  config COMPAT_OLD_SIGACTION
> >  	bool
> >  
> > +config HAVE_ARM_SMCCC
> > +	bool
> 
> It is ok by me to move it there, probably we do not want it at the end of
> the "ABI hall of shame" list :)
> 
> Or drivers/firmware/Kconfig ?

You tell me, I'm too new here to have a feeling for this.

> 
> Strictly speaking, since PSCI uses this by default, you should also
> enforce an ARM_PSCI_FW dependency on HAVE_ARM_SMCCC.

ARM_PSCI depends on CPU_V7 and ARM_PSCI_FW doesn't really depend on
anything today.

Would it be OK if I changed ARM_PSCI to depend on HAVE_ARM_SMCCC instead
of CPU_V7 in the "drivers: psci: replace psci firmware calls" patch?
At the same time I would move the "select HAVE_ARM_SMCCC if CPU_V7" line
to the "config ARM" block instead in the
"arm: add implementation for arm-smccc" patch.

I'll include this change in the v7 patch set if I don't hear anything.

> 
> >  source "kernel/gcov/Kconfig"
> > diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h
> > new file mode 100644
> > index 0000000..dea68a9
> > --- /dev/null
> > +++ b/include/linux/arm-smccc.h
> > @@ -0,0 +1,98 @@
> > +/*
> > + * Copyright (c) 2015, Linaro Limited
> > + *
> > + * This software is licensed under the terms of the GNU General Public
> > + * License version 2, as published by the Free Software Foundation, and
> > + * may be copied, distributed, and modified under those terms.
> > + *
> > + * 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 the
> > + * GNU General Public License for more details.
> > + *
> > + */
> > +#ifndef __LINUX_ARM_SMCCC_H
> > +#define __LINUX_ARM_SMCCC_H
> > +
> > +#include <linux/types.h>
> > +#include <linux/linkage.h>
> 
> Nit: alphabetical order please.
> 
> > +
> > +/*
> > + * This file provides common defines for ARM SMC Calling Convention as
> > + * specified in
> > + * http://infocenter.arm.com/help/topic/com.arm.doc.den0028a/index.html
> > + */
> > +
> > +#define ARM_SMCCC_SMC_32		(0 << 30)
> > +#define ARM_SMCCC_SMC_64		(1 << 30)
> > +#define ARM_SMCCC_FAST_CALL		(1 << 31)
> > +#define ARM_SMCCC_STD_CALL		(0 << 31)
> > +
> > +#define ARM_SMCCC_OWNER_MASK		0x3F
> > +#define ARM_SMCCC_OWNER_SHIFT		24
> > +
> > +#define ARM_SMCCC_FUNC_MASK		0xFFFF
> > +
> > +#define ARM_SMCCC_IS_FAST_CALL(smc_val)	((smc_val) & ARM_SMCCC_FAST_CALL)
> > +#define ARM_SMCCC_IS_64(smc_val)	((smc_val) & ARM_SMCCC_SMC_64)
> > +#define ARM_SMCCC_FUNC_NUM(smc_val)	((smc_val) & ARM_SMCCC_FUNC_MASK)
> > +#define ARM_SMCCC_OWNER_NUM(smc_val) \
> > +	(((smc_val) >> ARM_SMCCC_OWNER_SHIFT) & ARM_SMCCC_OWNER_MASK)
> > +
> > +#define ARM_SMCCC_CALL_VAL(type, calling_convention, owner, func_num) \
> > +	((type) | (calling_convention) | \
> 
> Nit: if you use a shift macro for some fields it would be clearer if you use
> for all of them (I am referring to type/calling_convention here), it can
> be changed later.
> 
> Other than that:
> 
> Reviewed-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>

Thanks for the review.
--
Jens
Russell King - ARM Linux Dec. 22, 2015, 12:14 p.m. UTC | #3
On Tue, Dec 22, 2015 at 10:46:08AM +0100, Jens Wiklander wrote:
> On Mon, Dec 21, 2015 at 11:14:55AM +0000, Lorenzo Pieralisi wrote:
> > On Wed, Dec 09, 2015 at 02:24:55PM +0100, Jens Wiklander wrote:
> > > diff --git a/arch/Kconfig b/arch/Kconfig
> > > index 4e949e5..ce3c0b0 100644
> > > --- a/arch/Kconfig
> > > +++ b/arch/Kconfig
> > > @@ -564,4 +564,7 @@ config OLD_SIGACTION
> > >  config COMPAT_OLD_SIGACTION
> > >  	bool
> > >  
> > > +config HAVE_ARM_SMCCC
> > > +	bool
> > 
> > It is ok by me to move it there, probably we do not want it at the end of
> > the "ABI hall of shame" list :)
> > 
> > Or drivers/firmware/Kconfig ?
> 
> You tell me, I'm too new here to have a feeling for this.
> 
> > 
> > Strictly speaking, since PSCI uses this by default, you should also
> > enforce an ARM_PSCI_FW dependency on HAVE_ARM_SMCCC.
> 
> ARM_PSCI depends on CPU_V7 and ARM_PSCI_FW doesn't really depend on
> anything today.
> 
> Would it be OK if I changed ARM_PSCI to depend on HAVE_ARM_SMCCC instead
> of CPU_V7 in the "drivers: psci: replace psci firmware calls" patch?
> At the same time I would move the "select HAVE_ARM_SMCCC if CPU_V7" line
> to the "config ARM" block instead in the
> "arm: add implementation for arm-smccc" patch.
> 
> I'll include this change in the v7 patch set if I don't hear anything.

Okay, I think as we don't have a decision on this, the proximity of
Christmas, and the presumable opening of the merge window early in
the new year, I can't merge these patches for the upcoming window.
I'll discard those which have already been submitted to the patch
system.

This also has a knock-on effect on patch 8486/1:

"ARM64: kernel: PSCI: move PSCI idle management code to drivers/firmware"

which is based on top of this series.  If someone wants to replace
that patch with one which has been tested _without_ this series
then I'll look at applying it, provided its only trivially different
from the existing one.

Thanks.
Lorenzo Pieralisi Jan. 4, 2016, 10:13 a.m. UTC | #4
Hi Russell,

On Tue, Dec 22, 2015 at 12:14:49PM +0000, Russell King - ARM Linux wrote:
> On Tue, Dec 22, 2015 at 10:46:08AM +0100, Jens Wiklander wrote:
> > On Mon, Dec 21, 2015 at 11:14:55AM +0000, Lorenzo Pieralisi wrote:
> > > On Wed, Dec 09, 2015 at 02:24:55PM +0100, Jens Wiklander wrote:
> > > > diff --git a/arch/Kconfig b/arch/Kconfig
> > > > index 4e949e5..ce3c0b0 100644
> > > > --- a/arch/Kconfig
> > > > +++ b/arch/Kconfig
> > > > @@ -564,4 +564,7 @@ config OLD_SIGACTION
> > > >  config COMPAT_OLD_SIGACTION
> > > >  	bool
> > > >  
> > > > +config HAVE_ARM_SMCCC
> > > > +	bool
> > > 
> > > It is ok by me to move it there, probably we do not want it at the end of
> > > the "ABI hall of shame" list :)
> > > 
> > > Or drivers/firmware/Kconfig ?
> > 
> > You tell me, I'm too new here to have a feeling for this.
> > 
> > > 
> > > Strictly speaking, since PSCI uses this by default, you should also
> > > enforce an ARM_PSCI_FW dependency on HAVE_ARM_SMCCC.
> > 
> > ARM_PSCI depends on CPU_V7 and ARM_PSCI_FW doesn't really depend on
> > anything today.
> > 
> > Would it be OK if I changed ARM_PSCI to depend on HAVE_ARM_SMCCC instead
> > of CPU_V7 in the "drivers: psci: replace psci firmware calls" patch?
> > At the same time I would move the "select HAVE_ARM_SMCCC if CPU_V7" line
> > to the "config ARM" block instead in the
> > "arm: add implementation for arm-smccc" patch.
> > 
> > I'll include this change in the v7 patch set if I don't hear anything.
> 
> Okay, I think as we don't have a decision on this, the proximity of
> Christmas, and the presumable opening of the merge window early in
> the new year, I can't merge these patches for the upcoming window.
> I'll discard those which have already been submitted to the patch
> system.
> 
> This also has a knock-on effect on patch 8486/1:
> 
> "ARM64: kernel: PSCI: move PSCI idle management code to drivers/firmware"
> 
> which is based on top of this series.  If someone wants to replace
> that patch with one which has been tested _without_ this series
> then I'll look at applying it, provided its only trivially different
> from the existing one.

I guess Jens' patches are not considered material for the upcoming merge
window, would you consider applying an updated version of 8486/1 (that does
not depend on Jens' series) or it is too late ? That patch has already
missed a merge window for patch dependencies, I would avoid another one,
I appreciate the timing is not ideal though, please let me know.

Thanks !
Lorenzo
Russell King - ARM Linux Jan. 4, 2016, 11:11 a.m. UTC | #5
On Mon, Jan 04, 2016 at 10:13:39AM +0000, Lorenzo Pieralisi wrote:
> Hi Russell,
> 
> On Tue, Dec 22, 2015 at 12:14:49PM +0000, Russell King - ARM Linux wrote:
> > Okay, I think as we don't have a decision on this, the proximity of
> > Christmas, and the presumable opening of the merge window early in
> > the new year, I can't merge these patches for the upcoming window.
> > I'll discard those which have already been submitted to the patch
> > system.
> > 
> > This also has a knock-on effect on patch 8486/1:
> > 
> > "ARM64: kernel: PSCI: move PSCI idle management code to drivers/firmware"
> > 
> > which is based on top of this series.  If someone wants to replace
> > that patch with one which has been tested _without_ this series
> > then I'll look at applying it, provided its only trivially different
> > from the existing one.
> 
> I guess Jens' patches are not considered material for the upcoming merge
> window, would you consider applying an updated version of 8486/1 (that does
> not depend on Jens' series) or it is too late ? That patch has already
> missed a merge window for patch dependencies, I would avoid another one,
> I appreciate the timing is not ideal though, please let me know.

The reason I said what I did above was to head-off the merge window
opening last night, and having a rushed job dealing with problems
with patches merged at the last minute.

Consider that the period 24th December to 3rd January does not exist
for many as far as working on the kernel is concerned, and linux-next
probably wasn't running over that period either.

The situation has changed though; last night, Linus released -rc8,
which means we have one week of breathing space before the merge window
is likely to open, and we have four days of linux-next trees.

This means that I'm willing to take patches today (and today only), as
it will give the remainder of the week (up to Thursday - due to the
linux-next timing) to sort out any deficiencies in those patches.
Russell King - ARM Linux Jan. 4, 2016, 11:16 a.m. UTC | #6
On Mon, Jan 04, 2016 at 11:11:02AM +0000, Russell King - ARM Linux wrote:
> The reason I said what I did above was to head-off the merge window
> opening last night, and having a rushed job dealing with problems
> with patches merged at the last minute.
> 
> Consider that the period 24th December to 3rd January does not exist
> for many as far as working on the kernel is concerned, and linux-next
> probably wasn't running over that period either.
> 
> The situation has changed though; last night, Linus released -rc8,
> which means we have one week of breathing space before the merge window
> is likely to open, and we have four days of linux-next trees.
> 
> This means that I'm willing to take patches today (and today only), as
> it will give the remainder of the week (up to Thursday - due to the
> linux-next timing) to sort out any deficiencies in those patches.

That all said, 8486/1 _is_ the patch you've just asked me to merge,
which has open questions from Jens that you (Lorenzo) have _not_
responded to.

Jens was asking, in response to your feedback, whether an alternative
Kconfig structure would satisfy your feedback... to which he's had no
reply from you.  So, we're waiting on your response.
Lorenzo Pieralisi Jan. 4, 2016, 12:14 p.m. UTC | #7
On Tue, Dec 22, 2015 at 10:46:08AM +0100, Jens Wiklander wrote:
> On Mon, Dec 21, 2015 at 11:14:55AM +0000, Lorenzo Pieralisi wrote:
> > On Wed, Dec 09, 2015 at 02:24:55PM +0100, Jens Wiklander wrote:
> > > Adds helpers to do SMC and HVC based on ARM SMC Calling Convention.
> > > CONFIG_HAVE_ARM_SMCCC is enabled for architectures that may support the
> > > SMC or HVC instruction. It's the responsibility of the caller to know if
> > > the SMC instruction is supported by the platform.
> > > 
> > > This patch doesn't provide an implementation of the declared functions.
> > > Later patches will bring in implementations and set
> > > CONFIG_HAVE_ARM_SMCCC for ARM and ARM64 respectively.
> > > 
> > > Signed-off-by: Jens Wiklander <jens.wiklander@linaro.org>
> > > ---
> > > 
> > > v6:
> > > * Move HAVE_ARM_SMCCC from init/Kconfig
> > > 
> > >  arch/Kconfig              |  3 ++
> > >  include/linux/arm-smccc.h | 98 +++++++++++++++++++++++++++++++++++++++++++++++
> > >  2 files changed, 101 insertions(+)
> > >  create mode 100644 include/linux/arm-smccc.h
> > > 
> > > diff --git a/arch/Kconfig b/arch/Kconfig
> > > index 4e949e5..ce3c0b0 100644
> > > --- a/arch/Kconfig
> > > +++ b/arch/Kconfig
> > > @@ -564,4 +564,7 @@ config OLD_SIGACTION
> > >  config COMPAT_OLD_SIGACTION
> > >  	bool
> > >  
> > > +config HAVE_ARM_SMCCC
> > > +	bool
> > 
> > It is ok by me to move it there, probably we do not want it at the end of
> > the "ABI hall of shame" list :)
> > 
> > Or drivers/firmware/Kconfig ?
> 
> You tell me, I'm too new here to have a feeling for this.
> 
> > 
> > Strictly speaking, since PSCI uses this by default, you should also
> > enforce an ARM_PSCI_FW dependency on HAVE_ARM_SMCCC.
> 
> ARM_PSCI depends on CPU_V7 and ARM_PSCI_FW doesn't really depend on
> anything today.
> 
> Would it be OK if I changed ARM_PSCI to depend on HAVE_ARM_SMCCC instead
> of CPU_V7 in the "drivers: psci: replace psci firmware calls" patch?
> At the same time I would move the "select HAVE_ARM_SMCCC if CPU_V7" line
> to the "config ARM" block instead in the
> "arm: add implementation for arm-smccc" patch.
> 
> I'll include this change in the v7 patch set if I don't hear anything.

Sorry for the delay in getting back to you.

Yes, I still think that HAVE_ARM_SMCCC should not be listed at the
end of "ABI hall of shame" in arch/Kconfig and you can move it to
drivers/firmware/Kconfig.

Other than that your v7 is fine by me, can you respin quickly and
ask Russell to pull today please ?

Thanks,
Lorenzo

> 
> > 
> > >  source "kernel/gcov/Kconfig"
> > > diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h
> > > new file mode 100644
> > > index 0000000..dea68a9
> > > --- /dev/null
> > > +++ b/include/linux/arm-smccc.h
> > > @@ -0,0 +1,98 @@
> > > +/*
> > > + * Copyright (c) 2015, Linaro Limited
> > > + *
> > > + * This software is licensed under the terms of the GNU General Public
> > > + * License version 2, as published by the Free Software Foundation, and
> > > + * may be copied, distributed, and modified under those terms.
> > > + *
> > > + * 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 the
> > > + * GNU General Public License for more details.
> > > + *
> > > + */
> > > +#ifndef __LINUX_ARM_SMCCC_H
> > > +#define __LINUX_ARM_SMCCC_H
> > > +
> > > +#include <linux/types.h>
> > > +#include <linux/linkage.h>
> > 
> > Nit: alphabetical order please.
> > 
> > > +
> > > +/*
> > > + * This file provides common defines for ARM SMC Calling Convention as
> > > + * specified in
> > > + * http://infocenter.arm.com/help/topic/com.arm.doc.den0028a/index.html
> > > + */
> > > +
> > > +#define ARM_SMCCC_SMC_32		(0 << 30)
> > > +#define ARM_SMCCC_SMC_64		(1 << 30)
> > > +#define ARM_SMCCC_FAST_CALL		(1 << 31)
> > > +#define ARM_SMCCC_STD_CALL		(0 << 31)
> > > +
> > > +#define ARM_SMCCC_OWNER_MASK		0x3F
> > > +#define ARM_SMCCC_OWNER_SHIFT		24
> > > +
> > > +#define ARM_SMCCC_FUNC_MASK		0xFFFF
> > > +
> > > +#define ARM_SMCCC_IS_FAST_CALL(smc_val)	((smc_val) & ARM_SMCCC_FAST_CALL)
> > > +#define ARM_SMCCC_IS_64(smc_val)	((smc_val) & ARM_SMCCC_SMC_64)
> > > +#define ARM_SMCCC_FUNC_NUM(smc_val)	((smc_val) & ARM_SMCCC_FUNC_MASK)
> > > +#define ARM_SMCCC_OWNER_NUM(smc_val) \
> > > +	(((smc_val) >> ARM_SMCCC_OWNER_SHIFT) & ARM_SMCCC_OWNER_MASK)
> > > +
> > > +#define ARM_SMCCC_CALL_VAL(type, calling_convention, owner, func_num) \
> > > +	((type) | (calling_convention) | \
> > 
> > Nit: if you use a shift macro for some fields it would be clearer if you use
> > for all of them (I am referring to type/calling_convention here), it can
> > be changed later.
> > 
> > Other than that:
> > 
> > Reviewed-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
> 
> Thanks for the review.
> --
> Jens
>
Lorenzo Pieralisi Jan. 4, 2016, 12:22 p.m. UTC | #8
On Mon, Jan 04, 2016 at 11:16:27AM +0000, Russell King - ARM Linux wrote:
> On Mon, Jan 04, 2016 at 11:11:02AM +0000, Russell King - ARM Linux wrote:
> > The reason I said what I did above was to head-off the merge window
> > opening last night, and having a rushed job dealing with problems
> > with patches merged at the last minute.
> > 
> > Consider that the period 24th December to 3rd January does not exist
> > for many as far as working on the kernel is concerned, and linux-next
> > probably wasn't running over that period either.
> > 
> > The situation has changed though; last night, Linus released -rc8,
> > which means we have one week of breathing space before the merge window
> > is likely to open, and we have four days of linux-next trees.
> > 
> > This means that I'm willing to take patches today (and today only), as
> > it will give the remainder of the week (up to Thursday - due to the
> > linux-next timing) to sort out any deficiencies in those patches.
> 
> That all said, 8486/1 _is_ the patch you've just asked me to merge,
> which has open questions from Jens that you (Lorenzo) have _not_
> responded to.
> 
> Jens was asking, in response to your feedback, whether an alternative
> Kconfig structure would satisfy your feedback... to which he's had no
> reply from you.  So, we're waiting on your response.

Sorry for the delay in replying. I re-tested 8486/1 on top of Jens'
v7, it is all fine, I commented on the config structure which is
a change that does not affect 8486/1 so if it is ok with you I am happy
for 8486/1 to be applied on top of Jens' series (I guess he should be
sending a v8 today which should be final).

As a heads-up, 8486/1 also depends on 8485/1 that you have already applied.

Thanks,
Lorenzo
Jens Wiklander Jan. 4, 2016, 12:26 p.m. UTC | #9
On Mon, Jan 04, 2016 at 12:14:01PM +0000, Lorenzo Pieralisi wrote:
> On Tue, Dec 22, 2015 at 10:46:08AM +0100, Jens Wiklander wrote:
> > On Mon, Dec 21, 2015 at 11:14:55AM +0000, Lorenzo Pieralisi wrote:
> > > On Wed, Dec 09, 2015 at 02:24:55PM +0100, Jens Wiklander wrote:
> > > > Adds helpers to do SMC and HVC based on ARM SMC Calling Convention.
> > > > CONFIG_HAVE_ARM_SMCCC is enabled for architectures that may support the
> > > > SMC or HVC instruction. It's the responsibility of the caller to know if
> > > > the SMC instruction is supported by the platform.
> > > > 
> > > > This patch doesn't provide an implementation of the declared functions.
> > > > Later patches will bring in implementations and set
> > > > CONFIG_HAVE_ARM_SMCCC for ARM and ARM64 respectively.
> > > > 
> > > > Signed-off-by: Jens Wiklander <jens.wiklander@linaro.org>
> > > > ---
> > > > 
> > > > v6:
> > > > * Move HAVE_ARM_SMCCC from init/Kconfig
> > > > 
> > > >  arch/Kconfig              |  3 ++
> > > >  include/linux/arm-smccc.h | 98 +++++++++++++++++++++++++++++++++++++++++++++++
> > > >  2 files changed, 101 insertions(+)
> > > >  create mode 100644 include/linux/arm-smccc.h
> > > > 
> > > > diff --git a/arch/Kconfig b/arch/Kconfig
> > > > index 4e949e5..ce3c0b0 100644
> > > > --- a/arch/Kconfig
> > > > +++ b/arch/Kconfig
> > > > @@ -564,4 +564,7 @@ config OLD_SIGACTION
> > > >  config COMPAT_OLD_SIGACTION
> > > >  	bool
> > > >  
> > > > +config HAVE_ARM_SMCCC
> > > > +	bool
> > > 
> > > It is ok by me to move it there, probably we do not want it at the end of
> > > the "ABI hall of shame" list :)
> > > 
> > > Or drivers/firmware/Kconfig ?
> > 
> > You tell me, I'm too new here to have a feeling for this.
> > 
> > > 
> > > Strictly speaking, since PSCI uses this by default, you should also
> > > enforce an ARM_PSCI_FW dependency on HAVE_ARM_SMCCC.
> > 
> > ARM_PSCI depends on CPU_V7 and ARM_PSCI_FW doesn't really depend on
> > anything today.
> > 
> > Would it be OK if I changed ARM_PSCI to depend on HAVE_ARM_SMCCC instead
> > of CPU_V7 in the "drivers: psci: replace psci firmware calls" patch?
> > At the same time I would move the "select HAVE_ARM_SMCCC if CPU_V7" line
> > to the "config ARM" block instead in the
> > "arm: add implementation for arm-smccc" patch.
> > 
> > I'll include this change in the v7 patch set if I don't hear anything.
> 
> Sorry for the delay in getting back to you.
> 
> Yes, I still think that HAVE_ARM_SMCCC should not be listed at the
> end of "ABI hall of shame" in arch/Kconfig and you can move it to
> drivers/firmware/Kconfig.
> 
> Other than that your v7 is fine by me, can you respin quickly and
> ask Russell to pull today please ?

OK, I'll do that asap. 

Thanks,
Jens
diff mbox

Patch

diff --git a/arch/Kconfig b/arch/Kconfig
index 4e949e5..ce3c0b0 100644
--- a/arch/Kconfig
+++ b/arch/Kconfig
@@ -564,4 +564,7 @@  config OLD_SIGACTION
 config COMPAT_OLD_SIGACTION
 	bool
 
+config HAVE_ARM_SMCCC
+	bool
+
 source "kernel/gcov/Kconfig"
diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h
new file mode 100644
index 0000000..dea68a9
--- /dev/null
+++ b/include/linux/arm-smccc.h
@@ -0,0 +1,98 @@ 
+/*
+ * Copyright (c) 2015, Linaro Limited
+ *
+ * This software is licensed under the terms of the GNU General Public
+ * License version 2, as published by the Free Software Foundation, and
+ * may be copied, distributed, and modified under those terms.
+ *
+ * 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 the
+ * GNU General Public License for more details.
+ *
+ */
+#ifndef __LINUX_ARM_SMCCC_H
+#define __LINUX_ARM_SMCCC_H
+
+#include <linux/types.h>
+#include <linux/linkage.h>
+
+/*
+ * This file provides common defines for ARM SMC Calling Convention as
+ * specified in
+ * http://infocenter.arm.com/help/topic/com.arm.doc.den0028a/index.html
+ */
+
+#define ARM_SMCCC_SMC_32		(0 << 30)
+#define ARM_SMCCC_SMC_64		(1 << 30)
+#define ARM_SMCCC_FAST_CALL		(1 << 31)
+#define ARM_SMCCC_STD_CALL		(0 << 31)
+
+#define ARM_SMCCC_OWNER_MASK		0x3F
+#define ARM_SMCCC_OWNER_SHIFT		24
+
+#define ARM_SMCCC_FUNC_MASK		0xFFFF
+
+#define ARM_SMCCC_IS_FAST_CALL(smc_val)	((smc_val) & ARM_SMCCC_FAST_CALL)
+#define ARM_SMCCC_IS_64(smc_val)	((smc_val) & ARM_SMCCC_SMC_64)
+#define ARM_SMCCC_FUNC_NUM(smc_val)	((smc_val) & ARM_SMCCC_FUNC_MASK)
+#define ARM_SMCCC_OWNER_NUM(smc_val) \
+	(((smc_val) >> ARM_SMCCC_OWNER_SHIFT) & ARM_SMCCC_OWNER_MASK)
+
+#define ARM_SMCCC_CALL_VAL(type, calling_convention, owner, func_num) \
+	((type) | (calling_convention) | \
+	(((owner) & ARM_SMCCC_OWNER_MASK) << ARM_SMCCC_OWNER_SHIFT) | \
+	((func_num) & ARM_SMCCC_FUNC_MASK))
+
+#define ARM_SMCCC_OWNER_ARCH		0
+#define ARM_SMCCC_OWNER_CPU		1
+#define ARM_SMCCC_OWNER_SIP		2
+#define ARM_SMCCC_OWNER_OEM		3
+#define ARM_SMCCC_OWNER_STANDARD	4
+#define ARM_SMCCC_OWNER_TRUSTED_APP	48
+#define ARM_SMCCC_OWNER_TRUSTED_APP_END	49
+#define ARM_SMCCC_OWNER_TRUSTED_OS	50
+#define ARM_SMCCC_OWNER_TRUSTED_OS_END	63
+
+/**
+ * struct arm_smccc_res - Result from SMC/HVC call
+ * @a0-a3 result values from registers 0 to 3
+ */
+struct arm_smccc_res {
+	unsigned long a0;
+	unsigned long a1;
+	unsigned long a2;
+	unsigned long a3;
+};
+
+/**
+ * arm_smccc_smc() - make SMC calls
+ * @a0-a7: arguments passed in registers 0 to 7
+ * @res: result values from registers 0 to 3
+ *
+ * This function is used to make SMC calls following SMC Calling Convention.
+ * The content of the supplied param are copied to registers 0 to 7 prior
+ * to the SMC instruction. The return values are updated with the content
+ * from register 0 to 3 on return from the SMC instruction.
+ */
+asmlinkage void arm_smccc_smc(unsigned long a0, unsigned long a1,
+			unsigned long a2, unsigned long a3, unsigned long a4,
+			unsigned long a5, unsigned long a6, unsigned long a7,
+			struct arm_smccc_res *res);
+
+/**
+ * arm_smccc_hvc() - make HVC calls
+ * @a0-a7: arguments passed in registers 0 to 7
+ * @res: result values from registers 0 to 3
+ *
+ * This function is used to make HVC calls following SMC Calling
+ * Convention.  The content of the supplied param are copied to registers 0
+ * to 7 prior to the HVC instruction. The return values are updated with
+ * the content from register 0 to 3 on return from the HVC instruction.
+ */
+asmlinkage void arm_smccc_hvc(unsigned long a0, unsigned long a1,
+			unsigned long a2, unsigned long a3, unsigned long a4,
+			unsigned long a5, unsigned long a6, unsigned long a7,
+			struct arm_smccc_res *res);
+
+#endif /*__LINUX_ARM_SMCCC_H*/