Commit Graph

280558 Commits

Author SHA1 Message Date
simonb 4c244afec7 Octeon CN70XX CPUs have a COP0 config5 register.
XXX: The presense of these are defined by the MIPS architecture, should probe.
2020-09-02 01:33:27 +00:00
uwe cadd41c60c Fix chroot path (in a comment). 2020-09-02 00:15:15 +00:00
rillig 5518d2b27c make(1): rename Hash_Table fields
Back in the 1980s it made sense to have the type information encoded in
the variable names.  At the time when make was imported into the NetBSD
tree (1993-03-21), the functions did indeed not have prototypes, they
only had return types.  The void type was already invented at that time.
Since the compiler could not verify the types of function parameters, it
made perfect sense to have each variable tell whether it was a pointer
or not.

Since ISO C90 this is no longer necessary since the compiler checks
this.  The variable names can now focus on the application level and
their high-level meaning, expressing the relationship to other
variables instead of encoding redundant type information.
2020-09-01 21:11:31 +00:00
rillig b567ed9890 make(1): replace Hash_Table macros with inline functions 2020-09-01 21:00:15 +00:00
rillig 795de22c71 make(1): inline constant for hash table size
The name HTSIZE didn't provide any explanation for the value 191, and it
is obvious that this is a hash table size.  Therefore giving the
constant a name didn't explain anything or make it less magic.
2020-09-01 20:54:00 +00:00
rillig 90b52971fa make(1): improve documentation for enum.c and enum.h 2020-09-01 20:34:51 +00:00
rillig 93d390f91b make(1): improve variable names and data types in Dir_FindHereOrAbove 2020-09-01 20:17:18 +00:00
rillig 6f8bfeb0a6 make(1): add test for the -m option, the special .../ path 2020-09-01 20:14:34 +00:00
rillig 95110f95c2 make(1): add test for -m option with special argument .../ 2020-09-01 19:17:58 +00:00
gson 9c5137ef5c Format PR references consistently so that they can be automatically
turned into links in HTML reports.
2020-09-01 18:40:09 +00:00
rillig 39ed054cac make(1): make data types in Dir_HasWildcards more precise 2020-09-01 17:56:32 +00:00
rillig 93677eff47 make(1): mark LIBSUFF and RECHECK as independent build options 2020-09-01 17:40:34 +00:00
rillig dc36bab27e make(1): clean up documentation in buf.h, and redundant include files 2020-09-01 17:38:26 +00:00
rillig 8d45a60e32 make(1): remove filemon object files on clean 2020-09-01 17:12:30 +00:00
thorpej d249112c60 Update to the SoftFloat-2c version of softfloat-macros.h. This has 3
small changes:
- Simplification of the license.
- Minor style changes to 3 comments.
- Fixes a bug in shift128Right() for shift counts >= 64;
2020-09-01 15:45:20 +00:00
thorpej 9fc5e70813 Update to the SoftFloat-2b version of softfloat-macros.h. This makes a
clarifying change to the warranty disclaimer and updates the comments.  NFC.
2020-09-01 15:36:53 +00:00
bouyer 9ddb20e453 Fix braino in pmap_find_gnt(), really return the gnt entry covering the range
and not one that starts just after.
Fixes a KASSERT in pmap_remove_gnt().
2020-09-01 11:24:14 +00:00
thorpej 9f195b2aba - compare_{le,lt)(): Use float64_{le,lt}_quiet() to avoid raising
exceptions on QNaNs.
- alpha_fp_interpret(): Instructions are 32-bits wide, so don't use a
  uint64_t to contain them.
- alpha_fp_complete(): Operations on NaNs trap on Alpha, but the exception
  summary reports INV (invalid operation) rather than SWC (software
  completion) in this case.  So also interpret the instruction if INV
  is set in the exception summary.  This will emulate operations on
  NaN and correctly suppress FP traps for QNaNs.

This fixes bin/55633, which was caused by:

  -> Input string "nanotime" is passed to awk's internal is_number().
  -> strtod() interprets as "nan" and returns QNaN as the result.
  -> Result compared against HUGE_VAL, blows up because cmptle is called
     with a NaN operand, and the hardware doesn't care that it's quiet.
2020-09-01 08:22:36 +00:00
msaitoh 121c2aad9d Fix a panic on shutdown on a machine which use the recovery mode timer.
The recovery mode timer is first issued by the callout and it schedule
the workqueue. The workqueue then reschedule the callout. It's hard to
stop both of them without race only with callout_stop() and workqueue_wait.
To solve this problem. add new "detaching" flag and use it.

 The situation is almost the same as schedule_wqs_ok for the local_timer's
callout and workqueue, but the difference is that the local_timer isn't
required to run if the interface is not up. If it's not important to prevent
running timer while !IFF_UP, the flag can be integrated into one.
2020-09-01 04:19:16 +00:00
msaitoh b600995833 Call ixgbe_ifstop() instead of ixgbe_stop_locked() in
ixgbe_setup_low_power_mode() to stop the timer workqueue.
2020-09-01 04:06:56 +00:00
uwe 4895509f32 Improvements from Dan Plassche. 2020-09-01 01:15:28 +00:00
christos 85da8872cb eat the sign, pointed out by uwe@ 2020-09-01 00:35:29 +00:00
christos d21092d46f check explicitly for inf and nan. We can't check if it is a number,
because awk parses 1a as 1...
2020-09-01 00:21:01 +00:00
christos 4b14471916 Add a check_number function that does what is repeated in many places in
the code, but better.
2020-08-31 23:37:55 +00:00
christos 8871000030 Don't try so hard to convert strings into numbers. Results in bogus
conversions like:

% awk 'BEGIN { print "nanotime" + 123 }'
nan
% awk 'BEGIN { print "microtime" + 123 }'
123
% awk 'BEGIN { print "inftime" + 123 }'
inf
2020-08-31 23:36:58 +00:00
riastradh fa197dbf76 wg: Avoid memory leak if socreate fails. 2020-08-31 20:34:43 +00:00
riastradh 9ccb9ca69e wg: Make it build with WG_DEBUG on 32-bit platforms. 2020-08-31 20:34:18 +00:00
riastradh d1a81d3157 wg: Simplify locking.
Summary: Access to a stable established session is still allowed via
psref; all other access to peer and session state is now serialized
by struct wg_peer::wgp_lock, with no dancing around a per-session
lock.  This way, the handshake paths are locked, while the data
transmission paths are pserialized.

- Eliminate struct wg_session::wgs_lock.

- Eliminate wg_get_unstable_session -- access to the unstable session
  is allowed only with struct wgp_peer::wgp_lock held.

- Push INIT_PASSIVE->ESTABLISHED transition down into a thread task.

- Push rekey down into a thread task.

- Allocate session indices only on transition from UNKNOWN and free
  them only on transition back to UNKNOWN.

- Be a little more explicit about allowed state transitions, and
  reject some nonsensical ones.

- Sprinkle assertions and comments.

- Reduce atomic r/m/w swap operations that can just as well be
  store-release.
2020-08-31 20:33:58 +00:00
riastradh 4131d8f567 tests/net/if_wg: Allow one second of leeway for rekey. 2020-08-31 20:32:58 +00:00
riastradh 566d0c30dc wg: M_NOWAIT -> M_DONTWAIT
These happen to be aliases, but M_NOWAIT is part of the legacy malloc
API whereas M_DONTWAIT is part of the mbuf API.
2020-08-31 20:31:43 +00:00
riastradh 3ea30ceaf5 wg: wg_sockaddr audit.
- Ensure all access to struct wg_peer::wgp_endpoint happens while
  holding a psref.

- Simplify internalize/externalize logic and be more careful about
  verifying it before printing anything.
2020-08-31 20:31:03 +00:00
riastradh 993b555422 wg: On INIT, do DH and decrypt timestamp before locking session.
This narrows the window when the session is unlocked.  Really there
should be no such window, but we'll finish getting rid of it later.
2020-08-31 20:30:34 +00:00
riastradh 375c658faf wg: Verify or send cookie challenge before looking up session.
This step doesn't depend on the session, so let's avoid touching the
session state until we've passed it.
2020-08-31 20:29:14 +00:00
riastradh f25326ab88 wg: Verify mac1 as the first step on INIT and RESP messages.
This avoids the expensive DH computation before the sender has proven
knowledge of our public key.
2020-08-31 20:27:06 +00:00
riastradh b9cc45ec1f wg: Omit needless variable. 2020-08-31 20:26:46 +00:00
riastradh f0e0eb88b7 wg: Switch to callout_stop for session destructor timer.
Can't release the lock here, and can't sleep waiting for the callout
while we hold it without risking deadlock.  But not waiting is fine;
after we transition out of WGS_STATE_UNKNOWN the timer has no effect.
2020-08-31 20:26:21 +00:00
riastradh 01e85b3e6c wg: Fix indentation. No functional change. 2020-08-31 20:25:33 +00:00
riastradh cee9c1f171 wg: Just call callout_halt directly.
No functional change, just makes it easier to read where callout_halt
happens.
2020-08-31 20:25:11 +00:00
riastradh 9b47d5fd6f wg: Fix byte order on wire.
Give this a chance to work on big-endian systems.
2020-08-31 20:24:49 +00:00
riastradh 5dfb9270fc wg: mbuf m_freem audit.
1. wg_handle_msg_data frees m but the other wg_handle_msg_* just take
   a pointer to the mbuf content and not m itself, so free m in those
   cases.

2. Can't trivially prove that the pcq is empty by the time
   wg_destroy_peer runs pcq_destroy, so let's explicitly purge it
   just in case.

3. If wg_send_udp isn't doing udp_send or udp6_output, it still has
   to free m in the !INET6 error branch for IPv6 packets.

4. After rumpuser_wg_send_peer or rumpuser_wg_send_user, we still
   need to free the mbuf.
2020-08-31 20:24:19 +00:00
riastradh 2ca0f50d6d wg: Use thmap(9) for peer and session lookup.
Make sure we also don't trip over our own shoelaces by choosing the
same session index twice.
2020-08-31 20:23:56 +00:00
riastradh aced4ea104 thmap: Use keyed BLAKE2s for second-level hash and beyond.
This thwarts hash-flooding, but pays the cost only for those keys
that collide under the cheaper murmurhash2.
2020-08-31 20:22:57 +00:00
riastradh b73dc92dda wg: XAEAD doesn't use a counter, so don't pass one. 2020-08-31 20:21:30 +00:00
riastradh 3655877610 wg: Count down wg_npeers in wg_destroy_all_peers too.
Doesn't actually make a difference -- wg_destroy_all_peers is only
used when we're destroying the wg instance altogether -- but let's
not leave rakes to step on.
2020-08-31 20:21:09 +00:00
riastradh 7ec1face32 wg: Note lock order. 2020-08-31 20:20:48 +00:00
riastradh 4bf5fd0b75 wg: Remove IFF_POINTOPOINT.
Unclear why this was set; setting it seems to have required a kludge
in netinet/in.c that broke ipsec tunnels.  Clearing it makes wg work
again after that kludge was reverted.
2020-08-31 20:20:22 +00:00
rillig 7a2f02b40d make(1): move some of the :ts tests into a separate file
The successful cases can be easily tested in the .if conditions.  Around
these conditions, there is enough space for explaining the test cases
and their purpose.

The failure cases have been left in the file for now since they still
produce unwanted characters in the output.  These characters are not
produced when the parse error occurs in a conditional.
2020-08-31 19:58:21 +00:00
christos 67653226d1 PR/55629: Andreas Gustafsson: Don't crash when an emulation does not provide
e_dtrace_syscall (like compat_netbsd32)
2020-08-31 19:51:30 +00:00
rillig 32c7ea9694 make(1): inline a local variable in VarUniq
Just to eliminate any remote possibility of aliasing and thereby
forgetting to update all involved variables.
2020-08-31 19:09:19 +00:00
rillig 411604f9db make(1): add more examples to the documentation of ParseModifierPart 2020-08-31 19:05:53 +00:00