2012-10-11 00:04:08 +00:00
|
|
|
mpv is a fork of mplayer2, which is a fork of MPlayer.
|
|
|
|
|
2017-10-13 13:37:55 +00:00
|
|
|
mpv as a whole is licensed under the GNU General Public License GPL version 2
|
|
|
|
or later (called GPLv2+ in this document, see LICENSE.GPL for full license
|
|
|
|
text) by default, or the GNU Lesser General Public License LGPL version 2 or
|
|
|
|
later (LGPLv2.1+ in this document, see LICENSE.LGPL for full license text) if
|
|
|
|
built with the --enable-lgpl configure switch.
|
|
|
|
|
|
|
|
Most source files are LGPLv2.1+ or GPLv2+, but some files are available under
|
|
|
|
more liberal licenses, such as BSD, MIT, ISC, and possibly others. Look at the
|
|
|
|
copyright header of each source file, and grep the sources for "Copyright" if
|
|
|
|
you need to know details. C source files without Copyright notice are usually
|
|
|
|
licensed as LGPLv2.1+. Also see the list of files with specific licenses below
|
|
|
|
(not all files can have a standard license header).
|
2015-07-24 21:53:31 +00:00
|
|
|
|
2017-10-10 14:21:01 +00:00
|
|
|
All new contributions must be LGPLv2.1+ licensed. Using a more liberal license
|
|
|
|
compatible to LGPLv2.1+ is also ok.
|
|
|
|
|
|
|
|
If changes are done on GPL code, must come with the implicit agreement that the
|
2017-10-13 13:37:55 +00:00
|
|
|
project can relicense the changes to LGPLv2.1+ at a later point without asking
|
|
|
|
the contributor. This is a safeguard for making potential relicensing of
|
|
|
|
remaining GPL code to LGPLv2.1+ easier.
|
2003-12-09 08:35:55 +00:00
|
|
|
|
2013-10-12 23:18:50 +00:00
|
|
|
For information about authors and contributors, consult the git log, which
|
|
|
|
contains the complete SVN and CVS history as well.
|
2010-01-04 13:01:44 +00:00
|
|
|
|
2015-07-24 21:53:31 +00:00
|
|
|
"v2.1+" in this context means "version 2.1 or later".
|
2017-02-16 10:43:02 +00:00
|
|
|
|
2017-05-11 06:12:14 +00:00
|
|
|
Some libraries are GPLv2+ or GPLv3+ only. Building mpv with Samba support makes
|
|
|
|
it GPLv3+.
|
|
|
|
|
2017-10-10 14:21:01 +00:00
|
|
|
mpv can be built as LGPLv2.1+ with the --enable-lgpl configure option. To add
|
|
|
|
a LGPL mode to mpv, MPlayer code had to be relicensed from GPLv2+ to LGPLv2.1+
|
|
|
|
by asking the MPlayer authors for permission. Since permission could not be
|
|
|
|
obtained from everyone, LGPL mode disables the following features, some of
|
|
|
|
them quite central:
|
audio: add audio softvol processing to AO
This does what af_volume used to do. Since we couldn't relicense it,
just rewrite it. Since we don't have a new filter mechanism yet, and the
libavfilter is too inconvenient, do applying the volume gain in ao.c
directly. This is done before handling the audio data to the driver.
Since push.c runs a separate thread, and pull.c is called asynchronously
from the audio driver's thread, the volume value needs to be
synchronized. There's no existing central mutex, so do some shit with
atomics. Since there's no atomic_float type predefined (which is at
least needed when using the legacy wrapper), do some nonsense about
reinterpret casting the float value to an int for the purpose of atomic
access. Not sure if using memcpy() is undefined behavior, but for now I
don't care.
The advantage of not using a filter is lower complexity (no filter auto
insertion), and lower latency (gain processing is done after our
internal audio buffer of at least 200ms).
Disavdantages include inability to use native volume control _before_
other filters with custom filter chains, and the need to add new
processing for each new sample type.
Since this doesn't reuse any of the old GPL code, nor does indirectly
rely on it, volume and replaygain handling now works in LGPL mode.
How to process the gain is inspired by libavfilter's af_volume (LGPL).
In particular, we use exactly the same rounding, and we quantize
processing for integer sample types by 256 steps. Some of libavfilter's
copyright may or may not apply, but I think not, and it's the same
license anyway.
2017-11-29 20:30:10 +00:00
|
|
|
- no audio filtering, which breaks: --af, pitch correction, fine control over
|
|
|
|
downmix/upmix/resampling behavior
|
2017-09-21 11:50:18 +00:00
|
|
|
- Linux X11 video output
|
|
|
|
- BSD audio output via OSS
|
2017-11-29 18:50:04 +00:00
|
|
|
- NVIDIA/Linux hardware decoding (vdpau, although nvdec usually works)
|
2017-09-21 11:50:18 +00:00
|
|
|
- Linux TV input
|
|
|
|
- minor features: jack, DVD, CDDA, SMB, CACA, legacy direct3d VO
|
player: change 3 remaining GPL-only code pieces to LGPL
There has been no new developments or agreements, but I was uncertain
about the copyright status of them. Thus this part of code was marked as
being potentially GPL, and was not built in LGPL mode. Now I've taken a
close look again, and decided that these can be relicensed using the
existing relicensing agreements.
OSD level 3 was introduced in commit 8d190244, with the author being
unreachable. As I decided in commit 6ddd95fd, OSD level 3 itself can
be kept, but the "osd" command had to go, and the "rendering" of OSD
level 3 (the HAVE_GPL code in osd.c) was uncertain. But the code for
this was rewritten: instead of duplicating the time/percent formatting
code, it was changed to use common code, and some weird extra logic was
removed. The code inside of the "if" is exactly the same as the code
that formats the OSD status line (covered by LGPL relicensing).
The current commands for adding/removing sub/audio tracks more or less
originated from commit 2f376d1b39, with the author being unreachable.
But the original code was very different, mostly due to MPlayer's
incredibly messy handling of subtitles in general. Nothing of this
remains in the current code. Even the command declarations were
rewritten. The commands (as seen from the user side) are rather similar
in naming and semantics, but we don't consider this copyrightable. So it
doesn't look like anything copyrightable is left.
The add/cycle commands were more or less based on step_property,
introduced in commit 7a71da01d6, with the patch author disagreeing with
the LGPL relicensing. But all code original to the patch has been
replaced in later mpv changes, and the original code was mostly copied
from MP_CMD_SET_PROPERTY anyway. The underlying property interface was
completely changed, the error handling was redone, and all of this is
very similar to the changes that were done on SET_PROPERTY. The command
declarations are completely different in the first place, because the
semantic change from step to add/cycle. The commit also seems to have
been co-authored by reimar to some degree. He also had the idea to
change the original patch from making the command modify a specific
property to making it generic.
(The error message line, especially with its %g formatting, might
contain some level of originality, so change that just to be sure.
This commit Copies and adapts the error message for SET_PROPERTY.)
Although I'm a bit on the fence with all the above things, it really
doesn't look like there's anything substantial that would cause issues.
I thus claim that there is no problem with changing the license to LGPL
for the above things. It's probably still slightly below the standard
that was usually applied in the code relicensing in mpv, but probably
still far above to the usual in open source relicensing (and above
commercial standards as well, if you look what certain tech giants do).
2017-11-24 13:04:53 +00:00
|
|
|
Some of these will be fixed in the future. The intended use for LGPL mode is
|
2017-11-29 16:29:41 +00:00
|
|
|
with libmpv, and currently it's not recommended to build mpv CLI in LGPL mode
|
2017-09-21 11:50:18 +00:00
|
|
|
at all.
|
|
|
|
|
2017-10-10 14:21:01 +00:00
|
|
|
The following files are still GPL only (--enable-lgpl disables them):
|
2017-05-05 06:38:30 +00:00
|
|
|
|
2017-09-21 11:50:18 +00:00
|
|
|
audio/filter/* will be replaced with new filter chain
|
|
|
|
audio/filter/af_format.c mostly LGPL (except af glue code)
|
|
|
|
audio/filter/af_lavc3enc.c as above
|
|
|
|
audio/filter/af_lavfi.c as above
|
|
|
|
audio/filter/af_scaletempo.c as above
|
|
|
|
audio/filter/af_rubberband.c as above
|
audio/out: change license of some core files to LGPL
All contributors of the current code have agreed. ao.c requires a
"driver" entry for each audio output - we assume that if someone who
didn't agree to LGPL added a line, it's fine for ao.c to be LGPL
anyway. If the affected audio output is not disabled at compilation
time, the resulting binary will be GPL anyway, and ootherwise the
code is not included.
The audio output code itself was inspired or partially copied from
libao in 7a2eec4b59f4 (thus why MPlayer's audio code is named libao2).
Just to be sure we got permission from Aaron Holtzman, Jack Moffitt, and
Stan Seibert, who according to libao's SVN history and README are the
initial author. (Something similar was done for libvo, although the
commit relicensing it forgot to mention it.)
242aa6ebd40: anders mostly disagreed with the LGPL relicensing, but we
got permission for this particular commit.
0ef8e555735: nick could not be reached, but the include statement was
removed again anyway.
879e05a7c17: iive agreed to LGPL v3+ only, but this line of code was
removed anyway, so ao_null.c can be LGPL v2.1+.
9dd8f241ac2: patch author could not be reached, but the corresponding
code (old slave mode interface) was completely removed later.
2017-05-20 09:35:25 +00:00
|
|
|
audio/out/ao_jack.c will stay GPL
|
2017-05-05 06:38:30 +00:00
|
|
|
audio/out/ao_oss.c will stay GPL
|
2017-09-21 11:50:18 +00:00
|
|
|
audio/audio.* needed by af code only
|
2017-05-05 06:38:30 +00:00
|
|
|
demux/demux_tv.c will stay GPL
|
|
|
|
stream/ai_* will stay GPL (TV code)
|
|
|
|
stream/audio_in.* will stay GPL (TV code)
|
|
|
|
stream/dvb* must stay GPL
|
|
|
|
stream/frequencies.* must stay GPL
|
|
|
|
stream/stream_cdda.c unknown
|
|
|
|
stream/stream_dvb.* must stay GPL
|
|
|
|
stream/stream_dvd.c unknown
|
|
|
|
stream/stream_dvd_common.* unknown
|
|
|
|
stream/stream_dvdnav.c unknown
|
2017-05-11 06:12:14 +00:00
|
|
|
stream/stream_smb.c will stay GPLv3
|
2017-05-05 06:38:30 +00:00
|
|
|
stream/stream_tv.c will stay GPL
|
|
|
|
stream/tv* will stay GPL
|
|
|
|
video/out/vo_caca.c unknown
|
|
|
|
video/out/vo_direct3d.c unknown
|
|
|
|
video/out/vo_vaapi.c probably impossible (some company's code)
|
|
|
|
video/out/vo_vdpau.c probably impossible (nVidia's code)
|
|
|
|
video/out/vo_x11.c probably impossible
|
|
|
|
video/out/vo_xv.c probably impossible
|
|
|
|
video/out/x11_common.* probably impossible
|
|
|
|
video/vdpau.c hard (GPL-only parts must be ifdefed)
|
|
|
|
video/vdpau.h unknown
|
|
|
|
video/vdpau_mixer.* actual code must be rewritten
|
2017-10-10 14:21:01 +00:00
|
|
|
DOCS/man/ GPLv2+
|
|
|
|
bootstrap.py unknown license, probably GPLv2+ or LGPLv2+
|
|
|
|
etc/mplayer-input.conf unknown license, probably GPLv2+
|
|
|
|
mpv.desktop unknown license, probably GPLv2+
|
2017-11-29 16:29:41 +00:00
|
|
|
etc/restore-old-bindings.conf unknown license, probably GPLv2+
|
2017-09-21 11:50:18 +00:00
|
|
|
|
2017-10-10 14:21:01 +00:00
|
|
|
The following files contain some optional GPL code (--enable-lgpl disables it):
|
2017-09-21 11:50:18 +00:00
|
|
|
|
|
|
|
options/parse_commandline.c dvd:// expansion
|
|
|
|
player/audio.c libaf glue code
|
2017-10-10 14:21:01 +00:00
|
|
|
|
|
|
|
None of the exceptions listed above affect the final binary if it's built as
|
|
|
|
LGPL. Linked libraries still can affect the final license (for example if
|
|
|
|
FFmpeg was built as GPL).
|