blob: a625670372b8a20a0156a76019a9d5d77ad45297 [file] [log] [blame] [view]
# libavif third party sources
Anything in this directory is imported from third party sources with minimal changes.
See `LICENSE` file of respective subdirectories of this directory for license information.
## libyuv
This subdirectory contains source code imported from libyuv as of `def473f501acbd652cd4593fd2a90a067e8c9f1a`, with
modifications intended to keep them relatively small and simple.
### Importing from upstream
When importing source code from upstream libyuv, the following changes must be done:
1. Source hierarchy is to be kept the same as in libyuv.
2. The only APIs that are called by libavif for scaling are `ScalePlane()` and `ScalePlane_12()`. Anything else must be
left out.
3. In function `ScalePlane()` and `ScalePlane_16()`, only the `ScalePlaneVertical()`, `CopyPlane()`, `ScalePlaneBox()`,
`ScalePlaneUp2_Linear()`, `ScalePlaneUp2_Bilinear()`, `ScalePlaneBilinearUp()`, `ScalePlaneBilinearDown()` and
`ScalePlaneSimple()` paths (and their `_16` equivalents) from libyuv must be kept; any other paths are to be stripped
out (including SIMD).
4. The commit hash of libyuv from where the files got imported in this README.md file must be updated.
5. `LIBYUV_API` must be removed from any and all imported functions as these files are always built static.
6. Replace .cc file extension by .c.