Close Menu

    Subscribe to Updates

    Get the latest creative news from FooBar about art, design and business.

    What's Hot

    Senate passes Trump’s massive budget bill, with no mentions of crypto or Bitcoin

    July 1, 2025

    US sanctions Filipino company behind pig-butchering tech

    July 1, 2025

    Crypto cases Trump’s SEC has paused and dismissed in 2025

    July 1, 2025
    Facebook X (Twitter) Instagram
    Block Buzz News
    • Bitcoin
    • Coinbase
      • Litecoin
      • Altcoins
    • Blockchain
    • Crypto
    • Ethereum
    • Lithosphere News Releases
    Facebook X (Twitter) Instagram YouTube
    Block Buzz News
    Home » Solidity Bugfix Release | Ethereum Foundation Blog
    Ethereum

    Solidity Bugfix Release | Ethereum Foundation Blog

    Sophia BrownBy Sophia BrownJanuary 30, 2025No Comments3 Mins Read
    Share
    Facebook Twitter LinkedIn Pinterest Email


    The latest version 0.4.25 release of Solidity fixes
    two important bugs.
    Another important bug has already been fixed in version 0.4.22 but it was only discovered recently that the bug existed.

    Note that the Ethereum Foundation runs a bounty program for the code generator part of Solidity.

    Cleanup of Exponent in Exponentiation

    • Likelihood of occurrence: very low
    • Exploitability: high
    • Discoverability by tests: low
    • Fixed in version: 0.4.25

    Summary: Using short types in the exponent of an exponentiation operation can lead to invalid results.

    The Solidity language allows integer types that are shorter than 256 bits, even though the Ethereum Virtual Machine
    only knows types of exactly 256 bits. Because of that, higher order bits need to be set to zero from time to time.
    For many operations, it is not relevant whether those bits are set to zero or not (addition is one example).
    Because of that, the Solidity compiler delays this cleanup until it is needed in order to save gas.

    In the very special circumstance that the exponent of the ** operator has a type that is shorter
    than 256 bits, but not shorter than the type of the base and contains dirty higher order bits,
    this can lead to an incorrect result. Note that literal exponents like in x ** 2 as well as
    the case where the type of the base is uint256 or int256 are unaffected.

    Note that a function parameter can have dirty higher order bits if called by a malicious entity,
    and the same is true for data returned from functions of contracts deployed by malicious entities.

    After having screened a large number of contracts, we deem this bug to affect only a very tiny number of
    smart contracts, if any at all, because the regular uses of the exponentiation operator do not lead to the bug.

    This bug was found by nweller.

    Memory Corruption in Multi-Dimensional Array Decoder

    • Likelihood of occurrence: low
    • Exploitability: medium
    • Discoverability by tests: high
    • Introduced in version: 0.1.4
    • Fixed in version: 0.4.22

    Summary: Calling functions of other contracts that return multi-dimensional fixed-size arrays results in memory corruption.

    If Solidity code calls a function that returns a multi-dimensional fixed-size array,
    the returned ABI-encoded data has to be converted to Solidity’s internal representation
    of arrays. In Solidity, multi-dimensional arrays are implemented as arrays of
    memory pointers, while in the ABI, the data is encoded inline.
    The decoder did not take this difference into account with the result that the returned
    elements are interpreted as memory pointers and thus can cause memory
    corruption if the return values are accessed. Calling functions with multi-dimensional
    fixed-size array arguments is unaffected as is returning fixed-size arrays from function calls
    if they are not used in a Solidity contract.
    The bug is only in the component that decodes a multi-dimensional fixed-size array
    that is returned from a function call from Solidity.

    This bug was found by jmahhh.

    Invalid Encoding of Structs in Events

    • Likelihood of occurrence: low
    • Exploitability: low
    • Discoverability by tests: high
    • Introduced in version: 0.4.17
    • Fixed in version: 0.4.25

    Summary: Structs as event parameters are not handled properly.

    Structs were not meant to be supported as event parameters without the new ABI encoder.
    The compiler did accept them nevertheless, but encoded their memory address instead of their actual value.
    Even with the new ABI encoder, structs cannot be indexed event parameters.

    Now, structs are properly disallowed for the old encoder and if they are indexed also for the new encoder.



    Source link

    Share. Facebook Twitter Pinterest LinkedIn Tumblr Email
    Sophia Brown

    Related Posts

    Katana mainnet launch nears as pre-deposit closes with $200M in active deposits

    June 30, 2025

    World Experience: Updates from the Next Billion Fellowship

    June 24, 2025

    Checkpoint #4: Berlinterop | Ethereum Foundation Blog

    June 23, 2025

    Checkpoint #4: Berlinterop | Ethereum Foundation Blog

    June 23, 2025
    Add A Comment
    Leave A Reply Cancel Reply

    Top Posts

    iDEGEN price prediction: Is this the AI agent token to buy?

    January 24, 2025

    Gate.io to list CYBRO token on Dec 14 after $7M presale success

    January 24, 2025

    🐍 Lunar New Year Scratch & Win Campaign Is Live with a Grand Prize of 8,888,888 VERSE (~$1800) | by Bitcoin.com | Jan, 2025

    January 24, 2025

    Trade VERSE/USDT on KuCoin to Earn your Share of $8400 in Rewards! | by Bitcoin.com | Jan, 2025

    January 24, 2025
    Don't Miss
    Crypto

    Senate passes Trump’s massive budget bill, with no mentions of crypto or Bitcoin

    By James WilsonJuly 1, 2025

    Trump’s “big, beautiful bill” passed the Senate, but without any provisions related to the crypto…

    US sanctions Filipino company behind pig-butchering tech

    July 1, 2025

    Crypto cases Trump’s SEC has paused and dismissed in 2025

    July 1, 2025

    Not all Bitcoin holding firms will avoid death spiral

    July 1, 2025
    Stay In Touch
    • Facebook
    • Twitter
    • Pinterest
    • Instagram
    • YouTube
    • Vimeo

    Subscribe to Updates

    Get the latest creative news from SmartMag about art & design.

    About Us

    BlockBuzzNews: Your daily dose of the latest in cryptocurrency trends, insights, and updates!

    Our Picks

    Senate passes Trump’s massive budget bill, with no mentions of crypto or Bitcoin

    July 1, 2025

    US sanctions Filipino company behind pig-butchering tech

    July 1, 2025

    Crypto cases Trump’s SEC has paused and dismissed in 2025

    July 1, 2025
    Most Popular

    iDEGEN price prediction: Is this the AI agent token to buy?

    January 24, 2025

    Gate.io to list CYBRO token on Dec 14 after $7M presale success

    January 24, 2025

    🐍 Lunar New Year Scratch & Win Campaign Is Live with a Grand Prize of 8,888,888 VERSE (~$1800) | by Bitcoin.com | Jan, 2025

    January 24, 2025

    Type above and press Enter to search. Press Esc to cancel.