1. 26 Nov, 2017 20 commits
  2. 25 Nov, 2017 16 commits
  3. 24 Nov, 2017 4 commits
    • James Almer's avatar
      31de45d2
    • Philip Langdale's avatar
      avcodec/nvdec: Round up odd width/height values · 4186a77f
      Philip Langdale authored
      nvdec will not produce odd width/height output, and while this is
      basically never an issue with most codecs, due to internal alignment
      requirements, you can get odd sized jpegs.
      
      If an odd-sized jpeg is encountered, nvdec will actually round down
      internally and produce output that is slightly smaller. This isn't
      the end of the world, as long as you know the output size doesn't
      match the original image resolution.
      
      However, with an hwaccel, we don't know. The decoder controls
      the reported output size and the hwaccel cannot change it. I was
      able to trigger an error in mpv where it tries to copy the output
      surface as part of rendering and triggers a cuda error because
      cuda knows the output frame is smaller than expected.
      
      To fix this, we can round up the configured width/height passed
      to nvdec so that the frames are always at least as large as the
      decoder's reported size, and data can be copied out safely.
      
      In this particular jpeg case, you end up with a blank (green) line
      at the bottom due to nvdec refusing to decode the last line, but
      the behaviour matches cuviddec, so it's as good as you're going to
      get.
      4186a77f
    • James Almer's avatar
      avformat/ttaenc: add tta_init() · fa412150
      James Almer authored
      Signed-off-by: 's avatarJames Almer <jamrial@gmail.com>
      fa412150
    • James Almer's avatar
      avformat/ttaenc: buffer packets directly · e97667c8
      James Almer authored
      This is a bit more robust in case of OOM.
      Signed-off-by: 's avatarJames Almer <jamrial@gmail.com>
      e97667c8