summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/common/socket.h4
-rw-r--r--src/map/clif.c4
2 files changed, 5 insertions, 3 deletions
diff --git a/src/common/socket.h b/src/common/socket.h
index 29f3eb3d7..07c8608d8 100644
--- a/src/common/socket.h
+++ b/src/common/socket.h
@@ -47,8 +47,8 @@ struct config_setting_t;
sockt->realloc_writefifo((fd), (size)); \
} while(0)
-#define RFIFOP(fd,pos) (sockt->session[fd]->rdata + sockt->session[fd]->rdata_pos + (pos))
-#define WFIFOP(fd,pos) (sockt->session[fd]->wdata + sockt->session[fd]->wdata_size + (pos))
+#define RFIFOP(fd,pos) ((const void *)(sockt->session[fd]->rdata + sockt->session[fd]->rdata_pos + (pos)))
+#define WFIFOP(fd,pos) ((void *)(sockt->session[fd]->wdata + sockt->session[fd]->wdata_size + (pos)))
#define RFIFOB(fd,pos) (*(const uint8*)RFIFOP((fd),(pos)))
#define WFIFOB(fd,pos) (*(uint8*)WFIFOP((fd),(pos)))
diff --git a/src/map/clif.c b/src/map/clif.c
index 7152aaa14..1cb925303 100644
--- a/src/map/clif.c
+++ b/src/map/clif.c
@@ -18817,7 +18817,9 @@ int clif_parse(int fd) {
if( battle_config.packet_obfuscation == 2 || cmd != RFIFOW(fd, 0) || (sd && sd->parse_cmd_func == clif_parse_cmd_decrypt) ) {
// Note: Overriding const qualifier to re-inject the decoded packet ID.
- int16 *packet_id = (int16 *)RFIFOP(fd, 0);
+#define RFIFOP_mutable(fd, pos) ((void *)(sockt->session[fd]->rdata + sockt->session[fd]->rdata_pos + (pos)))
+ int16 *packet_id = RFIFOP_mutable(fd, 0);
+#undef RFIFOP_mutable
*packet_id = cmd;
if( sd ) {
sd->cryptKey = (( sd->cryptKey * clif->cryptKey[1] ) + clif->cryptKey[2]) & 0xFFFFFFFF; // Update key for the next packet