Merge pull request #25314 from marxin/fix-24417-class-memaccess

Fix class memaccess
This commit is contained in:
Rémi Verschelde 2019-01-27 21:32:26 +01:00 committed by GitHub
commit d0f289b0d9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 8 additions and 6 deletions

View File

@ -33,6 +33,7 @@
#include "RgbaBitmap.h" #include "RgbaBitmap.h"
#include "core/os/file_access.h" #include "core/os/file_access.h"
#include <string.h> #include <string.h>
#include <new>
static void _pvrtc_decompress(Image *p_img); static void _pvrtc_decompress(Image *p_img);
@ -215,12 +216,10 @@ static void _compress_pvrtc4(Image *p_img) {
int ofs, size, w, h; int ofs, size, w, h;
img->get_mipmap_offset_size_and_dimensions(i, ofs, size, w, h); img->get_mipmap_offset_size_and_dimensions(i, ofs, size, w, h);
Javelin::RgbaBitmap bm(w, h); Javelin::RgbaBitmap bm(w, h);
copymem(bm.GetData(), &r[ofs], size); for (unsigned j = 0; j < size / 4; j++) {
{
Javelin::ColorRgba<unsigned char> *dp = bm.GetData(); Javelin::ColorRgba<unsigned char> *dp = bm.GetData();
for (int j = 0; j < size / 4; j++) { /* red and Green colors are swapped. */
SWAP(dp[j].r, dp[j].b); new (dp) Javelin::ColorRgba<unsigned char>(r[ofs + 4 * j + 2], r[ofs + 4 * j + 1], r[ofs + 4 * j], r[ofs + 4 * j + 3]);
}
} }
new_img->get_mipmap_offset_size_and_dimensions(i, ofs, size, w, h); new_img->get_mipmap_offset_size_and_dimensions(i, ofs, size, w, h);

View File

@ -32,6 +32,7 @@
#include "core/os/os.h" #include "core/os/os.h"
#include "visual_server_global.h" #include "visual_server_global.h"
#include "visual_server_raster.h" #include "visual_server_raster.h"
#include <new>
/* CAMERA API */ /* CAMERA API */
RID VisualServerScene::camera_create() { RID VisualServerScene::camera_create() {
@ -1253,7 +1254,9 @@ void VisualServerScene::_update_instance_lightmap_captures(Instance *p_instance)
//print_line("update captures for pos: " + p_instance->transform.origin); //print_line("update captures for pos: " + p_instance->transform.origin);
zeromem(p_instance->lightmap_capture_data.ptrw(), 12 * sizeof(Color)); for (int i = 0; i < 12; i++)
new (&p_instance->lightmap_capture_data.ptrw()[i]) Color;
//this could use some sort of blending.. //this could use some sort of blending..
for (List<Instance *>::Element *E = geom->lightmap_captures.front(); E; E = E->next()) { for (List<Instance *>::Element *E = geom->lightmap_captures.front(); E; E = E->next()) {
const PoolVector<RasterizerStorage::LightmapCaptureOctree> *octree = VSG::storage->lightmap_capture_get_octree_ptr(E->get()->base); const PoolVector<RasterizerStorage::LightmapCaptureOctree> *octree = VSG::storage->lightmap_capture_get_octree_ptr(E->get()->base);