We have a C++-based application that runs on Windows, Mac, and Linux. I now need to add h.264 and h.265 decoding within this application. It seems ffmpeg will do the trick.
As ours is a commercial application, we cannot disclose the source code to public. However, as I understand, FFMpeg is based on LGPL licensing requirements. Going through various articles on LGPL requirements, it seems I can use ffmpeg without disclosing our source code as long as:
- I build ffmpeg as a shared libraries and make sure that I don't use "--enable-gpl" flag during configuration.
- I acknowledge in our About dialog box that we are using ffmpeg shared libraries.
Can someone please verify if this more or less meets the requirements? Regards.
Note that I need ffmpeg only to decode and not to encode. Therefore, I don't have to use "--enable-libx264" and "--enable-libx265" flags.
As a FFmpeg developer, I would expect you to follow the considerations mentioned on our website:
- Compile FFmpeg without "--enable-gpl" and without
"--enable-nonfree".
- Use dynamic linking (on windows, this means
linking to dlls) for linking with FFmpeg libraries.
- Distribute the
source code of FFmpeg, no matter if you modified it or not.
- Make
sure the source code corresponds exactly to the library binaries you
are distributing.
- Run the command "git diff > changes.diff" in the
root directory of the FFmpeg source code to create a file with only
the changes.
- Explain how you compiled FFmpeg, for example the
configure line, in a text file added to the root directory of the
source code.
- Use tarball or a zip file for distributing the source
code.
- Host the FFmpeg source code on the same webserver as the
binary you are distributing.
- Add "This software uses code of FFmpeg licensed under the LGPLv2.1 and its source can be downloaded here [where here is a link to the source code]" to every page in your website
where there is a download link to your application.
- Mention "This
software uses libraries from the FFmpeg project under the LGPLv2.1"
in your program "about box".
- Mention in your EULA that your program
uses FFmpeg under the LGPLv2.1.
- If your EULA claims ownership over
the code, you have to explicitly mention that you do not own FFmpeg,
and where the relevant owners can be found.
- Remove any prohibition
of reverse engineering from your EULA.
- Apply the same changes to all
translations of your EULA.
- Do not misspell FFmpeg (two capitals F
and lowercase "mpeg").
- Do not rename FFmpeg dlls to some obfuscated
name, but adding a suffix or prefix is fine (renaming "avcodec.dll"
to "MyProgDec.dll" is not fine, but to "avcodec-MyProg.dll" is).
- Go
through all the items again for any LGPL external library you
compiled into FFmpeg (for example LAME).
- Make sure your program is
not using any GPL libraries (notably libx264).
From what you've said so far, I think you're doing only point 1-2, 9-11, 15-18. You need to make the source code (of FFmpeg) including modifications (3-5, 7-8) available along with your application, mention build instructions (6), remove ownership claims on FFmpeg, remove reverse engineering prohibitions (if any), and check your EULA (12-14).
Yes, with lgpl you can use it as a dll/shared lib and you won't need to make your source code available.
But you should be aware that it's not the licensing of the code is the issue for commercial use, but the patents around h.264/h.265 and you need license for that. AFAIK, even if you simply want to decode you'll still need to have license.
MPEGLA is the licensing body for h264 codec patent pool.