Skip to content

Latest commit

 

History

History
75 lines (71 loc) · 2.43 KB

README.md

File metadata and controls

75 lines (71 loc) · 2.43 KB

ultra_mpeg - An MPEG-1/2 decoder library for the Nintendo 64

Copyright (C) 2020 - 2022 devwizard

This project is licensed under the terms of the MIT license. See LICENSE for more information.

Using the demo

  1. Clone this repository: git clone --recursive https://github.com/devwizard64/ultra_mpeg.git.
  2. If you wish to use libmpeg2, download it here: https://libmpeg2.sourceforge.io/downloads.html and place its contents in libmpeg2/.
  3. Install ffmpeg: apt install ffmpeg.
  4. Install a MIPS cross compiler: apt install gcc-mips-linux-gnu.
  • If you are using a toolchain other than mips-linux-gnu, edit makefile accordingly.
  1. Place a video in src/demo.mp4.
  2. Run make.

Using in another project

  • Add -I and -L flags according to makefile.
  • Add -lmpeg2 -lmpeg2_convert flags.
  • Include umpg.c in your project, and add -DUMPG_PL_MPEG or -DUMPG_LIBMPEG2 flags.
  • Include the following functions in your codebase:
    • malloc
    • free
    • memset
    • osCreateMesgQueue
    • osRecvMesg
    • osInvalDCache
    • osPiStartDma
    • fopen (pl_mpeg / may be stubbed)
    • fseek (pl_mpeg / may be stubbed)
    • ftell (pl_mpeg / may be stubbed)
    • fclose (pl_mpeg / may be stubbed)
    • fread (pl_mpeg / may be stubbed)
    • realloc (pl_mpeg)
    • abs (pl_mpeg)
    • memmove (pl_mpeg)
    • osSetEventMesg (pl_mpeg)
    • osSendMesg (pl_mpeg)
    • osWritebackDCacheAll (pl_mpeg)
    • osGetTime (pl_mpeg)
    • osAiSetFrequency (pl_mpeg)
    • osAiSetNextBuffer (pl_mpeg)
    • memcmp (libmpeg2)
    • osSetTimer (libmpeg2)

Documentation

  • UMPG *umpg_init( int x, int y, unsigned int w, unsigned int h, const void *start, const void *end );
    • Create an ultra_mpeg object.
    • x: X position of output, 10.2
    • y: Y position of output, 10.2
    • w: Width of output, 10.2
    • h: Height of output, 10.2
    • start: ROM start of MPG data
    • end: ROM end of MPG data
  • void umpg_free(UMPG *umpg);
    • Free an ultra_mpeg object.
    • umpg: ultra_mpeg object
  • int umpg_update(UMPG *umpg, Gfx **gfx);
    • Update an ultra_mpeg object.
    • umpg: ultra_mpeg object
    • gfx: Buffer to write 3 display list commands.
  • void umpg_resize(UMPG *umpg, int x, int y, unsigned int w, unsigned int h);
    • Resize an ultra_mpeg object.
    • umpg: ultra_mpeg object
    • x: X position of output, 10.2
    • y: Y position of output, 10.2
    • w: Width of output, 10.2
    • h: Height of output, 10.2