]> git.ipfire.org Git - thirdparty/tor.git/log
thirdparty/tor.git
2 years agoBug 40811: Count conflux leg launch attempts early.
Mike Perry [Thu, 15 Jun 2023 16:13:34 +0000 (16:13 +0000)] 
Bug 40811: Count conflux leg launch attempts early.

Also, double check that the consensus has enough overall exits before
attempting conflux set launch.

2 years agoMerge branch 'tor-gitlab/mr/721'
David Goulet [Wed, 14 Jun 2023 13:45:27 +0000 (09:45 -0400)] 
Merge branch 'tor-gitlab/mr/721'

2 years agoChanges file for bug40810
Mike Perry [Tue, 13 Jun 2023 18:13:02 +0000 (18:13 +0000)] 
Changes file for bug40810

2 years agoBug 40810: Avoid using 0 RTT legs
Mike Perry [Tue, 13 Jun 2023 18:15:07 +0000 (18:15 +0000)] 
Bug 40810: Avoid using 0 RTT legs

2 years agoBug 40810: Improve validation checks to ignore 0-RTT legs
Mike Perry [Sat, 10 Jun 2023 16:00:56 +0000 (16:00 +0000)] 
Bug 40810: Improve validation checks to ignore 0-RTT legs

Also add calls to dump the legs of a conflux set if we have too many

2 years agoMerge branch 'tor-gitlab/mr/715'
David Goulet [Tue, 13 Jun 2023 17:03:11 +0000 (13:03 -0400)] 
Merge branch 'tor-gitlab/mr/715'

2 years agoBug 40801: Add changes file
Mike Perry [Fri, 9 Jun 2023 16:12:51 +0000 (16:12 +0000)] 
Bug 40801: Add changes file

2 years agoBug 40801: Do not change read state of marked conns
Mike Perry [Fri, 9 Jun 2023 15:52:42 +0000 (15:52 +0000)] 
Bug 40801: Do not change read state of marked conns

2 years agoBug 40801: Send LINKED_ACK before attaching streams
Mike Perry [Thu, 8 Jun 2023 22:44:26 +0000 (22:44 +0000)] 
Bug 40801: Send LINKED_ACK before attaching streams

Otherwise, the BEGIN cell arrives at the exit before it has an RTT,
and then it does not know which circuit to prefer in response.

2 years agoAdd BUG() macro to marked edge reads
Mike Perry [Tue, 6 Jun 2023 16:21:20 +0000 (16:21 +0000)] 
Add BUG() macro to marked edge reads

This will give us a full stacktrace.

2 years agoAdd conflux logs to diagnose cases where RTTs are absent/zero.
Mike Perry [Thu, 30 Mar 2023 23:43:34 +0000 (23:43 +0000)] 
Add conflux logs to diagnose cases where RTTs are absent/zero.

2 years agoFix the spacing in the 'Your Tor identity key fingerprint is' log line'
Neel Chauhan [Wed, 7 Jun 2023 17:02:33 +0000 (10:02 -0700)] 
Fix the spacing in the 'Your Tor identity key fingerprint is' log line'

2 years agoAdd a conflux helper to log conflux sets.
Mike Perry [Tue, 6 Jun 2023 15:14:33 +0000 (15:14 +0000)] 
Add a conflux helper to log conflux sets.

2 years agoMore fixes for compile-time warnings in equix and hashx
Micah Elizabeth Scott [Thu, 1 Jun 2023 18:30:40 +0000 (11:30 -0700)] 
More fixes for compile-time warnings in equix and hashx

This addresses issue #40800 and a couple other problems I noticed while
trying to reproduce that one.

The original issue is just a missing cast to void* on the args of
__builtin___clear_cache(), and clang is picky about the implicit cast
between what it considers to be char of different signedness. Original
report is from MacOS but it's also reproducible on other clang targets.

The cmake-based original build system for equix and hashx was a handy
way to run tests, but it suffered from some warnings due to incorrect
application of include_directories().

And lastly, there were some return codes from hashx_exec() that get
ignored on equix when asserts are disabled. It bugged me too much to
just silence this with a (void) cast, since even though this is in the
realm of low-likelyhood programming errors and not true runtime errors, I
don't want to make it easy for the hashx_exec() wrappers to return
values that are dangerously wrong if an error is ignored. I made sure
that even if asserts are disabled, we return values that will cause the
solver and verifier to both fail to validate a potential solution.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoversion: Bump version to 0.4.8.1-alpha-dev
Tor CI Release [Thu, 1 Jun 2023 14:33:12 +0000 (14:33 +0000)] 
version: Bump version to 0.4.8.1-alpha-dev

2 years agoversion: Bump version to 0.4.8.1-alpha tor-0.4.8.1-alpha
Tor CI Release [Thu, 1 Jun 2023 13:36:17 +0000 (13:36 +0000)] 
version: Bump version to 0.4.8.1-alpha

2 years agorelease: ChangeLog for 0.4.8.1-alpha
Tor CI Release [Thu, 1 Jun 2023 13:36:17 +0000 (13:36 +0000)] 
release: ChangeLog for 0.4.8.1-alpha

2 years agofallbackdir: Update list generated on June 01, 2023
Tor CI Release [Thu, 1 Jun 2023 13:35:34 +0000 (13:35 +0000)] 
fallbackdir: Update list generated on June 01, 2023

2 years agoUpdate geoip files to match ipfire location db, 2023/06/01.
Tor CI Release [Thu, 1 Jun 2023 13:35:03 +0000 (13:35 +0000)] 
Update geoip files to match ipfire location db, 2023/06/01.

2 years agoscripts: Use latest geoip database instead of using location
David Goulet [Thu, 1 Jun 2023 13:32:11 +0000 (09:32 -0400)] 
scripts: Use latest geoip database instead of using location

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agotest: Really fix the mem leak from prior commit
David Goulet [Thu, 1 Jun 2023 13:07:43 +0000 (09:07 -0400)] 
test: Really fix the mem leak from prior commit

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agotest: Fix a mem leak reported by Coverity
David Goulet [Thu, 1 Jun 2023 12:35:08 +0000 (08:35 -0400)] 
test: Fix a mem leak reported by Coverity

Here is the report:

  *** CID 1531835:  Resource leaks  (RESOURCE_LEAK)
  /src/test/test_crypto_slow.c: 683 in test_crypto_equix()
  677
  678           /* Solve phase: Make sure the test vector matches */
  679           memset(&output, 0xa5, sizeof output);
  680           equix_result result;
  681           result = equix_solve(solve_ctx, challenge_literal,
  682                                challenge_len, &output);
  >>>     CID 1531835:  Resource leaks  (RESOURCE_LEAK)
  >>>     Variable "solve_ctx" going out of scope leaks the storage it points to.

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agoMerge branch 'maint-0.4.7'
David Goulet [Wed, 31 May 2023 18:32:07 +0000 (14:32 -0400)] 
Merge branch 'maint-0.4.7'

2 years agochanges: Add file for MR 714
David Goulet [Wed, 31 May 2023 18:31:59 +0000 (14:31 -0400)] 
changes: Add file for MR 714

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agoMerge branch 'tor-gitlab/mr/714' into maint-0.4.7
David Goulet [Wed, 31 May 2023 18:28:44 +0000 (14:28 -0400)] 
Merge branch 'tor-gitlab/mr/714' into maint-0.4.7

2 years agoUpdate CI builds to Debian Bullseye, fix associated compatibility bugs
Micah Elizabeth Scott [Tue, 30 May 2023 16:53:09 +0000 (09:53 -0700)] 
Update CI builds to Debian Bullseye, fix associated compatibility bugs

This is a change intended for 0.4.7 maintenance as well as main.

The CI builds use Debian Buster which is now end of life, and I was
experiencing inconsistent CI failures with accessing its security update
server. I wanted to update CI to a distro that isn't EOL, and Bullseye
is the current stable release of Debian.

This opened up a small can of worms that this commit also deals with.
In particular there's a docker engine bug that we work around by
removing the docker-specific apt cleanup script if it exists, and
there's a new incompatibility between tracing and sandbox support.

The tracing/sandbox incompatibility itself had two parts:

  - The membarrier() syscall is used to deliver inter-processor
    synchronization events, and the external "userspace-rcu"
    data structure library would make assumptions that if membarrier
    is available at initialization it always will be. This caused
    segfaults in some cases when running trace + sandbox. Resolved this
    by allowing membarrier entirely, in the sandbox.

  - userspace-rcu also assumes it can block signals, and fails
    hard if this can't be done. We already include a similar carveout
    to allow this in the sandbox for fragile-hardening, so I extended
    that to cover tracing as well.

Addresses issue #40799

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoMerge branch 'tor-gitlab/mr/713'
David Goulet [Wed, 31 May 2023 13:07:45 +0000 (09:07 -0400)] 
Merge branch 'tor-gitlab/mr/713'

2 years agotls: Disable a warning with LibreSSL >= 3.8.0
orbea [Mon, 29 May 2023 19:56:37 +0000 (12:56 -0700)] 
tls: Disable a warning with LibreSSL >= 3.8.0

Skip a warning using EC_GFp_nist_method() which was removed in LibreSSL
3.8.

Based on a patch from OpenBSD.

https://github.com/openbsd/ports/commit/33fe251a08cb11f30ce6094a2e0759c3bb63ed16

These functions are deprecated since OpenSSL 3.0.

https://www.openssl.org/docs/man3.1/man3/EC_GFp_nist_method.html

2 years agohs_pow: Add CompiledProofOfWorkHash torrc option
Micah Elizabeth Scott [Mon, 29 May 2023 02:45:41 +0000 (19:45 -0700)] 
hs_pow: Add CompiledProofOfWorkHash torrc option

This exposes the new fallback behavior in hashx via a new AUTOBOOL
configuration option, available to both clients and services. The
default should be fine for nearly everyone, but it might be necessary
to enable or disable the compiler manually for diagnostic purposes.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: Update for equix API to fix issue 40794
Micah Elizabeth Scott [Sun, 28 May 2023 23:35:31 +0000 (16:35 -0700)] 
hs_pow: Update for equix API to fix issue 40794

This change adapts the hs_pow layer and unit tests to API changes
in hashx and equix which modify the fault recovery responsibilities
and reporting behaivor.

This and the corresponding implementation changes in hashx and equix
form the fix for #40794, both solving the segfault and giving hashx a
way to report those failures up the call chain without them being
mistaken for a different error (unusable seed) that would warrant a
retry.

To handle these new late compiler failures with a minimum of fuss or
inefficiency, the failover is delegated to the internals of hashx and
tor needs only pass in a EQUIX_CTX_TRY_COMPILE flag to get the behavior
that tor was previously responsible for implementing.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoequix: API changes for new result codes and hashx compatibility
Micah Elizabeth Scott [Sun, 28 May 2023 21:05:45 +0000 (14:05 -0700)] 
equix: API changes for new result codes and hashx compatibility

This change adapts Equi-X to the corresponding HashX API changes that
added HASHX_TRY_COMPILE. The new regularized HashX return codes are
reflected by revised corresponding Equi-X return codes.

Both solve and verify operations now return an error/success code, and a
new equix_solutions_buffer struct includes both the solution buffer
and information about the solution count and hashx implementation.

With this change, it's possible to discern between hash construction
failures (invalid seed) and some external error like an mprotect()
failure.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohashx: API changes to allow recovery from late compile failures
Micah Elizabeth Scott [Fri, 26 May 2023 00:37:52 +0000 (17:37 -0700)] 
hashx: API changes to allow recovery from late compile failures

This is an API breaking change to hashx, which modifies the error
handling strategy. The main goal here is to allow unproblematic
recovery from hashx_compile failures.

hashx_alloc can no longer fail for reasons other than memory
allocation. All platform-specific compile failures are now reported via
hashx_make(), in order to both allow later failure and avoid requiring
users of the API to maintain and test multiple failure paths.

Note that late failures may be more common in actual use than early
failures. Early failures represent architectures other than x86_64 and
aarch64. Late failures could represent a number of system configurations
where syscalls are restricted.

The definition of a hashx context no longer tries to overlay storage for
the different types of program, and instead allows one context to always
contain an interpretable description of the program as well as an optional
buffer for compiled code.

The hashx_type enum is now used to mean either a specific type of hash
function or a type of hashx context. You can allocate a context for use
only with interpreted or compiled functions, or you can use
HASHX_TRY_COMPILE to prefer the compiler with an automatic fallback on
the interpreter. After calling hashx_make(), the new hashx_query_type()
can be used if needed to determine which implementation was actually
chosen.

The error return types have been overhauled so that everyone uses the
hashx_result enum, and seed failures vs compile failures are always
clearly distinguishable.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohashx: allow hashx_compile to fail, avoid segfault without changing API
Micah Elizabeth Scott [Wed, 24 May 2023 20:25:54 +0000 (13:25 -0700)] 
hashx: allow hashx_compile to fail, avoid segfault without changing API

This is a minimal portion of the fix for tor issue #40794, in which
hashx segfaults due to denial of mprotect() syscalls at runtime.

Prior to this fix, hashx makes the assumption that if the JIT is
supported on the current architecture, it will also be usable at
runtime. This isn't true if mprotect fails on linux, which it may for
various reasons: the tor built-in sandbox, the shadow simulator, or
external security software that implements a syscall filter.

The necessary error propagation was missing internally in hashx,
causing us to obliviously call into code which was never made
executable. With this fix, hashx_make() will instead fail by returning
zero.

A proper fix will require API changes so that callers can discern
between different types of failures. Zero already means that a program
couldn't be constructed, which requires a different response: choosing a
different seed, vs switching implementations. Callers would also benefit
from a way to use one context (with its already-built program) to
run in either compiled or interpreted mode.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohashx: minor, another logical operator change
Micah Elizabeth Scott [Wed, 24 May 2023 20:20:58 +0000 (13:20 -0700)] 
hashx: minor, another logical operator change

The code style in equix and hashx sometimes uses bitwise operators
in place of logical ones in cases where it doesn't really matter
either way. This sometimes annoys our static analyzer tools.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agotest_sandbox: equix crypto test case for issue 40794
Micah Elizabeth Scott [Wed, 24 May 2023 02:18:50 +0000 (19:18 -0700)] 
test_sandbox: equix crypto test case for issue 40794

This is an additional test case for test_sandbox that runs a small
subset of test_crypto_equix() inside the syscall sandbox, where
mprotect() is filtered.

It's reasonable for the sandbox to disallow JIT. We could revise this
policy if we want, but it seems a good default for now. The problem
in issue 40794 is that both equix and hashx need improvements in their
API to handle failures after allocation time, and this failure occurs
while the hash function is being compiled.

With this commit only, the segfault from issue 40794 is reproduced.
Subsequent commits will fix the segfault and revise the API.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agochanges: Add file for ticket 40797
David Goulet [Thu, 25 May 2023 15:12:15 +0000 (11:12 -0400)] 
changes: Add file for ticket 40797

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agoForgot about the stub names
friendly73 [Sat, 15 Apr 2023 14:48:30 +0000 (14:48 +0000)] 
Forgot about the stub names

2 years agoAdded relay prefix to new metrics functions
friendly73 [Sat, 15 Apr 2023 12:03:14 +0000 (12:03 +0000)] 
Added relay prefix to new metrics functions

2 years agoFixed enum type not found in relay_stub
friendly73 [Fri, 24 Mar 2023 15:34:11 +0000 (15:34 +0000)] 
Fixed enum type not found in relay_stub

2 years agoAdded void stubs for the relay metrics functions to fix building without relay module
friendly73 [Fri, 24 Mar 2023 15:21:40 +0000 (15:21 +0000)] 
Added void stubs for the relay metrics functions to fix building without relay module

2 years agoFixed new arguments for metrics_store_add
friendly73 [Tue, 21 Mar 2023 14:42:17 +0000 (14:42 +0000)] 
Fixed new arguments for metrics_store_add

2 years agoRemoved getter abstraction and moved from rephist to relay_metrics.
friendly73 [Tue, 21 Mar 2023 14:25:57 +0000 (14:25 +0000)] 
Removed getter abstraction and moved from rephist to relay_metrics.

2 years agoFixed est intro getter using wrong array
friendly73 [Sun, 19 Feb 2023 19:03:48 +0000 (19:03 +0000)] 
Fixed est intro getter using wrong array

2 years agoFixed REND1 metric label value
friendly73 [Sun, 19 Feb 2023 19:03:14 +0000 (19:03 +0000)] 
Fixed REND1 metric label value

2 years agoAdded INTRO and REND metrics for relay.
friendly73 [Sun, 19 Feb 2023 16:17:50 +0000 (16:17 +0000)] 
Added INTRO and REND metrics for relay.

2 years agoMerge branch 'tor-gitlab/mr/443'
David Goulet [Thu, 25 May 2023 14:50:15 +0000 (10:50 -0400)] 
Merge branch 'tor-gitlab/mr/443'

2 years agoAdd missing changes file for tor#33669.
Alexander Færøy [Fri, 4 Nov 2022 19:57:53 +0000 (20:57 +0100)] 
Add missing changes file for tor#33669.

See: tpo/core/tor#33669.

2 years agoRestart PT processes when they die on us.
Alexander Færøy [Fri, 24 Sep 2021 14:08:12 +0000 (16:08 +0200)] 
Restart PT processes when they die on us.

This patch forces a PT reconfigure of infant PT processes as part of the
PT process' exit handler.

See: tpo/core/tor#33669

2 years agoLog at LD_PT instead of LD_GENERAL for PT process stdout lines.
Alexander Færøy [Fri, 24 Sep 2021 14:07:50 +0000 (16:07 +0200)] 
Log at LD_PT instead of LD_GENERAL for PT process stdout lines.

See: tpo/core/tor#33669

2 years agoOnly terminate PT processes that are running.
Alexander Færøy [Fri, 24 Sep 2021 14:07:21 +0000 (16:07 +0200)] 
Only terminate PT processes that are running.

See: tpo/core/tor#33669

2 years agoLog name of managed proxy in exit handler.
Alexander Færøy [Fri, 24 Sep 2021 12:47:30 +0000 (14:47 +0200)] 
Log name of managed proxy in exit handler.

This patch ensures that we can figure out which PT that terminated in
the PT exit handler.

See: tpo/core/tor#33669

2 years agoLog state transitions for Pluggable Transports
Alexander Færøy [Fri, 24 Sep 2021 12:43:24 +0000 (14:43 +0200)] 
Log state transitions for Pluggable Transports

This patch makes Tor log state transitions within the PT layer at the
info log-level. This should make it easier to figure out if Tor ends up
in a strange state.

See: tpo/core/tor#33669

2 years agotest: Fix parseconf to account for ClientUseIPv6 change for dirauth disabled
David Goulet [Thu, 25 May 2023 14:20:12 +0000 (10:20 -0400)] 
test: Fix parseconf to account for ClientUseIPv6 change for dirauth disabled

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agotest: Fix parseconf to account for ClientUseIPv6 change
David Goulet [Thu, 25 May 2023 13:21:23 +0000 (09:21 -0400)] 
test: Fix parseconf to account for ClientUseIPv6 change

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agoMerge branch 'tor-gitlab/mr/711'
David Goulet [Wed, 24 May 2023 15:45:40 +0000 (11:45 -0400)] 
Merge branch 'tor-gitlab/mr/711'

2 years agotoken_bucket_ctr: replace 32-bit wallclock time with monotime
Micah Elizabeth Scott [Tue, 16 May 2023 23:28:26 +0000 (16:28 -0700)] 
token_bucket_ctr: replace 32-bit wallclock time with monotime

This started as a response to ticket #40792 where Coverity is
complaining about a potential year 2038 bug where we cast time_t from
approx_time() to uint32_t for use in token_bucket_ctr.

There was a larger can of worms though, since token_bucket really
doesn't want to be using wallclock time here. I audited the call sites
for approx_time() and changed any that used a 32-bit cast or made
inappropriate use of wallclock time. Things like certificate lifetime,
consensus intervals, etc. need wallclock time. Measurements of rates
over time, however, are better served with a monotonic timer that does
not try and sync with wallclock ever.

Looking closer at token_bucket, its design is a bit odd because it was
initially intended for use with tick units but later forked into
token_bucket_rw which uses ticks to count bytes per second, and
token_bucket_ctr which uses seconds to count slower events. The rates
represented by either token bucket can't be lower than 1 per second, so
the slower timer in 'ctr' is necessary to represent the slower rates of
things like connections or introduction packets or rendezvous attempts.

I considered modifying token_bucket to use 64-bit timestamps overall
instead of 32-bit, but that seemed like an unnecessarily invasive change
that would grant some peace of mind but probably not help much. I was
more interested in removing the dependency on wallclock time. The
token_bucket_rw timer already uses monotonic time. This patch converts
token_bucket_ctr to use monotonic time as well. It introduces a new
monotime_coarse_absolute_sec(), which is currently the same as nsec
divided by a billion but could be optimized easily if we ever need to.

This patch also might fix a rollover bug.. I haven't tested this
extensively but I don't think the previous version of the rollover code
on either token bucket was correct, and I would expect it to get stuck
after the first rollover.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoMerge branch 'tor-gitlab/mr/709'
David Goulet [Wed, 24 May 2023 15:37:05 +0000 (11:37 -0400)] 
Merge branch 'tor-gitlab/mr/709'

2 years agoMerge branch 'tor-gitlab/mr/710'
David Goulet [Wed, 24 May 2023 15:12:22 +0000 (11:12 -0400)] 
Merge branch 'tor-gitlab/mr/710'

2 years agotest_hs_descriptor: Add a test case that fails without the fix for 40793
Micah Elizabeth Scott [Thu, 18 May 2023 01:33:19 +0000 (18:33 -0700)] 
test_hs_descriptor: Add a test case that fails without the fix for 40793

This adds a bit more to hs_descriptor/test_decode_descriptor, mostly
testing pow-params and triggering the tor_assert() in issue #40793.

There was no mechanism for adding arbitrary test strings to the
encrypted portion of the desc without duplicating encode logic. One
option might be to publicize get_inner_encrypted_layer_plaintext enough
to add a mock implementation. In this patch I opt for what seems like
the simplest solution, at the cost of a small amount of #ifdef noise.
The unpacked descriptor grows a new test-only member that's used for
dropping arbitrary data in at encode time.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoMerge branch 'tor-gitlab/mr/708'
David Goulet [Wed, 24 May 2023 15:03:47 +0000 (11:03 -0400)] 
Merge branch 'tor-gitlab/mr/708'

2 years agoipv6: Flip ClientUseIPv6 to 1
agowa338 [Sat, 29 Apr 2023 17:28:30 +0000 (17:28 +0000)] 
ipv6: Flip ClientUseIPv6 to 1

Fixes #40785

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agometrics: Add ticket 40546 changes file and code fix
David Goulet [Wed, 24 May 2023 14:42:00 +0000 (10:42 -0400)] 
metrics: Add ticket 40546 changes file and code fix

The MR was using an old function definition so the code fix is for that.

Closes #40546

Signed-off-by: David Goulet <dgoulet@torproject.org>
2 years agoMerge branch 'tor-gitlab/mr/698'
David Goulet [Wed, 24 May 2023 14:40:25 +0000 (10:40 -0400)] 
Merge branch 'tor-gitlab/mr/698'

2 years agoMerge branch 'tor-gitlab/mr/703'
David Goulet [Wed, 24 May 2023 14:38:58 +0000 (10:38 -0400)] 
Merge branch 'tor-gitlab/mr/703'

2 years agohs_pow: fix insufficient length check in pow-params
Micah Elizabeth Scott [Mon, 15 May 2023 19:11:00 +0000 (12:11 -0700)] 
hs_pow: fix insufficient length check in pow-params

The descriptor validation table had an out of date minimum length
for pow-params (3) whereas the spec and the current code expect at
least 4 parameters. This was an opportunity for a malicious service
to cause an assert failure in clients which attempted to parse its
descriptor.

Addresses issue #40793

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoAdd changes file for conflux.
Mike Perry [Thu, 11 May 2023 19:24:49 +0000 (19:24 +0000)] 
Add changes file for conflux.

2 years agotest_crypto: avoid memory leak in some hashx test failures
Micah Elizabeth Scott [Thu, 11 May 2023 18:17:43 +0000 (11:17 -0700)] 
test_crypto: avoid memory leak in some hashx test failures

This should fix one of the warnings in issue #40792.

I was sloppy with freeing memory in the failure cases for
test_crypto_hashx. ASAN didn't notice but coverity did. Okay, I'll eat
my vegetables and put hashx_ctx's deinit in an upper scope and use
'goto done' correctly like a properly diligent C programmer.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoequix: avoid a coverity warning in hashx_alloc()
Micah Elizabeth Scott [Thu, 11 May 2023 18:10:15 +0000 (11:10 -0700)] 
equix: avoid a coverity warning in hashx_alloc()

This addresses one of the warnings in issue #40792. As far as I can tell
this is a false positive, since the use of "ctx->type" in hashx_free()
can only be hit after the unioned code/program pointer is non-NULL. It's
no big deal to zero this value explicitly to silence the warning though.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agoAdd torrc option for conflux client UX.
Mike Perry [Thu, 11 May 2023 17:57:00 +0000 (17:57 +0000)] 
Add torrc option for conflux client UX.

2 years agoFix unit tests.
Mike Perry [Wed, 10 May 2023 21:56:52 +0000 (21:56 +0000)] 
Fix unit tests.

2 years agoClean up UX decision logic; hardcode for browser UX case.
Mike Perry [Tue, 9 May 2023 20:11:41 +0000 (20:11 +0000)] 
Clean up UX decision logic; hardcode for browser UX case.

2 years agofix minor typos in conflux and pow areas
Roger Dingledine [Thu, 11 May 2023 17:09:34 +0000 (13:09 -0400)] 
fix minor typos in conflux and pow areas

2 years agoClean up and disable switch rate limiting.
Mike Perry [Tue, 9 May 2023 19:42:05 +0000 (19:42 +0000)] 
Clean up and disable switch rate limiting.

Switch rate limiting will likely be helpful for limiting OOQ, but according to
shadow it was the cause of slower performance in Hong Kong endpoints.

So let's disable it, and then optimize for OOQ later.

2 years agoRemove two conflux algs: maxrate and cwndrate.
Mike Perry [Mon, 8 May 2023 14:44:38 +0000 (14:44 +0000)] 
Remove two conflux algs: maxrate and cwndrate.

Maxrate had slower throughput than lowrtt in Shadow, which is not too
surprising. We just wanted to test it.

2 years agohs_pow: Modify challenge format, include blinded HS id
Micah Elizabeth Scott [Tue, 9 May 2023 06:58:30 +0000 (23:58 -0700)] 
hs_pow: Modify challenge format, include blinded HS id

This is a protocol breaking change that implements nickm's
changes to prop 327 to add an algorithm personalization string
and blinded HS id to the EquiX challenge string for our onion
service client puzzle.

This corresponds with the spec changes in torspec!130,
and it fixes a proposed vulnerability documented in
ticket tor#40789.

Clients and services prior to this patch will no longer
be compatible with the proposed "v1" proof-of-work protocol.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: add per-circuit effort information to control port
Micah Elizabeth Scott [Wed, 26 Apr 2023 22:29:04 +0000 (15:29 -0700)] 
hs_pow: add per-circuit effort information to control port

This lets controller apps see the outgoing PoW effort on client
circuits, and the validated effort received on an incoming service
circuit.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: fix error path with outdated assumption
Micah Elizabeth Scott [Tue, 25 Apr 2023 16:02:45 +0000 (09:02 -0700)] 
hs_pow: fix error path with outdated assumption

This error path with the "PoW cpuworker returned with no solution.
Will retry soon." message was usually lying. It's concerning
now because we expect to always find a solution no matter how
long it takes, rather than re-enter the solver repeatedly, so any
exit without a solution is a sign of a problem.

In fact when this error path gets hit, we are usually missing a
circuit instead because the request is quite old and the circuits
have been destroyed. This is not an emergency, it's just a sign
of client-side overload.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: swap out some comments
Micah Elizabeth Scott [Tue, 11 Apr 2023 23:45:21 +0000 (16:45 -0700)] 
hs_pow: swap out some comments

i think we're done with these?
and swap in a nonfatal assert to replace one of the comments.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: always give other events a chance to run between rend requests
Micah Elizabeth Scott [Tue, 11 Apr 2023 17:28:09 +0000 (10:28 -0700)] 
hs_pow: always give other events a chance to run between rend requests

This dequeue path has been through a few revisions by now, first
limiting us to a fixed number per event loop callback, then an
additional limit based on a token bucket, then the current version
which has only the token bucket.

The thinking behing processing multiple requests per callback was to
optimize our usage of libevent, but in effect this creates a
prioritization problem. I think even a small fixed limit would be less
reliable than just backing out this optimization and always allowing
other callbacks to interrupt us in-between dequeues.

With this patch I'm seeing much smoother queueing behavior when I add
artificial delays to the main thread in testing.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: modified approach to pqueue level thresholds
Micah Elizabeth Scott [Mon, 10 Apr 2023 22:27:33 +0000 (15:27 -0700)] 
hs_pow: modified approach to pqueue level thresholds

This centralizes the logic for deciding on these magic thresholds,
and tries to reduce them to just two: a min and max. The min should be a
"nearly empty" threshold, indicating that the queue only contains work
we expect to be able to complete very soon. The max level triggers a
bulk culling process that reduces the queue to half that amount.

This patch calculates both thresholds based on the torrc pqueue rate
settings if they're present, and uses generic defaults if the user asked
for an unlimited dequeue rate in torrc.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: faster hs_circuitmap lookup for rend in pow_worker_job_t
Micah Elizabeth Scott [Thu, 6 Apr 2023 21:27:18 +0000 (14:27 -0700)] 
hs_pow: faster hs_circuitmap lookup for rend in pow_worker_job_t

The worker job queue for hs_pow needs what's effectively a weak pointer
to two circuits, but there's not a generic mechanism for this in c-tor.
The previous approach of circuit_get_by_global_id() is straightforward
but not efficient. These global IDs are normally only used by the
control port protocol. To reduce the number of O(N) lookups we have over
the whole circuit list, we can use hs_circuitmap to look up the rend
circuit by its auth cookie.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: review feedback, use MAX for max_trimmed_effort
Micah Elizabeth Scott [Thu, 6 Apr 2023 16:29:37 +0000 (09:29 -0700)] 
hs_pow: review feedback, use MAX for max_trimmed_effort

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: Lower several logs from notice to info
Micah Elizabeth Scott [Thu, 6 Apr 2023 15:34:47 +0000 (08:34 -0700)] 
hs_pow: Lower several logs from notice to info

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: update_suggested_effort fix and cleanup
Micah Elizabeth Scott [Tue, 4 Apr 2023 03:02:17 +0000 (20:02 -0700)] 
hs_pow: update_suggested_effort fix and cleanup

This is trying to be an AIMD event-driven algorithm, but we ended up with
two different add paths with diverging behavior. This fix makes the AIMD
events more explicit, and it fixes an earlier behavior where the effort
could be decreased (by the add/recalculate branch) even when the pqueue
was not emptying at all. With this patch we shouldn't drop down to an
effort of zero as long as even low-effort attacks are flooding the
pqueue.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: client side effort adjustment
Micah Elizabeth Scott [Fri, 31 Mar 2023 20:36:58 +0000 (13:36 -0700)] 
hs_pow: client side effort adjustment

The goal of this patch is to add an additional mechanism for adjusting
PoW effort upwards, where clients rather than services can choose to
solve their puzzles at a higher effort than what was suggested in the
descriptor.

I wanted to use hs_cache's existing unreachability stats to drive this
effort bump, but this revealed some cases where a circuit (intro or
rend) closed early on can end up in hs_cache with an all zero intro
point key, where nobody will find it. This moves intro_auth_pk
initialization earlier in a couple places and adds nonfatal asserts to
catch the problem if it shows up elsewhere.

The actual effort adjustment method I chose is to multiply the suggested
effort by (1 + unresponsive_count), then ensure the result is at least
1. If a service has suggested effort of 0 but we fail to connect,
retries will all use an effort of 1. If the suggestion was 50, we'll try
50, 100, 150, 200, etc. This is bounded both by our client effort limit
and by the limit on unresponsive_count (currently 5).

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: leak fix, free the contents of pqueue entries in hs_pow_free_service_state
Micah Elizabeth Scott [Mon, 27 Mar 2023 23:18:26 +0000 (16:18 -0700)] 
hs_pow: leak fix, free the contents of pqueue entries in hs_pow_free_service_state

Asan catches this pretty readily when ending a service gracefully while
a DoS is in progress and the queue is full of items that haven't yet
timed out.

The module boundaries in hs_circuit are quite fuzzy here, but I'm trying
to follow the vibe of the existing hs_pow code.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: bump client-side effort limit from 500 to 10000
Micah Elizabeth Scott [Tue, 21 Mar 2023 19:56:10 +0000 (12:56 -0700)] 
hs_pow: bump client-side effort limit from 500 to 10000

500 was quite low, but this limit was helpful when the suggested-effort
estimation algorithm was likely to give us large abrupt increases. Now
that this should be fixed, let's allow spending a bit more time on the
client puzzles if it's actually necessary.

Solving a puzzle with effort=10000 usually completes within a minute
on my old x86_64 machine. We may want to fine tune this further, and it
should probably be made into a config option.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: stop having a "minimum effort", and let PoW effort start low
Micah Elizabeth Scott [Tue, 21 Mar 2023 19:28:23 +0000 (12:28 -0700)] 
hs_pow: stop having a "minimum effort", and let PoW effort start low

I don't think the concept of "minimum effort" is really useful to us,
so this patch removes it entirely and consequentially changes the way
that "total" effort is calculated so that we don't rely on any minimum
and we instead ramp up effort no faster than necessary.

If at least some portion of the attack is conducted by clients that
avoid PoW or provide incorrect solutions, those (potentially very
cheap) attacks will end up keeping the pqueue full. Prior to this patch,
that would cause suggested efforts to be unnecessarily high, because
rounding these very cheap requests up to even a minimum of 1 will
overestimate how much actual attack effort is being spent.

The result is that this patch is a simplification and it also allows a
slower start, where PoW effort jumps up either by a single unit or by an
amount calculated from actual effort in the queue.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agochanges: Ticket 40634 (hs_pow)
Micah Elizabeth Scott [Thu, 16 Mar 2023 15:44:15 +0000 (08:44 -0700)] 
changes: Ticket 40634 (hs_pow)

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agogitlab-ci: Try enabling GPL mode so we test hs_pow
Micah Elizabeth Scott [Thu, 9 Mar 2023 23:37:25 +0000 (15:37 -0800)] 
gitlab-ci: Try enabling GPL mode so we test hs_pow

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: Represent equix_solution as a byte array
Micah Elizabeth Scott [Wed, 15 Mar 2023 19:31:50 +0000 (12:31 -0700)] 
hs_pow: Represent equix_solution as a byte array

This patch is intended to clarify the points at which we convert
between the internal representation of an equix_solution and a portable
but opaque byte array representation.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agosandbox: allow stack mmap with prot_none
Micah Elizabeth Scott [Wed, 15 Mar 2023 18:52:45 +0000 (11:52 -0700)] 
sandbox: allow stack mmap with prot_none

This fixes a failure that was showing up on i386 Debian hosts
with sandboxing enabled, now that cpuworker is enabled on clients.
We already had allowances for creating threads and creating stacks
in the sandbox, but prot_none (probably used for a stack guard)
was not allowed so thread creation failed.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: Fix nonce cache entry leak
Micah Elizabeth Scott [Wed, 15 Mar 2023 17:41:22 +0000 (10:41 -0700)] 
hs_pow: Fix nonce cache entry leak

This leak was showing up in address sanitizer runs of test_hs_pow,
but it will also happen during normal operation as seeds are rotated.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: Define seed_head as uint8_t[4] instead of uint32_t
Micah Elizabeth Scott [Wed, 15 Mar 2023 03:45:36 +0000 (20:45 -0700)] 
hs_pow: Define seed_head as uint8_t[4] instead of uint32_t

This is more consistent with the specification, and it's much
less confusing with endianness. This resolves the underlying
cause of the earlier byte-swap. This patch itself does not
change the wire protocol at all, it's just tidying up the
types we use at the trunnel layer.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: Don't require uint128_t
Micah Elizabeth Scott [Tue, 14 Mar 2023 23:16:27 +0000 (16:16 -0700)] 
hs_pow: Don't require uint128_t

We were using a native uint128_t to represent the hs_pow nonce,
but as the comments note it's more portable and more flexible to
use a byte array. Indeed the uint128_t was a problem for 32-bit
platforms. This swaps in a new implementation that uses multiple
machine words to implement the nonce incrementation.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: unswap byte order of seed_head field
Micah Elizabeth Scott [Tue, 14 Mar 2023 22:25:12 +0000 (15:25 -0700)] 
hs_pow: unswap byte order of seed_head field

In proposal 327, "POW_SEED is the first 4 bytes of the seed used".

The proposal doesn't specifically mention the data type of this field,
and the code in hs_pow so far treats it as an integer but semantically
it's more like the first four bytes of an already-encoded little endian
blob. This leads to a byte swap, since the type confusion takes place
in a little-endian subsystem but the wire encoding of seed_head uses
tor's default of big endian.

This patch does not address the underlying type confusion, it's a
minimal change that only swaps the byte order and updates unit tests
accordingly. Further changes will clean up the data types.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: fix assert in services that receive unsolicited proof of work
Micah Elizabeth Scott [Tue, 14 Mar 2023 16:01:14 +0000 (09:01 -0700)] 
hs_pow: fix assert in services that receive unsolicited proof of work

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohs_pow: use the compiled HashX implementation
Micah Elizabeth Scott [Sat, 11 Mar 2023 01:23:06 +0000 (17:23 -0800)] 
hs_pow: use the compiled HashX implementation

Much faster per-hash, affects both verify and solve.
Only implemented on x86_64 and aarch64, other platforms
always use the interpreted version of hashx.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agotest_hs_pow: add test vectors for our hs_pow client puzzle
Micah Elizabeth Scott [Fri, 10 Mar 2023 22:09:45 +0000 (14:09 -0800)] 
test_hs_pow: add test vectors for our hs_pow client puzzle

This adds test vectors for the overall client puzzle at the
hs_pow and hs_cell layers.

These are similar to the crypto/equix tests, but they also cover
particulars of our hs_pow format like the conversion to byte arrays,
the replay cache, the effort test, and the formatting of the equix
challenge string.

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>
2 years agohashx: trim trailing whitespace
Micah Elizabeth Scott [Wed, 15 Mar 2023 21:55:17 +0000 (14:55 -0700)] 
hashx: trim trailing whitespace

Signed-off-by: Micah Elizabeth Scott <beth@torproject.org>