1. 21 Sep, 2018 4 commits
  2. 20 Sep, 2018 12 commits
  3. 19 Sep, 2018 24 commits
    • Lioncash's avatar
      control_metadata: Remove unnecessary else within GetLanguageEntry() · 3146502a
      Lioncash authored
      There's no need to indent the code here, given the if case contains a
      return statement at the end of it.
      3146502a
    • Lioncash's avatar
      control_metadata: Move language name array definition to the cpp file · 05d49962
      Lioncash authored
      This was used in two different translation units
      (deconstructed_rom_directory and patch_manager). This means we'd be
      pointlessly duplicating the whole array twice due to it being defined
      within the header.
      05d49962
    • MerryMage's avatar
      arm_dynarmic: Support BKPT instruction · 3b4a1582
      MerryMage authored
      3b4a1582
    • MerryMage's avatar
      externals: Update dynarmic to 171d116 · 321eb0b6
      MerryMage authored
      171d116 A64: Implement SCVTF, UCVTF (vector, fixed-point), scalar variant
      f221bb0 emit_x64_floating_point: Reduce fallback LUT code in EmitFPToFixed
      eb123e2 A64: Implement FCVTZS, FCVTZU, UCVTF, SCVTF (vector, fixed-point), vector variant
      487d37a A64: Implement UQSHL's vector immediate and register variants
      f698933 ir: Add opcodes for unsigned saturating left shifts
      7148e66 A64/translate/impl: Make signatures consistent for unimplemented by-element SIMD variants
      fdde4ca A64: Implement BRK
      b1490db A64/imm: Add full range of comparison operators to Imm template
      1ec40ef IR: Add fbits argument to FPVectorFrom{Signed,Unsigned}Fixed
      d6d5e98 A64: Implement SCVTF, UCVTF (scalar, fixed-point)
      6513595 opcodes.inc: Align columns to a tabstop of 4
      6b0d2b5 IR: Add fbits argument to FixedToFP-related opcodes
      c4b3831 A64: Implement SQSHL's vector immediate variant
      e0d8d2d A64: Implement SQSHL's vector register variant
      5327625 ir: Add opcodes for left signed saturated shifts
      9705252 branch: Make variables const where applicable
      650946e move_wide: Make variables const where applicable
      62b3a6d load_store_register_unprivileged: Make variables const where applicable
      3add1c7 load_store_register_immediate: Place conditional bodies on their own line
      2fc4088 load_store_load_literal: Make variables const where applicable
      b2c1462 data_processing_logical: Move datasize declarations after early-exit conditionals
      028028f data_processing_conditional_select: Make variables const where applicable
      c66042d data_processing_addsub: Move datasize declarations after early-exit conditionals
      6bc546e data_processing_bitfield: Move datasize variables after early-exit conditionals
      2aad5fa A64: Implement CLS's vector variant
      6c877ff emit_x64_vector: Make EmitVectorUnsignedSaturatedAccumulateSigned() internally linked
      4b5926d perf_map: Use std::string_view instead of std::string for PerfMapRegister()
      7445947 A64: Implement SQRDMULH (vector), vector variant
      03b80f2 A64: Implement SQDMULL (vector), vector variant
      4a2c596 IR: Add VectorSignedSaturatedDoublingMultiplyLong
      59dc33e emit_x64_vector: Changes to VectorSignedSaturatedDoublingMultiply
      bbaebeb IR: Implement Vector{Signed,Unsigned}Multiply{16,32}
      baac5a8 backend_x64/a64_interface: Re-enable the constant folding pass
      e78ca19 emit_x64_vector_floating_point: Hardware FMA implementation for RSqrtStepFused
      8a5ae9a emit_x64_vector_floating_point: Hardware FMA implementation of FPVectorRecipStepFused
      39818f9 emit_x64_floating_point: Hardware FMA implementation of FPRSqrtStepFused
      3d0a0b4 emit_x64_floating_point: Hardware FMA implementation of FPRecipStepFused{32,64}
      2293dff emit_x64_vector: SSE implementation of VectorSignedSaturatedAccumulateUnsigned{8,16,32}
      2047683 emit_x64_vector: Correct static asserts for < 64-bit type checks in saturated accumulate fallbacks
      55e9e40 emit_x64_vector: EmitVectorSignedSaturatedAccumulateUnsigned64: SSE implementation
      1076651 emit_x64_vector: Simplify fpsr_qc related code
      4039030 A64: Implement CLZ's vector variant
      0bb908f ir: Add opcodes for vector CLZ operations
      3b13259 A64/translate: VectorZeroUpper for V(64) stores
      1931d44 simd_two_register_misc: FNEG (vector) with Q == 0 had dirty upper
      a0790f0 emit_x64_vector: Remove unnecessary [[maybe_unused]] attributes
      b0e1eb5 A64: Implement USQADD's scalar and vector variants
      28424c7 ir: Add opcodes form unsigned saturated accumulations of signed values
      9923ea0 A64: Implement SUQADD's scalar and vector variants
      4c0adbb ir: Add opcodes for signed saturated accumulations of unsigned values
      799bfed A64: Implement SMLAL{2}, SMLSL{2}, UMLAL{2}, and UMLSL{2}'s vector by-element variants
      94451ec A64: Implement UMULL{2}'s vector by-element variant
      45867de A64: Implement SMULL{2}'s vector by-element variant
      0235793 ir/value: Replace includes with forward declarations
      450f721 ir/cond: Migrate to C++17 nested namespace specifiers
      e649988 CMakeLists: Add missing cond.h header to file listing
      d20e769 A64: Implement URSQRTE
      4f3bde5 ir: Add opcodes for performing unsigned reciprocal square root estimates
      cfeeaec A64: Implement URECPE
      622b60e ir: Add opcodes for unsigned reciprocal estimate
      d17599a Update Xbyak to 5.71
      f7c26e9 Squashed 'externals/xbyak/' changes from 671fc805..1de435ed
      8782b69 travis: Make macOS build with Xcode 9.4.1
      b575b23 A64: Implement SQNEG's scalar and vector variant
      06062a9 A64: Add opcodes for signed saturating negations
      1c40579 emit_x64_vector: Simplify "position == 0" case for EmitVectorExtract()
      e335050 emit_x64_vector: Simplify "position == 0" case for EmitVectorExtractLower()
      8b13421 A64: Implement SQDMULH's by-element scalar variant
      9122a6e A64: Implement SQDMULH's by-element vector variant
      176e60e backend/x64: Do not clear fast_dispatch_table if not enabled
      321eb0b6
    • Lioncash's avatar
      xts_archive: Remove unused variables from CalculateHMAC256() · 2e5f0e50
      Lioncash authored
      These variables aren't used, which still has an impact, as std::vector
      cannot be optimized away by the compiler (it's constructor and
      destructor are both non-trivial), so this was just wasting memory.
      2e5f0e50
    • Lioncash's avatar
      xts_archive: Make AsNCA() return a std::unique_ptr instead of a std::shared_ptr · 27521838
      Lioncash authored
      std::shared_ptr isn't strictly necessary here and is only ever used in
      contexts where the object doesn't depend on being shared. This also
      makes the interface more flexible, as it's possible to create a
      std::shared_ptr from a std::unique_ptr (std::shared_ptr has a
      constructor that accepts a std::unique_ptr), but not the other way
      around.
      27521838
    • Lioncash's avatar
      nax: Avoid re-parsing NAX data with GetFileType() · 45195a51
      Lioncash authored
      An instance of the NAX apploader already has an existing NAX instance in
      memory. Calling directly into IdentifyType() directly would re-parse the
      whole file again into yet another NAX instance, only to toss it away
      again.
      
      This gets rid of unnecessary/redundant file parsing and allocations.
      45195a51
    • Lioncash's avatar
      nax: Avoid unnecessary calls to AsNCA() in IdentifyType() · c8c41056
      Lioncash authored
      AsNCA() allocates an NCA instance every time it's called. In the current
      manner it's used, it's quite inefficient as it's making a redundant
      allocation.
      
      We can just amend the order of the conditionals to make it easier to
      just call it once.
      c8c41056
    • Lioncash's avatar
      xts_archive: Ensure NAX's type member is always initialized · f272261c
      Lioncash authored
      Ensures that the member always has a deterministic value.
      f272261c
    • Lioncash's avatar
      xts_archive: Amend initializer order of NAX's constructor · 92a98a8b
      Lioncash authored
      Orders the initializer list in the same order the members would be
      initialized. Avoids compiler warnings.
      92a98a8b
    • David's avatar
      Reworked incorrect nifm stubs (#1355) · 0432af5a
      David authored
      * Reworked incorrect nifm stubs
      
      Need confirmation on `CreateTemporaryNetworkProfile`, unsure which game uses it but according to reversing. It should return a uuid which we currently don't do.
      
      Any 0 client id is considered an invalid client id.
      
      GetRequestState 0 is considered invalid.
      
      * Fixups for nifm
      0432af5a
    • bunnei's avatar
      Merge pull request #1356 from degasus/hotfix · 52fb86c6
      bunnei authored
      gl_rasterizer: Fix StartAddress handling with indexed draw calls.
      52fb86c6
    • bunnei's avatar
      Merge pull request #1359 from ogniK5377/nes · 8dff92c5
      bunnei authored
      Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevision
      8dff92c5
    • bunnei's avatar
      Merge pull request #1353 from ogniK5377/remove-MakeBuilder · 5fbc3542
      bunnei authored
      Removed the use of rp.MakeBuilder in the yuzu codebase
      5fbc3542
    • David Marcec's avatar
      Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevision · cbc7ad8f
      David Marcec authored
      With these, `Nintendo Entertainment System - Nintendo Switch Online` loads
      cbc7ad8f
    • Zach Hilman's avatar
      savedata_factory: Add TemporaryStorage SaveDataType · dfaea55b
      Zach Hilman authored
      Seems to be used by NSO NES Emulator
      dfaea55b
    • Markus Wick's avatar
      gl_rasterizer: Fix StartAddress handling with indexed draw calls. · f465e4aa
      Markus Wick authored
      We uploaded the wrong data before. So the offset on the host GPU pointer may work for the first vertices, the last ones run out bounds.
      Let's just offset the upload instead.
      f465e4aa
    • David Marcec's avatar
      08819ec7
    • David Marcec's avatar
      Removed the use of rp.MakeBuilder · 6a0612f2
      David Marcec authored
      Due to keeping the code style consistent in the yuzu codebase. `rb = rp.MakeBuilder(...)` was replaced with `rb{ctx, ...}`
      6a0612f2
    • Lioncash's avatar
      ring_buffer: Use std::atomic_size_t in a static assert · ab6dfa4f
      Lioncash authored
      Avoids the need to repeat "std::" twice
      ab6dfa4f
    • Lioncash's avatar
      ring_buffer: Use std::hardware_destructive_interference_size to determine... · c51f8563
      Lioncash authored
      ring_buffer: Use std::hardware_destructive_interference_size to determine alignment size for avoiding false sharing
      
      MSVC 19.11 (A.K.A. VS 15.3)'s C++ standard library implements P0154R1
      (http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2016/p0154r1.html)
      which defines two new constants within the <new> header, std::hardware_destructive_interference_size
      and std::hardware_constructive_interference_size.
      
      std::hardware_destructive_interference_size defines the minimum
      recommended offset between two concurrently-accessed objects to avoid
      performance degradation due to contention introduced by the
      implementation (with the lower-bound being at least alignof(max_align_t)).
      In other words, the minimum offset between objects necessary to avoid
      false-sharing.
      
      std::hardware_constructive_interference_size on the other hand defines
      the maximum recommended size of contiguous memory occupied by two
      objects accessed wth temporal locality by concurrent threads (also
      defined to be at least alignof(max_align_t)). In other words the maximum
      size to promote true-sharing.
      
      So we can simply use this facility to determine the ideal alignment
      size. Unfortunately, only MSVC supports this right now, so we need to
      enclose it within an ifdef for the time being.
      c51f8563
    • bunnei's avatar
      Merge pull request #1348 from ogniK5377/GetImageSize · b33ce787
      bunnei authored
      Implemented IProfile::GetImageSize
      b33ce787
    • bunnei's avatar
      Merge pull request #1319 from lioncash/audio · d85130d7
      bunnei authored
      audio_core: Replace includes with forward declarations where applicable.
      d85130d7
    • bunnei's avatar
      Merge pull request #1351 from ogniK5377/GetDefaultDisplayResolution · c9942fe4
      bunnei authored
      Implemented GetDefaultDisplayResolution
      c9942fe4