forked from Alepha/Alepha
		
	Get it building again.
This commit is contained in:
		| @ -21,6 +21,11 @@ namespace Alepha::Hydrogen::Memory  ::detail::  ThreadSlab_m | ||||
| 	namespace C | ||||
| 	{ | ||||
| 		const std::size_t slabSize= 64 * 1024 * 1024; | ||||
|  | ||||
| 		const bool debug= false; | ||||
| 		const bool debugLifecycle= false or C::debug; | ||||
| 		const bool debugAllocation= false or C::debug; | ||||
| 		const bool debugDeallocations= false or C::debug; | ||||
| 	} | ||||
|  | ||||
| 	template< typename T > | ||||
| @ -49,27 +54,41 @@ namespace Alepha::Hydrogen::Memory  ::detail::  ThreadSlab_m | ||||
|  | ||||
| 			~ThreadSlab() | ||||
| 			{ | ||||
| 				std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 						<< (void *) this << " is retired." << std::endl; | ||||
| 				if( C::debugLifecycle ) | ||||
| 				{ | ||||
| 					std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 							<< (void *) this << " is retired." << std::endl; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			[[nodiscard]] T * | ||||
| 			allocate( const std::size_t amt ) | ||||
| 			{ | ||||
| 				// TODO: Alignment? | ||||
| 				// TODO: Alignment needs to be handled. | ||||
| 				const std::size_t req= amt + sizeof( Blob::StorageReservation ); | ||||
|  | ||||
| 				// TODO: Larger allocations may be worth bespoke allocations, if they're rare one-off cases | ||||
| 				if( req > C::slabSize ) throw std::bad_alloc{}; //{ "Unable to allocate larger than the slab size." }; | ||||
| 				if( slab.size() < req ) slab.reset( std::max( req, C::slabSize ) ); | ||||
|  | ||||
| 				std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 						<< (void *) this << " made an allocation." << std::endl; | ||||
| 				if( C::debugAllocation ) | ||||
| 				{ | ||||
| 					std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 							<< (void *) this << " made an allocation." << std::endl; | ||||
| 				} | ||||
|  | ||||
| 				auto next= slab.carveHead( req, Alignment{ sizeof( Blob::StorageReservation ) } ); | ||||
| 				auto next= slab.carveHead( req + sizeof( Blob::StorageReservation ) ); | ||||
| 				const auto rv= reinterpret_cast< T * >( &next.template as< Blob::StorageReservation >() + 1 ); | ||||
|  | ||||
| 				// FIXME: The placement new here is potentially unaligned -- this may significantly impact | ||||
| 				// performance. | ||||
| 				new ( &next.template as< Blob::StorageReservation >() ) Blob::StorageReservation{ std::move( next.reservation() ) }; | ||||
|  | ||||
| 				std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 						<< (void *) this << " made an allocation." << std::endl; | ||||
| 				if( C::debugAllocation ) | ||||
| 				{ | ||||
| 					std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 							<< (void *) this << " made an allocation." << std::endl; | ||||
| 				} | ||||
|  | ||||
| 				return rv; | ||||
| 			} | ||||
| @ -84,13 +103,20 @@ namespace Alepha::Hydrogen::Memory  ::detail::  ThreadSlab_m | ||||
| 			void | ||||
| 			deallocate( T *const p, const std::size_t /* ignored */ ) noexcept | ||||
| 			{ | ||||
| 				std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 						<< (void *) this << " made a deallocation." << std::endl; | ||||
| 				if( C::debugDeallocation ) | ||||
| 				{ | ||||
| 					std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 							<< (void *) this << " made a deallocation." << std::endl; | ||||
| 				} | ||||
|  | ||||
| 				auto *const hidden= reinterpret_cast< Blob::StorageReservation * >( p ) - 1; | ||||
| 				destroy( hidden ); | ||||
|  | ||||
| 				std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 						<< (void *) this << " made a deallocation." << std::endl; | ||||
| 				if( C::debugDeallocation ) | ||||
| 				{ | ||||
| 					std::cerr << "Reporting " << slab.reservation().use_count() << " living allocations when " | ||||
| 							<< (void *) this << " made a deallocation." << std::endl; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			friend constexpr bool operator == ( const ThreadSlab &, const ThreadSlab & ) noexcept { return true; } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user