Go to file
Kiril Menshikov 2f0b07975e Allow to allign allocated Buffers
Motivation:

64-byte alignment is recommended by the Intel performance guide (https://software.intel.com/en-us/articles/practical-intel-avx-optimization-on-2nd-generation-intel-core-processors) for data-structures over 64 bytes.
Requiring padding to a multiple of 64 bytes allows for using SIMD instructions consistently in loops without additional conditional checks. This should allow for simpler and more efficient code.

Modification:

At the moment cache alignment must be setup manually. But probably it might be taken from the system. The original code was introduced by @normanmaurer https://github.com/netty/netty/pull/4726/files

Result:

Buffer alignment works better than miss-align cache.
2017-02-06 09:51:06 +01:00
.github Use GitHub Issue/PR Template Feature 2016-12-07 11:40:46 -08:00
all [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
buffer Allow to allign allocated Buffers 2017-02-06 09:51:06 +01:00
codec [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
codec-haproxy [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
codec-http [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
codec-socks [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
common [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
example [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
handler Cleanup : for loops for arrays to make code easier to read and removed unnecessary toLowerCase() 2017-02-06 07:48:34 +01:00
license Let PoolThreadCache work even if allocation and deallocation Thread are different 2015-05-27 14:35:22 +02:00
microbench Allow to allign allocated Buffers 2017-02-06 09:51:06 +01:00
tarball [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
testsuite [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
testsuite-osgi [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
transport delete no useful intermediate variables 2017-02-06 07:54:50 +01:00
transport-native-epoll Cleanup : for loops for arrays to make code easier to read and removed unnecessary toLowerCase() 2017-02-06 07:48:34 +01:00
transport-rxtx [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
transport-sctp [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
transport-udt [maven-release-plugin] prepare for next development iteration 2017-01-30 17:42:39 +01:00
.fbprefs Updated Find Bugs configuration 2009-03-04 10:33:09 +00:00
.gitignore Use shaded dependency on JCTools instead of copy and paste 2016-06-10 13:53:28 +02:00
.travis.yml Travis CI branch whitelisting 2013-03-11 09:55:43 +09:00
CONTRIBUTING.md Move the pull request guide to the developer guide 2014-03-12 13:18:14 +09:00
LICENSE.txt Relicensed to Apache License v2 2009-08-28 07:15:49 +00:00
NOTICE.txt Let PoolThreadCache work even if allocation and deallocation Thread are different 2015-05-27 14:35:22 +02:00
pom.xml Switch to netty-tcnative 2.0.0 which uses different package names 2017-02-02 10:44:50 +01:00
README.md Updating Branches to look section to match the current branching structure of the project 2016-03-10 22:09:30 +01:00
run-example.sh Add logLevel property to enable different log levels for the examples. 2014-11-21 10:48:13 +09:00

Netty Project

Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients.

How to build

For the detailed information about building and developing Netty, please visit the developer guide. This page only gives very basic information.

You require the following to build Netty:

Note that this is build-time requirement. JDK 5 (for 3.x) or 6 (for 4.0+) is enough to run your Netty-based application.

Branches to look

Development of all versions takes place in each branch whose name is identical to <majorVersion>.<minorVersion>. For example, the development of 3.9 and 4.0 resides in the branch '3.9' and the branch '4.0' respectively.