Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
N
nginx-push-stream-module
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
nginx-push-stream-module
Commits
add33654
Commit
add33654
authored
Jan 01, 2012
by
Wandenberg Peixoto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
reducing the unnecessary use of ngx_memset to clear some memory areas
parent
e1f3dd26
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
20 additions
and
19 deletions
+20
-19
ngx_http_push_stream_module_version.h
include/ngx_http_push_stream_module_version.h
+1
-1
ngx_http_push_stream_module.c
src/ngx_http_push_stream_module.c
+1
-1
ngx_http_push_stream_module_utils.c
src/ngx_http_push_stream_module_utils.c
+15
-15
ngx_http_push_stream_rbtree_util.c
src/ngx_http_push_stream_rbtree_util.c
+3
-2
No files found.
include/ngx_http_push_stream_module_version.h
View file @
add33654
...
@@ -27,6 +27,6 @@
...
@@ -27,6 +27,6 @@
#define NGX_HTTP_PUSH_STREAM_MODULE_VERSION_H_
#define NGX_HTTP_PUSH_STREAM_MODULE_VERSION_H_
static
const
ngx_str_t
NGX_HTTP_PUSH_STREAM_TAG
=
ngx_string
(
"0.3.2"
);
static
const
ngx_str_t
NGX_HTTP_PUSH_STREAM_TAG
=
ngx_string
(
"0.3.2"
);
static
const
ngx_str_t
NGX_HTTP_PUSH_STREAM_COMMIT
=
ngx_string
(
"
17fc99c161818535d6490bc5dbb0b08f390ed682
"
);
static
const
ngx_str_t
NGX_HTTP_PUSH_STREAM_COMMIT
=
ngx_string
(
"
e1f3dd26fa6d52c97a77a55384894ccf49454d76
"
);
#endif
/* NGX_HTTP_PUSH_STREAM_MODULE_VERSION_H_ */
#endif
/* NGX_HTTP_PUSH_STREAM_MODULE_VERSION_H_ */
src/ngx_http_push_stream_module.c
View file @
add33654
...
@@ -130,7 +130,6 @@ ngx_http_push_stream_send_response_all_channels_info_summarized(ngx_http_request
...
@@ -130,7 +130,6 @@ ngx_http_push_stream_send_response_all_channels_info_summarized(ngx_http_request
ngx_log_error
(
NGX_LOG_ERR
,
r
->
connection
->
log
,
0
,
"Failed to allocate memory to write workers statistics."
);
ngx_log_error
(
NGX_LOG_ERR
,
r
->
connection
->
log
,
0
,
"Failed to allocate memory to write workers statistics."
);
return
NGX_HTTP_INTERNAL_SERVER_ERROR
;
return
NGX_HTTP_INTERNAL_SERVER_ERROR
;
}
}
ngx_memset
(
subscribers_by_workers
,
'\0'
,
len
);
start
=
subscribers_by_workers
;
start
=
subscribers_by_workers
;
for
(
i
=
0
,
j
=
0
;
(
i
<
used_slots
)
&&
(
j
<
NGX_MAX_PROCESSES
);
j
++
)
{
for
(
i
=
0
,
j
=
0
;
(
i
<
used_slots
)
&&
(
j
<
NGX_MAX_PROCESSES
);
j
++
)
{
worker_data
=
data
->
ipc
+
j
;
worker_data
=
data
->
ipc
+
j
;
...
@@ -140,6 +139,7 @@ ngx_http_push_stream_send_response_all_channels_info_summarized(ngx_http_request
...
@@ -140,6 +139,7 @@ ngx_http_push_stream_send_response_all_channels_info_summarized(ngx_http_request
i
++
;
i
++
;
}
}
}
}
*
start
=
'\0'
;
len
=
4
*
NGX_INT_T_LEN
+
subtype
->
format_summarized
->
len
+
hostname
->
len
+
currenttime
->
len
+
ngx_strlen
(
subscribers_by_workers
)
-
21
;
// minus 21 sprintf
len
=
4
*
NGX_INT_T_LEN
+
subtype
->
format_summarized
->
len
+
hostname
->
len
+
currenttime
->
len
+
ngx_strlen
(
subscribers_by_workers
)
-
21
;
// minus 21 sprintf
...
...
src/ngx_http_push_stream_module_utils.c
View file @
add33654
...
@@ -160,6 +160,7 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
...
@@ -160,6 +160,7 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
ngx_http_push_stream_template_queue_t
*
cur
=
sentinel
;
ngx_http_push_stream_template_queue_t
*
cur
=
sentinel
;
ngx_http_push_stream_msg_t
*
msg
;
ngx_http_push_stream_msg_t
*
msg
;
int
i
=
0
;
int
i
=
0
;
u_char
*
last
;
if
((
msg
=
ngx_slab_alloc_locked
(
shpool
,
sizeof
(
ngx_http_push_stream_msg_t
)))
==
NULL
)
{
if
((
msg
=
ngx_slab_alloc_locked
(
shpool
,
sizeof
(
ngx_http_push_stream_msg_t
)))
==
NULL
)
{
return
NULL
;
return
NULL
;
...
@@ -176,9 +177,9 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
...
@@ -176,9 +177,9 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
msg
->
raw
->
len
=
len
;
msg
->
raw
->
len
=
len
;
msg
->
raw
->
data
=
(
u_char
*
)
(
msg
->
raw
+
1
);
msg
->
raw
->
data
=
(
u_char
*
)
(
msg
->
raw
+
1
);
ngx_memset
(
msg
->
raw
->
data
,
'\0'
,
len
+
1
);
// copy the message to shared memory
// copy the message to shared memory
ngx_memcpy
(
msg
->
raw
->
data
,
data
,
len
);
last
=
ngx_copy
(
msg
->
raw
->
data
,
data
,
len
);
*
last
=
'\0'
;
if
(
event_id
!=
NULL
)
{
if
(
event_id
!=
NULL
)
{
if
((
msg
->
event_id
=
ngx_slab_alloc_locked
(
shpool
,
sizeof
(
ngx_str_t
)
+
event_id
->
len
+
1
))
==
NULL
)
{
if
((
msg
->
event_id
=
ngx_slab_alloc_locked
(
shpool
,
sizeof
(
ngx_str_t
)
+
event_id
->
len
+
1
))
==
NULL
)
{
...
@@ -188,8 +189,8 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
...
@@ -188,8 +189,8 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
msg
->
event_id
->
len
=
event_id
->
len
;
msg
->
event_id
->
len
=
event_id
->
len
;
msg
->
event_id
->
data
=
(
u_char
*
)
(
msg
->
event_id
+
1
);
msg
->
event_id
->
data
=
(
u_char
*
)
(
msg
->
event_id
+
1
);
ngx_memset
(
msg
->
event_id
->
data
,
'\0'
,
event_id
->
len
+
1
);
last
=
ngx_copy
(
msg
->
event_id
->
data
,
event_id
->
data
,
event_id
->
len
);
ngx_memcpy
(
msg
->
event_id
->
data
,
event_id
->
data
,
event_id
->
len
)
;
*
last
=
'\0'
;
u_char
*
aux
=
ngx_http_push_stream_str_replace
(
NGX_HTTP_PUSH_STREAM_EVENTSOURCE_ID_TEMPLATE
.
data
,
NGX_HTTP_PUSH_STREAM_TOKEN_MESSAGE_EVENT_ID
.
data
,
event_id
->
data
,
0
,
temp_pool
);
u_char
*
aux
=
ngx_http_push_stream_str_replace
(
NGX_HTTP_PUSH_STREAM_EVENTSOURCE_ID_TEMPLATE
.
data
,
NGX_HTTP_PUSH_STREAM_TOKEN_MESSAGE_EVENT_ID
.
data
,
event_id
->
data
,
0
,
temp_pool
);
if
(
aux
==
NULL
)
{
if
(
aux
==
NULL
)
{
...
@@ -205,8 +206,8 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
...
@@ -205,8 +206,8 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
msg
->
event_id_message
->
len
=
chunk
->
len
;
msg
->
event_id_message
->
len
=
chunk
->
len
;
msg
->
event_id_message
->
data
=
(
u_char
*
)
(
msg
->
event_id_message
+
1
);
msg
->
event_id_message
->
data
=
(
u_char
*
)
(
msg
->
event_id_message
+
1
);
ngx_memset
(
msg
->
event_id_message
->
data
,
'\0'
,
msg
->
event_id_message
->
len
+
1
);
last
=
ngx_copy
(
msg
->
event_id_message
->
data
,
chunk
->
data
,
msg
->
event_id_message
->
len
);
ngx_memcpy
(
msg
->
event_id_message
->
data
,
chunk
->
data
,
msg
->
event_id_message
->
len
)
;
*
last
=
'\0'
;
}
}
msg
->
deleted
=
0
;
msg
->
deleted
=
0
;
...
@@ -259,8 +260,8 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
...
@@ -259,8 +260,8 @@ ngx_http_push_stream_convert_char_to_msg_on_shared_locked(u_char *data, size_t l
}
}
formmated
->
len
=
text
->
len
;
formmated
->
len
=
text
->
len
;
ngx_memset
(
formmated
->
data
,
'\0'
,
formmated
->
len
+
1
);
last
=
ngx_copy
(
formmated
->
data
,
text
->
data
,
formmated
->
len
);
ngx_memcpy
(
formmated
->
data
,
text
->
data
,
formmated
->
len
)
;
*
last
=
'\0'
;
i
++
;
i
++
;
}
}
...
@@ -990,7 +991,7 @@ ngx_http_push_stream_str_replace(u_char *org, u_char *find, u_char *replace, ngx
...
@@ -990,7 +991,7 @@ ngx_http_push_stream_str_replace(u_char *org, u_char *find, u_char *replace, ngx
ngx_uint_t
len_find
=
ngx_strlen
(
find
);
ngx_uint_t
len_find
=
ngx_strlen
(
find
);
ngx_uint_t
len_replace
=
ngx_strlen
(
replace
);
ngx_uint_t
len_replace
=
ngx_strlen
(
replace
);
u_char
*
result
=
org
;
u_char
*
result
=
org
,
*
last
;
if
(
len_find
>
0
)
{
if
(
len_find
>
0
)
{
u_char
*
ret
=
(
u_char
*
)
ngx_strstr
(
org
+
offset
,
find
);
u_char
*
ret
=
(
u_char
*
)
ngx_strstr
(
org
+
offset
,
find
);
...
@@ -1001,12 +1002,11 @@ ngx_http_push_stream_str_replace(u_char *org, u_char *find, u_char *replace, ngx
...
@@ -1001,12 +1002,11 @@ ngx_http_push_stream_str_replace(u_char *org, u_char *find, u_char *replace, ngx
return
NULL
;
return
NULL
;
}
}
ngx_memset
(
tmp
,
'\0'
,
len_org
+
len_replace
+
len_find
+
1
);
u_int
len_found
=
ret
-
org
;
u_int
len_found
=
ret
-
org
;
ngx_memcpy
(
tmp
,
org
,
len_found
);
ngx_memcpy
(
tmp
,
org
,
len_found
);
ngx_memcpy
(
tmp
+
len_found
,
replace
,
len_replace
);
ngx_memcpy
(
tmp
+
len_found
,
replace
,
len_replace
);
ngx_memcpy
(
tmp
+
len_found
+
len_replace
,
org
+
len_found
+
len_find
,
len_org
-
len_found
-
len_find
);
last
=
ngx_copy
(
tmp
+
len_found
+
len_replace
,
org
+
len_found
+
len_find
,
len_org
-
len_found
-
len_find
);
*
last
=
'\0'
;
result
=
ngx_http_push_stream_str_replace
(
tmp
,
find
,
replace
,
len_found
+
len_replace
,
pool
);
result
=
ngx_http_push_stream_str_replace
(
tmp
,
find
,
replace
,
len_found
+
len_replace
,
pool
);
}
}
...
@@ -1030,15 +1030,15 @@ ngx_http_push_stream_get_formatted_message(ngx_http_request_t *r, ngx_http_push_
...
@@ -1030,15 +1030,15 @@ ngx_http_push_stream_get_formatted_message(ngx_http_request_t *r, ngx_http_push_
static
ngx_str_t
*
static
ngx_str_t
*
ngx_http_push_stream_format_message
(
ngx_http_push_stream_channel_t
*
channel
,
ngx_http_push_stream_msg_t
*
message
,
ngx_str_t
*
text
,
ngx_str_t
*
message_template
,
ngx_pool_t
*
temp_pool
)
ngx_http_push_stream_format_message
(
ngx_http_push_stream_channel_t
*
channel
,
ngx_http_push_stream_msg_t
*
message
,
ngx_str_t
*
text
,
ngx_str_t
*
message_template
,
ngx_pool_t
*
temp_pool
)
{
{
u_char
*
txt
=
NULL
;
u_char
*
txt
=
NULL
,
*
last
;
ngx_str_t
*
str
=
NULL
;
ngx_str_t
*
str
=
NULL
;
u_char
char_id
[
NGX_INT_T_LEN
];
u_char
char_id
[
NGX_INT_T_LEN
];
ngx_memset
(
char_id
,
'\0'
,
NGX_INT_T_LEN
);
u_char
*
channel_id
=
(
channel
!=
NULL
)
?
channel
->
id
.
data
:
NGX_HTTP_PUSH_STREAM_EMPTY
.
data
;
u_char
*
channel_id
=
(
channel
!=
NULL
)
?
channel
->
id
.
data
:
NGX_HTTP_PUSH_STREAM_EMPTY
.
data
;
u_char
*
event_id
=
(
message
->
event_id
!=
NULL
)
?
message
->
event_id
->
data
:
NGX_HTTP_PUSH_STREAM_EMPTY
.
data
;
u_char
*
event_id
=
(
message
->
event_id
!=
NULL
)
?
message
->
event_id
->
data
:
NGX_HTTP_PUSH_STREAM_EMPTY
.
data
;
ngx_sprintf
(
char_id
,
"%d"
,
message
->
id
);
last
=
ngx_sprintf
(
char_id
,
"%d"
,
message
->
id
);
*
last
=
'\0'
;
txt
=
ngx_http_push_stream_str_replace
(
message_template
->
data
,
NGX_HTTP_PUSH_STREAM_TOKEN_MESSAGE_ID
.
data
,
char_id
,
0
,
temp_pool
);
txt
=
ngx_http_push_stream_str_replace
(
message_template
->
data
,
NGX_HTTP_PUSH_STREAM_TOKEN_MESSAGE_ID
.
data
,
char_id
,
0
,
temp_pool
);
txt
=
ngx_http_push_stream_str_replace
(
txt
,
NGX_HTTP_PUSH_STREAM_TOKEN_MESSAGE_EVENT_ID
.
data
,
event_id
,
0
,
temp_pool
);
txt
=
ngx_http_push_stream_str_replace
(
txt
,
NGX_HTTP_PUSH_STREAM_TOKEN_MESSAGE_EVENT_ID
.
data
,
event_id
,
0
,
temp_pool
);
...
...
src/ngx_http_push_stream_rbtree_util.c
View file @
add33654
...
@@ -179,6 +179,7 @@ ngx_http_push_stream_get_channel(ngx_str_t *id, ngx_log_t *log, ngx_http_push_st
...
@@ -179,6 +179,7 @@ ngx_http_push_stream_get_channel(ngx_str_t *id, ngx_log_t *log, ngx_http_push_st
ngx_http_push_stream_channel_t
*
channel
;
ngx_http_push_stream_channel_t
*
channel
;
ngx_slab_pool_t
*
shpool
=
(
ngx_slab_pool_t
*
)
ngx_http_push_stream_shm_zone
->
shm
.
addr
;
ngx_slab_pool_t
*
shpool
=
(
ngx_slab_pool_t
*
)
ngx_http_push_stream_shm_zone
->
shm
.
addr
;
ngx_flag_t
is_broadcast_channel
=
0
;
ngx_flag_t
is_broadcast_channel
=
0
;
u_char
*
last
;
channel
=
ngx_http_push_stream_find_channel
(
id
,
log
);
channel
=
ngx_http_push_stream_find_channel
(
id
,
log
);
if
(
channel
!=
NULL
)
{
// we found our channel
if
(
channel
!=
NULL
)
{
// we found our channel
...
@@ -215,9 +216,9 @@ ngx_http_push_stream_get_channel(ngx_str_t *id, ngx_log_t *log, ngx_http_push_st
...
@@ -215,9 +216,9 @@ ngx_http_push_stream_get_channel(ngx_str_t *id, ngx_log_t *log, ngx_http_push_st
return
NULL
;
return
NULL
;
}
}
ngx_memset
(
channel
->
id
.
data
,
'\0'
,
id
->
len
+
1
);
channel
->
id
.
len
=
id
->
len
;
channel
->
id
.
len
=
id
->
len
;
ngx_memcpy
(
channel
->
id
.
data
,
id
->
data
,
channel
->
id
.
len
);
last
=
ngx_copy
(
channel
->
id
.
data
,
id
->
data
,
channel
->
id
.
len
);
*
last
=
'\0'
;
channel
->
broadcast
=
is_broadcast_channel
;
channel
->
broadcast
=
is_broadcast_channel
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment