1. 18 Apr, 2020 2 commits
    • Jonathan Sailor's avatar
      update public README about supported platforms, compilers · fb0e252e
      Jonathan Sailor authored
      Summary:
      The README stated "folly requires gcc 5.1+ and a version of boost..." which
      some people might thing means that folly only supports gcc.
      
      Edit the README with more details about supported compilers and platforms.
      I tried to strike a balance between informative (FB uses folly on many
      platforms), conservative (the CMake build might not support all of them),
      and not mentioning specific versions (likely to get outdated.)
      
      Reviewed By: yfeldblum
      
      Differential Revision: D21093741
      
      fbshipit-source-id: 3a541f22b30736201361d2a10d861d61bd278e47
      fb0e252e
    • Scott Wolchok's avatar
      Convert throw in IPAddress to throw_exception · 4ee17e23
      Scott Wolchok authored
      Summary: Unbreak -fno-exceptions support for this file.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D21043400
      
      fbshipit-source-id: aceea45c32d143c723ad6bae68a7403f14d7e0f2
      4ee17e23
  2. 17 Apr, 2020 1 commit
  3. 16 Apr, 2020 4 commits
    • Andrew Huang's avatar
      Implement abstracted SSL session in folly · 52a8633f
      Andrew Huang authored
      Summary: Repurpose the existing `folly::ssl::SSLSession` to be an abstraction for SSL sessions, with the internal implementation hidden. The intention is to soon move to using these abstracted sessions instead of directly using OpenSSL sessions.
      
      Reviewed By: yfeldblum, mingtaoy
      
      Differential Revision: D20143848
      
      fbshipit-source-id: 01e175668c0afcf8b91d19a289368496717d3150
      52a8633f
    • Maged Michael's avatar
      RequestContext: Fix overwrite of null data · 0e29494c
      Maged Michael authored
      Summary:
      Fix a bug in overwrite of null data.
      
      Null old data should be erased so that the insert of the new data can succeed.
      
      Reviewed By: davidtgoldblatt
      
      Differential Revision: D20908574
      
      fbshipit-source-id: 6873d9c76daf1289f1d5b97b001c21473c41ea3f
      0e29494c
    • Dan Melnic's avatar
      Fix typo · e1cdd680
      Dan Melnic authored
      Summary:
      Fix typo
      
      (Note: this ignores all push blocking failures!)
      
      Reviewed By: mokomull
      
      Differential Revision: D21056053
      
      fbshipit-source-id: 3bf4295f9c6be1c50cdc64f6bbdf1b34cce6bece
      e1cdd680
    • Adam Simpkins's avatar
      getdeps: make several improvements to the eden manifest · d2a4722e
      Adam Simpkins authored
      Summary:
      - Indicate that the EDEN_VERSION_OVERRIDE environment variable affects the
        build.
      - Exclude eden/config.py from the shipit  path map, as this file is
        auto-generated in open source builds.
      - Include pexpect as a dependency, as this is needed for some of the
        integration tests.
      
      Reviewed By: genevievehelsel
      
      Differential Revision: D21000163
      
      fbshipit-source-id: 8eec378f66487229c995f637c4787eae530c7845
      d2a4722e
  4. 14 Apr, 2020 1 commit
    • Misha Shneerson's avatar
      Lift RequestContext root-id into task stats · 7469e0b5
      Misha Shneerson authored
      Summary: We want to use observer API to correlate tasks across same Thrift request. `RequestContext::getRootId` is the thing for it.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20600485
      
      fbshipit-source-id: 1a79bde0f6c5b3692b4fb3805c98f377b1b317c9
      7469e0b5
  5. 10 Apr, 2020 2 commits
    • Felix Handte's avatar
      Make the Zstd Codec use the Context Singletons · 0938cf41
      Felix Handte authored
      Summary: Use pre-existing cached local contexts, rather than creating our own.
      
      Reviewed By: bimbashrestha
      
      Differential Revision: D18890550
      
      fbshipit-source-id: d53d0bdf35ebfcfa5dfb45da6b99a886022d5f8b
      0938cf41
    • Dan Melnic's avatar
      Fix PollIoBackend compile error · d1ec5727
      Dan Melnic authored
      Summary:
      Fix PollIoBackend compile error
      
      (Note: this ignores all push blocking failures!)
      
      Reviewed By: yfeldblum, kevin-vigor
      
      Differential Revision: D20955224
      
      fbshipit-source-id: a2c7a34d9129cb282d3652607e79dcee1ce1cc78
      d1ec5727
  6. 09 Apr, 2020 7 commits
    • Wez Furlong's avatar
      getdeps: export fbsource commit date into environment · 4a29e9cb
      Wez Furlong authored
      Summary:
      This diff extracts the fbsource commit hash and the date of that
      commit and maintains that in place of just the commit hash that
      we were previously extracting.
      
      This data is exported into the environment that we pass on to
      builders so that it is available if they choose to use it.
      
      In a follow on diff I'll use this to default a version number
      in the watchman project.
      
      Reviewed By: fanzeyi
      
      Differential Revision: D20949666
      
      fbshipit-source-id: dc12bffe5f0efc4297b15ba0140c4c67a23ab0fd
      4a29e9cb
    • Kirk Shoop's avatar
      Add Support for nested MasterPtr and Cleanup tasks · 8045a2a0
      Kirk Shoop authored
      Summary:
      Allow a T that derives from EnableMasterFromThis<T> to use masterLockFromThis() to get a non-owning shared_ptr to this and to use masterRefFromThis() to get a MasterPtrRef<> from this.
      
      Adds MasterPtr::cleanup() that returns SemiFuture<Unit>. join() just does a blocking wait on the SemiFuture returned from cleanup().
      
      Allows a T to provide a T::cleanup() method that will be composed into the MasterPtr::cleanup() work.
      
      MasterPtr now uses SemiFuture<Unit> instead of Baton. This allows users of MasterPtr::cleanup() to compose cleanup work with other tasks.
      
      Andrii suggested that the cleanup feature be extracted out of MasterPtr
      
      Adds cleanup traits (that MasterPtr satisfies) and a Cleanup type that satisfies the cleanup traits and allows objects that are not heap-allocated to participate in structured concurrency by deriving from Cleanup.
      
      Reviewed By: andriigrynenko
      
      Differential Revision: D19584561
      
      fbshipit-source-id: aa2d608effe613ec84b08f902a1c61561f3458bb
      8045a2a0
    • Yedidya Feldblum's avatar
      Simplify some tests-in-loop in unit-tests · 4bce7f6d
      Yedidya Feldblum authored
      Summary: [Folly] Simplify a few cases of writing a loop to test each element of the loop in small-locks and spin-locks unit-tests.
      
      Reviewed By: markisaa
      
      Differential Revision: D20936029
      
      fbshipit-source-id: fd8a922d8e7b0a00ccd524c9905c641fd97a32f9
      4bce7f6d
    • Lewis Baker's avatar
      Add coroutine-frame memory allocation hooks to enable identifying async... · ddcf8ada
      Lewis Baker authored
      Add coroutine-frame memory allocation hooks to enable identifying async coroutine allocations in traces
      
      Summary:
      Customises the coroutine-frame allocation for all async coroutine types to call through
      the new `folly_coro_async_malloc` and `folly_coro_async_free` functions when heap-allocating
      coroutine frames.
      
      This should allow the identification of samples/traces that are calling into memory allocation
      for allocating coroutine frames and should enable better quantification of the CPU cycles
      and memory usage attributable to coroutine-frame allocations by filtering to samples that
      contain these functions in their stack-traces.
      
      Reviewed By: davidtgoldblatt
      
      Differential Revision: D20929042
      
      fbshipit-source-id: a94691377b92fab42736942ec8c7316c82a4205d
      ddcf8ada
    • Eric Niebler's avatar
      Fix the Folly OSS build by guarding the include of range-v3 header · 6d299ca1
      Eric Niebler authored
      Summary: Folly OSS does not list range-v3 as a dependency. As a result, test/RangeTest.cpp fails to compile because it tries to include a range-v3 header. This change gates the inclusion of the header with `__has_include`, making the dependency optional.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20839733
      
      fbshipit-source-id: 2d5e9c17427a0913f40f1ee80e868e27080a68f0
      6d299ca1
    • Dan Melnic's avatar
      Improve IOBuf::clone and IOBuf::cloneOne() perf · 96f9e38d
      Dan Melnic authored
      Summary: Improve IOBuf::clone and IOBuf::cloneOne() perf
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20882203
      
      fbshipit-source-id: ce37c2bf3c0fbdbe3c316856dc431a0108e4b9bf
      96f9e38d
    • Dan Melnic's avatar
      Fix folly::AsyncUDPSocket::gro_.value() check - GRO is enabled if the value is > 0 · dc0571b7
      Dan Melnic authored
      Summary:
      Fix folly::AsyncUDPSocket::gro_.value() check - GRO is enabled if the value is > 0
      
      (Note: this ignores all push blocking failures!)
      
      Reviewed By: kevin-vigor
      
      Differential Revision: D20930544
      
      fbshipit-source-id: 6672b65cafe3f9859f86ad34a6c3a2d65c2dc355
      dc0571b7
  7. 08 Apr, 2020 4 commits
    • Matthieu Martin's avatar
      Folly coro: avoid KeepAlive copy in promise · 458af540
      Matthieu Martin authored
      Summary: This prevents one acquire/release.
      
      Reviewed By: lewissbaker
      
      Differential Revision: D20924353
      
      fbshipit-source-id: 8c5135bd2ebc03b736b1ea3dbb385e01218cffbc
      458af540
    • Hasnain Lakhani's avatar
      Further improve sorted_vector_types standard compliance · 007c0045
      Hasnain Lakhani authored
      Summary:
      This is a follow up from D16427231; after testing the code in a similar situation on a mac (with `clang` and `libc++`) I realized there were still standards compliance issues.
      
      In that diff, the guarantee we provide is:
      
      ```
       *   - insert() single key variants, emplace(), and emplace_hint() only provide
       *     the strong exception guarantee (unchanged when exception is thrown) when
       *     std::is_nothrow_move_constructible<value_type>::value is true.
      ```
      
      The implementation is eventually backed by `std::vector`.
      
      The guarantees provided by `std::vector` in the standard are slightly weaker (https://en.cppreference.com/w/cpp/container/vector/insert):
      
      ```
      If an exception is thrown when inserting a single element at the end, and T is CopyInsertable or std::is_nothrow_move_constructible<T>::value is true, there are no effects (strong exception guarantee).
      ```
      
      i.e. it only provides this safety guarantee if the element is inserted at the end, and that's exactly what the new test shows.
      
      After discussion with nbronson we discovered that `libstdc++` and `libc++` are using different techniques to handle the corner case of `v.insert(0, v[1])` for `insert(iter, value_type const&)`. `libstdc++` makes the copy into a temporary, and then moves it in, so it does in fact provide a stronger guarantee than necessary. `libc++` checks the address of the reference it is given, and if it is in the moved range it adjusts it (!) and then uses the copy assignment operator. This means on copy assignment exception there will be a moved-from element at the desired index.
      
      Section 26.2.1 para 11 says that `insert` or `emplace` will have no effects if an exception is thrown, unless otherwise specified. 26.3.11.5 is the `vector` modifiers, but that only mentions `insert`. That means we can fix this by merely switch our uses of `std::vector::insert` to `std::vector::emplace` inside `sorted_vector_map/set`. On `libstdc++` this should't have any effect, since both insert and emplace make a temporary copy for the non-end insertion case (in different but similar code paths). On `libc++` this will avoid the address-adjusting trick and use the temporary copy technique like in `libstdc++`.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20785383
      
      fbshipit-source-id: 290c3c7c061dedf1660da9534f4b9cc338da6224
      007c0045
    • Matthieu Martin's avatar
      Folly coro: missing executor move · f2fa1176
      Matthieu Martin authored
      Summary: This should reduce refcounting
      
      Reviewed By: lewissbaker
      
      Differential Revision: D20911114
      
      fbshipit-source-id: be941a5e0a095652c916e4704b0dd29874e0979d
      f2fa1176
    • Lee Howes's avatar
      Deprecate collectXSemiFuture · ff22ce9a
      Lee Howes authored
      Summary:
      Migration from Future-returning executor-erasing collectX forms to
      SemiFuture-returning forms, that are less risky in particular with coroutines.
      
      Earlier changes added collectXSemiFuture and collectXUnsafe as a migration
      path. We then migrated collectX callsites to collectXSemiFuture or
      collectXUnsafe and switched the implementation of collectX to the SemiFuture
      form.
      
      This diff adds deprecation flag to collectXSemiFuture during the migration to
      collectX and and removes from folly tests that are not specific to testing those
      operations.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20841855
      
      fbshipit-source-id: 30818711362c88c3296cfc976cd75fbd94e1c15c
      ff22ce9a
  8. 07 Apr, 2020 6 commits
    • Nathan Bronson's avatar
      support VS2019 in UninitializedMemoryHacks, fix VS2017 · b077851b
      Nathan Bronson authored
      Summary:
      VS2019 changes the internal implementation of basic_string and vector.
      This diff adds support for the new internals, and fixes a linkage
      problem on VS2017.  It also adds the UninitializedMemoryHacksTest to
      the getdeps-built tests.
      
      For basic_string a single version handles both old and new.
      basic_string::_Eos changed from public to private, so code that uses
      the template specialization hack to invoke it when it is private will
      work for the older public method as well.
      
      vector does not have any suitable internal methods, so we need to adapt
      to the new internal structure.
      
      This diff fixes the issues addressed by
      https://github.com/facebook/folly/pull/1345 , but uses an alternate
      strategy to avoid reinterpret_cast.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20838799
      
      fbshipit-source-id: eba7db2bd6feade1349d51be224c481a9156732b
      b077851b
    • Zeyi (Rice) Fan's avatar
      respect DISABLED flag reported by ctest · a9d3606b
      Zeyi (Rice) Fan authored
      Reviewed By: simpkins
      
      Differential Revision: D20885314
      
      fbshipit-source-id: 8c3a5ccbfd6630107b421b0d6953f17a93da2412
      a9d3606b
    • Maged Michael's avatar
      RequestContext: Optimize copying · 7e2877a3
      Maged Michael authored
      Summary:
      Reduce the cost of copying by keeping a vector of cleared RequestData references instead of keeping a hash map of the state of all RequestData references.
      
      Also, added FOLLY_ALWAYS_INLINE to functions called in copying of request contexts.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20863318
      
      fbshipit-source-id: 29cc38ac6e8abde3acaffcf8fa4d1e7ccbd45e87
      7e2877a3
    • Maged Michael's avatar
      SingleWriterFixedHashMap: Optimize copying · a2c4f8cf
      Maged Michael authored
      Summary: Use memcpy for copying maps with the same capacity instead of rehashing.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20863257
      
      fbshipit-source-id: 11e52f9f2246440fb724a94c2611e44e253e462d
      a2c4f8cf
    • Kirk Shoop's avatar
      add support for adopting a shared_ptr · 2f75edd3
      Kirk Shoop authored
      Summary:
      When incrementally adding in MasterPtr to an existing code-base there are some shared_ptr<> (eg. returned from factories) that need to be stored in MasterPtr.
      
      since unique_ptr converts to shared_ptr, just take and store a shared_ptr
      
      Yes, this removes the guarantee that ~T() will run in join(). I am open to suggestions
      
      Reviewed By: andriigrynenko
      
      Differential Revision: D19583122
      
      fbshipit-source-id: 3daf0436d56b9c396b5e82d397ebaf93ed1a2a2d
      2f75edd3
    • Kirk Shoop's avatar
      add EnableMasterFromThis · 1f5ce2de
      Kirk Shoop authored
      Summary:
      when T derives from EnableSharedFromThis<T> and T is placed in a MasterPtr<T> then users of T have access to MasterPtr<T> functionality.
      
      `EnableSharedFromThis<T>::masterLockFromThis()`
      `EnableSharedFromThis<T>::masterRefFromThis()`
      
      Reviewed By: andriigrynenko
      
      Differential Revision: D19583025
      
      fbshipit-source-id: ee12e9de30fd844b5be36c39d7e1ade830e27bbb
      1f5ce2de
  9. 06 Apr, 2020 3 commits
    • GaneshRapolu's avatar
      Fix data race/UB in RCU documentation example (#1348) · 98a70c4d
      GaneshRapolu authored
      Summary:
      The read of globalConfigData outside of sm.lock() races with any other writer that is modifying
      globalConfigData inside of sm.lock(). This is a documentation only change.
      Pull Request resolved: https://github.com/facebook/folly/pull/1348
      
      Reviewed By: paulmckrcu
      
      Differential Revision: D20864073
      
      Pulled By: yfeldblum
      
      fbshipit-source-id: 31b7ed469716acb35913df9a71585c2a59e50bea
      98a70c4d
    • Maged Michael's avatar
      RequestContextBenchmark: Update benchmarks and results · 674c2b7f
      Maged Michael authored
      Summary:
      Add microbenchmark for ShallowCopyRequestContextScopeGuard that involves copying RequestContext-s that hold references to multiple RequestData objects.
      
      Also, removed microbenchmark results for less common patterns, and updated results after switching to the hazard pointer-based implementation (D19145252).
      
      Reviewed By: A5he
      
      Differential Revision: D20862753
      
      fbshipit-source-id: b4fc36a548761d4281c7c55ec97f731c7b4bc98d
      674c2b7f
    • Yedidya Feldblum's avatar
      Revise references to TAsyncSocket · b5bf5677
      Yedidya Feldblum authored
      Summary: [Folly] Revise references to `TAsyncSocket`.
      
      Differential Revision: D20826538
      
      fbshipit-source-id: 4448f19d1cc64b88dbccc1eda2be63355d15bf42
      b5bf5677
  10. 05 Apr, 2020 1 commit
    • Nathan Bronson's avatar
      work around a VS2019 compiler crash · 9da28a94
      Nathan Bronson authored
      Summary:
      This diff moves a struct definition out from the inside of
      a closure, where it seems to have been causing a compilation issue
      under VS2019.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20845042
      
      fbshipit-source-id: 7b32c898490a8ba59f5e77f21e890097d9069a4f
      9da28a94
  11. 03 Apr, 2020 4 commits
  12. 02 Apr, 2020 3 commits
    • Mat Hostetter's avatar
      Work around spurious -Werror=array-bounds error in gcc-9.3. · a5909bd1
      Mat Hostetter authored
      Summary:
      gcc-9.3 complains about folly::Format:
      
      ```
      array subscript -1 is outside array bounds of ‘char [69]’
      ```
      
      But the warning is incorrect; my guess is that it is confused because
      it doesn't realize that higher-level logic guarantees that integer
      formatting will run out of digits before it runs out of buffer.
      
      Changing some code from `array + x` to `&array[x]` works around it.
      
      Reviewed By: pixelb
      
      Differential Revision: D20694399
      
      fbshipit-source-id: 1176858054cdec9e415de4829371647958955103
      a5909bd1
    • Alexander Mols's avatar
      Fix bug in optimizing module loader for coverage collection · cc9056ea
      Alexander Mols authored
      Summary:
      In coverage collection mode a special module loader is prepended to
      `sys.meta_path`. In very specific conditions this module loader can end up
      returning a loader pointing to a _completely wrong module_. When importing
      symbols from the wrong module errors occur.
      
      The conditions to trigger the bug are:
      
      - running in coverage collection mode, enabling the custom loader
      - the test binary is a zip (e.g. par_style=fastzip)
      - having a module name where the end part matches the name of a builtin Python
        module
      
      When these conditions were met, the special loader would return the builtin
      Python module instead of the expected module. E.g. when loading a module like
      `myapp.somemod.platform` in a zip style binary.
      
      The custom loader first calls `imp.find_module()` to find the module it wants
      to return a wrapped loader for. This fails for modules included in the test
      binary, because the builtin `imp` module can not load from zips. This was the
      trigger leading to the call to the buggy code.
      
      When the initial call to `imp.find_module()` failed, the custom loader would
      try a second call, asking the internal loader to this time try any path on
      `sys.path`. For most module names this call would also fail, making the custom
      loader return `None`, after which Python tries other loaders on `sys.path`.
      However, when the final part of the module that was asked to load matches the
      name of a Python builtin module, then the second call to the `imp` module would
      succeed, returning a loader for the builtin module. E.g. `platform` when asking
      for `myapp.somemod.platform`.
      
      This diff fixes the issue by removing the broken second call to the internal
      loader. This will never have worked, we just have not triggered or noticed
      triggering the wrong loading before.
      
      Differential Revision: D20798119
      
      fbshipit-source-id: dffb54e308106a81af21b63c5ee64c6ca2041920
      cc9056ea
    • Luca Niccolini's avatar
      upgrade openssl to 1.1.1f · b960056c
      Luca Niccolini authored
      Summary:
      https://www.openssl.org/source/openssl-1.1.1b.tar.gz is gone
      
      changelog:
      https://www.openssl.org/news/openssl-1.1.1-notes.html
      
      Reviewed By: udippant
      
      Differential Revision: D20810020
      
      fbshipit-source-id: 0ed385f49b2187ec149defd79feb86e2c8b492d2
      b960056c
  13. 01 Apr, 2020 2 commits
    • Lee Howes's avatar
      Replace default executor argument in FutureDAG · 5a67fac7
      Lee Howes authored
      Summary:
      Change to SemiFuture returning collect, which checks for nullptr passed to via, breaks this test which produced a default nullptr.
      
      Instead remove default and force passing of a valid executor.
      
      Reviewed By: yfeldblum
      
      Differential Revision: D20795552
      
      fbshipit-source-id: 5411fea910d9f85eb5a4ba825a1cfd48a72b8a44
      5a67fac7
    • Dan Melnic's avatar
      Add support for specifying which fatal signals to handle · c1beec58
      Dan Melnic authored
      Summary: Add support for specifying which fatal signals to handle
      
      Reviewed By: simpkins
      
      Differential Revision: D20672281
      
      fbshipit-source-id: 16696abcf551efcd932f5b56b336d6c5bc0d7a55
      c1beec58