代码拉取完成,页面将自动刷新
Disclaimer
----------
This library is written for the purpose of playing Blu-ray movies. It is
intended for software that want to support Blu-ray playback (such as VLC and
MPlayer). We, the authors of this library, do not condone nor endorse piracy.
This library is simply a tool for playback of Blu-ray movies. Like any tool, the
use of this tool can also be abused. There are already numerous laws in
different countries and juridictions all over the world that protect copyrighted
material, such as Blu-ray movies. With that said, it would have been
inappropriate for us to distribute this library with terms such as "you cannot
use this library for piracy". Instead, we present to everyone this disclaimer.
As a reminder, here is also the disclaimer found at the beginning of any movie
in relation to copyrights.
ATTENTION
International agreement and national laws protect copyrighted motion pictures,
videotapes, and sound recordings.
UNAUTHORIZED REPRODUCTION, EXHIBITION OR DISTRIBUTION OF COPYRIGHTED MOTION
PICTURES CAN RESULT IN SEVERE CRIMINAL AND CIVIL PENALTIES UNDER THE LAWS OF
YOUR COUNTRY.
The International Criminal Police Organization - INTERPOL, has expressed its
concern about motion picture and sound recording piracy to all of its member
national police forces. (Resolution adopted at INTERPOL General Assembly,
Stockholm, Sweden, September 8, 1977.)
Welcome to the BD+ library.
---------------------------
This library is not complete, in that it will never be complete and
will always require updates to stay up to date with the latest Bluray
disks released.
The general flow on this library is that the higher level 'player'
code will call us if there exist a "BDSVM/00000.svm" file on the disk. If
this is the case it will call bdplus_init(), connect the library with
other parts of BluRay player and call bdplus_start().
BD+ VM executes the DLX assembled code inside the SVM file.
This will perform thousands of AES, SHA, file reads and detailed
memory checks to guess the authenticity of the player.
If all goes well, the SVM will eventually spit out a 'conversion
table'. This is a large table (usually about 1-2MB but it varies) which
contains offsets into the M2TS video file. (usually the main title).
The video file has been purposely corrupted at random places. These
offsets, and 12 bytes of data for each one, is used to repair the
video file.
However, the conversion table is also 'encoded' (XOR). So the VM is
further executed to ask for the decode-keys for each part (segment) of
the conversion table.
============================================
the BD+ library will need various keys to perform its task. More
precisely, it needs:
6 AES Player keys (each 16 bytes)
There are also 5 dumps of the Player Discovery replies.
There is player memory dumps that needs to be simulated. Including
player name, version and executable map.
Configuration directory (vm0) is searched from following places:
Linux (xdg specification):
/etc/xdg/bdplus/
$HOME/.config/bdplus/
Windows:
%APPDATA%/bdplus/
Mac OS:
~/Library/Preferences/bdplus/
Configuration data is not included with libbdplus.
============================================
The BD+ design also uses 'slots', that is like a save-file stored on
NVRam/USB-Stick or similar permanent storage. The slot layout is 500
slots of 256 bytes each. The SVM can request a new/free slot to
write, or look for one previously written. In here it can store
information for future play attempts.
Slots are stored in the following file:
Linux (xdg specification):
$HOME/.cache/bdplus/slots.bin
Windows:
%APPDATA%/bdplus/slots.bin
Mac OS:
~/Library/Caches/bdplus/
============================================
The SVM also communicates with BluRay player BDJ and HDMV subsystems,
using the PSR102, PSR103 and PSR104 registers. To set up callback
functions for communication, BluRay player calls bdplus_set_psr().
============================================
What if things go wrong? And they will! Each new disk brought out will
potentially expose new issues with libbdplus. There are things that
can be done to help fix libbdplus.
You can set environment variables:
DBG_BDPLUS : General BDPlus debugging, traps etc.
where you can watch the SVM perform its various tasks. It is quite
hard to know where it goes wrong, unless you have something to compare
against though. I don't know if we can record traps and breaks anymore...
DBG_DLX: In-depth DLX assembly instruction debugging.
This is very verbose and shows the DLX instructions executing. It
would be unlikely to be bugs in the DLX opcodes, but you never
know. Included for amusements sake.
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。