Linux-ACPI Archive on lore.kernel.org
 help / color / Atom feed
From: "Gustavo A. R. Silva" <gustavo@embeddedor.com>
To: "Moore, Robert" <robert.moore@intel.com>,
	"Rafael J. Wysocki" <rafael@kernel.org>,
	"Gustavo A. R. Silva" <gustavoars@kernel.org>
Cc: "Kaneda, Erik" <erik.kaneda@intel.com>,
	"Wysocki, Rafael J" <rafael.j.wysocki@intel.com>,
	Len Brown <lenb@kernel.org>,
	ACPI Devel Maling List <linux-acpi@vger.kernel.org>,
	"open list:ACPI COMPONENT ARCHITECTURE (ACPICA)"
	<devel@acpica.org>,
	Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH][next] ACPICA: Use fallthrough pseudo-keyword
Date: Mon, 27 Jul 2020 17:23:20 -0500
Message-ID: <b851b2c8-2d7c-939d-507d-b322dd4a0dbf@embeddedor.com> (raw)
In-Reply-To: <BYAPR11MB325602EDA2D2ACC2B28EAF4687670@BYAPR11MB3256.namprd11.prod.outlook.com>

Hi,


This is a macro pseudo-keyword, which expands to /* fallthrough */
for compilers that don't support the attribute __fallthrough__. See:

include/linux/compiler_attributes.h:213:
213 #if __has_attribute(__fallthrough__)
214 # define fallthrough                    __attribute__((__fallthrough__))
215 #else
216 # define fallthrough                    do {} while (0)  /* fallthrough */
217 #endif

So, any compiler (older or new) will be fine with it.

Thanks
--
Gustavo

On 7/8/20 09:17, Moore, Robert wrote:
> It looks like this attribute is not supported by msvc 2017 (and perhaps other compilers) -- it is apparently a GCC extension -- meaning that it cannot be used in the ACPICA compiler-independent code.
> 
> Bob
> 
> 
> -----Original Message-----
> From: Rafael J. Wysocki <rafael@kernel.org> 
> Sent: Wednesday, July 08, 2020 3:59 AM
> To: Gustavo A. R. Silva <gustavoars@kernel.org>
> Cc: Moore, Robert <robert.moore@intel.com>; Kaneda, Erik <erik.kaneda@intel.com>; Wysocki, Rafael J <rafael.j.wysocki@intel.com>; Len Brown <lenb@kernel.org>; ACPI Devel Maling List <linux-acpi@vger.kernel.org>; open list:ACPI COMPONENT ARCHITECTURE (ACPICA) <devel@acpica.org>; Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
> Subject: Re: [PATCH][next] ACPICA: Use fallthrough pseudo-keyword
> 
> On Tue, Jul 7, 2020 at 10:01 PM Gustavo A. R. Silva <gustavoars@kernel.org> wrote:
>>
>> Replace the existing /* fall through */ comments and its variants with 
>> the new pseudo-keyword macro fallthrough[1]. Also, remove unnecessary 
>> fall-through markings when it is the case.
>>
>> [1] 
>> https://www.kernel.org/doc/html/latest/process/deprecated.html?highlig
>> ht=fallthrough#implicit-switch-case-fall-through
>>
>> Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
> 
> I need to talk to Erik and Bob about this one.
> 
>> ---
>>  drivers/acpi/acpica/dscontrol.c |    2 +-
>>  drivers/acpi/acpica/dswexec.c   |    3 +--
>>  drivers/acpi/acpica/dswload.c   |    2 +-
>>  drivers/acpi/acpica/dswload2.c  |    4 +---
>>  drivers/acpi/acpica/exfldio.c   |    2 +-
>>  drivers/acpi/acpica/exresop.c   |    4 ++--
>>  drivers/acpi/acpica/exstore.c   |    4 ++--
>>  drivers/acpi/acpica/hwgpe.c     |    3 +--
>>  drivers/acpi/acpica/utdelete.c  |    3 +--
>>  drivers/acpi/acpica/utprint.c   |    2 +-
>>  10 files changed, 12 insertions(+), 17 deletions(-)
>>
>> diff --git a/drivers/acpi/acpica/dscontrol.c 
>> b/drivers/acpi/acpica/dscontrol.c index 4b5b6e859f62..134d53380663 
>> 100644
>> --- a/drivers/acpi/acpica/dscontrol.c
>> +++ b/drivers/acpi/acpica/dscontrol.c
>> @@ -62,7 +62,7 @@ acpi_ds_exec_begin_control_op(struct acpi_walk_state *walk_state,
>>                         }
>>                 }
>>
>> -               /*lint -fallthrough */
>> +               fallthrough;
>>
>>         case AML_IF_OP:
>>                 /*
>> diff --git a/drivers/acpi/acpica/dswexec.c 
>> b/drivers/acpi/acpica/dswexec.c index 1d4f8c81028c..41f6cb61778a 
>> 100644
>> --- a/drivers/acpi/acpica/dswexec.c
>> +++ b/drivers/acpi/acpica/dswexec.c
>> @@ -598,8 +598,7 @@ acpi_status acpi_ds_exec_end_op(struct acpi_walk_state *walk_state)
>>                                         break;
>>                                 }
>>
>> -                               /* Fall through */
>> -                               /*lint -fallthrough */
>> +                               fallthrough;
>>
>>                         case AML_INT_EVAL_SUBTREE_OP:
>>
>> diff --git a/drivers/acpi/acpica/dswload.c 
>> b/drivers/acpi/acpica/dswload.c index 27069325b6de..1d8789869dda 
>> 100644
>> --- a/drivers/acpi/acpica/dswload.c
>> +++ b/drivers/acpi/acpica/dswload.c
>> @@ -224,7 +224,7 @@ acpi_ds_load1_begin_op(struct acpi_walk_state *walk_state,
>>                                 break;
>>                         }
>>
>> -                       /*lint -fallthrough */
>> +                       fallthrough;
>>
>>                 default:
>>
>> diff --git a/drivers/acpi/acpica/dswload2.c 
>> b/drivers/acpi/acpica/dswload2.c index edadbe146506..de367e8e4cf4 
>> 100644
>> --- a/drivers/acpi/acpica/dswload2.c
>> +++ b/drivers/acpi/acpica/dswload2.c
>> @@ -213,9 +213,7 @@ acpi_ds_load2_begin_op(struct acpi_walk_state *walk_state,
>>                              parse_flags & ACPI_PARSE_MODULE_LEVEL)) {
>>                                 break;
>>                         }
>> -
>> -                       /*lint -fallthrough */
>> -
>> +                       fallthrough;
>>                 default:
>>
>>                         /* All other types are an error */ diff --git 
>> a/drivers/acpi/acpica/exfldio.c b/drivers/acpi/acpica/exfldio.c index 
>> ade35ff1c7ba..677ba3ab1482 100644
>> --- a/drivers/acpi/acpica/exfldio.c
>> +++ b/drivers/acpi/acpica/exfldio.c
>> @@ -434,7 +434,7 @@ acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
>>                  * region_field case and write the datum to the Operation Region
>>                  */
>>
>> -               /*lint -fallthrough */
>> +               fallthrough;
>>
>>         case ACPI_TYPE_LOCAL_REGION_FIELD:
>>                 /*
>> diff --git a/drivers/acpi/acpica/exresop.c 
>> b/drivers/acpi/acpica/exresop.c index 4d1b22971d58..7c8676adcf43 
>> 100644
>> --- a/drivers/acpi/acpica/exresop.c
>> +++ b/drivers/acpi/acpica/exresop.c
>> @@ -198,7 +198,7 @@ acpi_ex_resolve_operands(u16 opcode,
>>
>>                                         target_op = AML_DEBUG_OP;
>>
>> -                                       /*lint -fallthrough */
>> +                                       fallthrough;
>>
>>                                 case ACPI_REFCLASS_ARG:
>>                                 case ACPI_REFCLASS_LOCAL:
>> @@ -264,7 +264,7 @@ acpi_ex_resolve_operands(u16 opcode,
>>                          * Else not a string - fall through to the normal Reference
>>                          * case below
>>                          */
>> -                       /*lint -fallthrough */
>> +                       fallthrough;
>>
>>                 case ARGI_REFERENCE:    /* References: */
>>                 case ARGI_INTEGER_REF:
>> diff --git a/drivers/acpi/acpica/exstore.c 
>> b/drivers/acpi/acpica/exstore.c index 3adc0a29d890..fcf8dff56c5b 
>> 100644
>> --- a/drivers/acpi/acpica/exstore.c
>> +++ b/drivers/acpi/acpica/exstore.c
>> @@ -96,7 +96,7 @@ acpi_ex_store(union acpi_operand_object *source_desc,
>>                         return_ACPI_STATUS(AE_OK);
>>                 }
>>
>> -               /*lint -fallthrough */
>> +               fallthrough;
>>
>>         default:
>>
>> @@ -422,7 +422,7 @@ acpi_ex_store_object_to_node(union acpi_operand_object *source_desc,
>>                                 break;
>>                         }
>>
>> -                       /* Fallthrough */
>> +                       fallthrough;
>>
>>                 case ACPI_TYPE_DEVICE:
>>                 case ACPI_TYPE_EVENT:
>> diff --git a/drivers/acpi/acpica/hwgpe.c b/drivers/acpi/acpica/hwgpe.c 
>> index 49c46d4dd070..19d574f64c78 100644
>> --- a/drivers/acpi/acpica/hwgpe.c
>> +++ b/drivers/acpi/acpica/hwgpe.c
>> @@ -95,8 +95,7 @@ acpi_hw_low_set_gpe(struct acpi_gpe_event_info *gpe_event_info, u32 action)
>>                 if (!(register_bit & gpe_register_info->enable_mask)) {
>>                         return (AE_BAD_PARAMETER);
>>                 }
>> -
>> -               /*lint -fallthrough */
>> +               fallthrough;
>>
>>         case ACPI_GPE_ENABLE:
>>
>> diff --git a/drivers/acpi/acpica/utdelete.c 
>> b/drivers/acpi/acpica/utdelete.c index c365faf4e6cd..6db09eb9d257 
>> 100644
>> --- a/drivers/acpi/acpica/utdelete.c
>> +++ b/drivers/acpi/acpica/utdelete.c
>> @@ -111,8 +111,7 @@ static void acpi_ut_delete_internal_obj(union acpi_operand_object *object)
>>                         (void)acpi_ev_delete_gpe_block(object->device.
>>                                                        gpe_block);
>>                 }
>> -
>> -               /*lint -fallthrough */
>> +               fallthrough;
>>
>>         case ACPI_TYPE_PROCESSOR:
>>         case ACPI_TYPE_THERMAL:
>> diff --git a/drivers/acpi/acpica/utprint.c 
>> b/drivers/acpi/acpica/utprint.c index 681c11f4af4e..f7e43baf5ff2 
>> 100644
>> --- a/drivers/acpi/acpica/utprint.c
>> +++ b/drivers/acpi/acpica/utprint.c
>> @@ -475,7 +475,7 @@ int vsnprintf(char *string, acpi_size size, const char *format, va_list args)
>>                 case 'X':
>>
>>                         type |= ACPI_FORMAT_UPPER;
>> -                       /* FALLTHROUGH */
>> +                       fallthrough;
>>
>>                 case 'x':
>>
>>

  reply index

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-07-07 20:07 Gustavo A. R. Silva
2020-07-08 10:58 ` Rafael J. Wysocki
2020-07-08 14:17   ` Moore, Robert
2020-07-27 22:23     ` Gustavo A. R. Silva [this message]
2020-07-28  2:22       ` Joe Perches
2020-07-28 15:09         ` Moore, Robert

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=b851b2c8-2d7c-939d-507d-b322dd4a0dbf@embeddedor.com \
    --to=gustavo@embeddedor.com \
    --cc=devel@acpica.org \
    --cc=erik.kaneda@intel.com \
    --cc=gustavoars@kernel.org \
    --cc=lenb@kernel.org \
    --cc=linux-acpi@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=rafael.j.wysocki@intel.com \
    --cc=rafael@kernel.org \
    --cc=robert.moore@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

Linux-ACPI Archive on lore.kernel.org

Archives are clonable:
	git clone --mirror https://lore.kernel.org/linux-acpi/0 linux-acpi/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 linux-acpi linux-acpi/ https://lore.kernel.org/linux-acpi \
		linux-acpi@vger.kernel.org
	public-inbox-index linux-acpi

Example config snippet for mirrors

Newsgroup available over NNTP:
	nntp://nntp.lore.kernel.org/org.kernel.vger.linux-acpi


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git