Page MenuHomeFreeBSD

Remove archaic register keyword from sys and ANSIfy prototypes while here
ClosedPublic

Authored by emaste on Mar 30 2017, 12:53 AM.
Tags
None
Referenced Files
F107736095: D10193.diff
Fri, Jan 17, 9:19 PM
Unknown Object (File)
Fri, Jan 3, 9:07 AM
Unknown Object (File)
Nov 21 2024, 7:49 PM
Unknown Object (File)
Sep 27 2024, 12:40 PM
Unknown Object (File)
Sep 20 2024, 4:05 AM
Unknown Object (File)
Sep 19 2024, 4:14 PM
Unknown Object (File)
Sep 17 2024, 11:04 PM
Unknown Object (File)
Sep 17 2024, 4:04 PM
Subscribers

Details

Summary

A long long time ago the register keyword told the compiler to store the corresponding variable in a CPU register, but it is not relevant for any compiler used in the FreeBSD world today.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

Did you use a coccinelle script for the ANSIfying, and if so, what was it?

In D10193#210689, @cem wrote:

Did you use a coccinelle script for the ANSIfying, and if so, what was it?

I did not - this is a collection of changes that have been sitting in various WIP trees of mine for ages, through a combination of manual changes and set etc.

cem added inline comments.
sys/kern/kern_clock.c
393–395

didn't feel like ANSIfying these too? :)

This revision is now accepted and ready to land.Mar 30 2017, 1:09 AM
sys/amd64/include/xen/hypercall.h
112

hypercall.h changes will be omitted, the register keyword is required for the __asm__("r10").

sys/kern/kern_clock.c
393–395

hrm, missed these. Updated in my tree.

sys/cddl/contrib/opensolaris/uts/common/sys/sysmacros.h
391

It would seem worth trying to upstream the sys/cddl/contrib changes or otherwise dropping them.

sys/ddb/db_access.c
60

Missed this 'register'.

sys/ddb/db_sym.c
292

Missed this 'register'.

370

Missed this 'register'.

sys/kern/sysv_msg.c
757

ANSIfy?

sys/kern/vfs_mount.c
368

Maybe follow the more typical '#ifndef _SYSPROTO_H_' format rather than doing this type of custom comment?

sys/kern/vfs_syscalls.c
1549

Use SYS_SYSPROTO_H here as well.

2354

SYS_SYSPROTO_H

sbruno added a subscriber: sbruno.

Just a LGTM based on the Intel Networking group.

sys/dev/ex/if_ex.c
815

Approved.

sys/dev/ixgb/if_ixgb.c
1780

Approved.

emaste edited edge metadata.
emaste marked 4 inline comments as done.

Update based on feedback in Phabricator

This revision now requires review to proceed.Apr 6 2017, 5:49 PM
emaste added inline comments.
sys/kern/vfs_syscalls.c
1558

leftover will be deleted

emaste added inline comments.
sys/cddl/contrib/opensolaris/uts/common/sys/sysmacros.h
391

Will handle these outside of this review.

sys/dev/ixgb/if_ixgb.c
1780

previously committed

emaste marked an inline comment as done.
This revision is now accepted and ready to land.May 17 2017, 1:53 PM

A note for posterity: I compared object files built with/without this patch. There were 8 files with differences, and those differences were due to __LINE__ being passed to mtx_lock or similar.

  • kern_clock.o
  • kern.exec.o
  • sys_machdep.o
  • sysv_msg.o
  • vfs_mount.o
  • vfs_syscalls.o
  • vfs_vnops.o
  • vm_machdep.o