QP/C
qs_blk.c
Go to the documentation of this file.
00001 /*****************************************************************************
00002 * Product:  QS/C
00003 * Last Updated for Version: 4.4.00
00004 * Date of the Last Update:  Jan 14, 2012
00005 *
00006 *                    Q u a n t u m     L e a P s
00007 *                    ---------------------------
00008 *                    innovating embedded systems
00009 *
00010 * Copyright (C) 2002-2012 Quantum Leaps, LLC. All rights reserved.
00011 *
00012 * This software may be distributed and modified under the terms of the GNU
00013 * General Public License version 2 (GPL) as published by the Free Software
00014 * Foundation and appearing in the file GPL.TXT included in the packaging of
00015 * this file. Please note that GPL Section 2[b] requires that all works based
00016 * on this software must also be made publicly available under the terms of
00017 * the GPL ("Copyleft").
00018 *
00019 * Alternatively, this software may be distributed and modified under the
00020 * terms of Quantum Leaps commercial licenses, which expressly supersede
00021 * the GPL and are specifically designed for licensees interested in
00022 * retaining the proprietary status of their code.
00023 *
00024 * Contact information:
00025 * Quantum Leaps Web site:  http://www.quantum-leaps.com
00026 * e-mail:                  info@quantum-leaps.com
00027 *****************************************************************************/
00028 #include "qs_pkg.h"
00029 
00036 /*..........................................................................*/
00037 /* get up to *pn bytes of contiguous memory */
00038 uint8_t const *QS_getBlock(uint16_t *pNbytes) {
00039     uint8_t *block;
00040     if (QS_used_ == (QSCtr)0) {
00041         *pNbytes = (uint16_t)0;
00042         block = (uint8_t *)0;               /* no bytes to return right now */
00043     }
00044     else {
00045         QSCtr t;
00046         QSCtr n = (QSCtr)(QS_end_ - QS_tail_);
00047         if (n > QS_used_) {
00048             n = QS_used_;
00049         }
00050         if (n > (QSCtr)(*pNbytes)) {
00051             n = (QSCtr)(*pNbytes);
00052         }
00053         *pNbytes = (uint16_t)n;
00054         QS_used_ = (QSCtr)(QS_used_ - n);
00055         t = QS_tail_;
00056         QS_tail_ = (QSCtr)(QS_tail_ + n);
00057         if (QS_tail_ == QS_end_) {
00058             QS_tail_ = (QSCtr)0;
00059         }
00060         block = &QS_PTR_AT_(t);
00061     }
00062     return block;
00063 }