[ 
https://issues.apache.org/jira/browse/IMPALA-10391?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Joe McDonnell resolved IMPALA-10391.
------------------------------------
    Fix Version/s: Impala 4.0
       Resolution: Fixed

> LIRS cache edge case where there is exactly one unprotected element
> -------------------------------------------------------------------
>
>                 Key: IMPALA-10391
>                 URL: https://issues.apache.org/jira/browse/IMPALA-10391
>             Project: IMPALA
>          Issue Type: Bug
>          Components: Backend
>    Affects Versions: Impala 4.0
>            Reporter: Joe McDonnell
>            Assignee: Joe McDonnell
>            Priority: Major
>             Fix For: Impala 4.0
>
>
> The fix for IMPALA-10127 introduced an issue in this code:
> {noformat}
>           // If an UNPROTECTED entry is not on the recency list, then its new 
> reuse
>           // distance is longer than any of the PROTECTED entries. So, it 
> remains
>           // an UNPROTECTED entry, but it should be added back to the recency 
> list and
>           // readded as the most recent entry on the unprotected list.
>           MoveToRecencyListBack(&tstate, e, false);
>           RemoveFromUnprotectedList(e);
>           AddToUnprotectedList(e);{noformat}
> RemoveFromUnprotectedList would detect that this is the last unprotected 
> entry and clear unprotected_list_front_. This doesn't decrement 
> num_unprotected_ to 0, so when AddToUnprotectedList is called, it doesn't set 
> unprotected_list_front_ when it adds the element back.
> This only applies when there is exactly one entry on the unprotected list. 
> This can be fixed by either decrementing/incrementing the counters to match 
> up with other locations or by skipping this code when num_unprotected_ == 1.



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to