[libcamera-devel] [PATCH] libamera: pipeline: rkisp1: timeline: Fix compilation with gcc-[56]

Kieran Bingham kieran.bingham at ideasonboard.com
Tue Oct 15 12:38:35 CEST 2019


Re $SUBJECT:

s/libamera/libcamera/

But I'm too late... it's already merged. Ooops oh well.

Perhaps we should add some sort of commit title checking to
checkstyle.py ... but that might be overkill.

Getting spell checking in there should cover it.

--
Kieran


On 11/10/2019 15:30, Laurent Pinchart wrote:
> With gcc 5 and 6, insertion in a std::multimap copies the pair passed as
> an argument to the insert() method. As the mapped type is a non-copyable
> std::unique_ptr<>, this fails to compile.
> 
> Compilation with newer gcc versions succeed due to support for C++-17
> and the fix described in https://cplusplus.github.io/LWG/issue2354. To
> support gcc 5 and 6, fix the issue by using std::multimap::emplace().
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
>  src/libcamera/pipeline/rkisp1/timeline.cpp | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/src/libcamera/pipeline/rkisp1/timeline.cpp b/src/libcamera/pipeline/rkisp1/timeline.cpp
> index b98a16689fa9..f6c6434d7b53 100644
> --- a/src/libcamera/pipeline/rkisp1/timeline.cpp
> +++ b/src/libcamera/pipeline/rkisp1/timeline.cpp
> @@ -123,7 +123,7 @@ void Timeline::scheduleAction(std::unique_ptr<FrameAction> action)
>  			<< ", run now " << utils::time_point_to_string(now);
>  		action->run();
>  	} else {
> -		actions_.insert({ deadline, std::move(action) });
> +		actions_.emplace(deadline, std::move(action));
>  		updateDeadline();
>  	}
>  }
> 

-- 
Regards
--
Kieran


More information about the libcamera-devel mailing list